Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
309a5702
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
309a5702
编写于
8月 19, 2014
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nouveau/bios: store aux addr independently of i2c
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
a7468451
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
73 addition
and
41 deletion
+73
-41
drivers/gpu/drm/nouveau/core/include/subdev/bios/i2c.h
drivers/gpu/drm/nouveau/core/include/subdev/bios/i2c.h
+1
-0
drivers/gpu/drm/nouveau/core/subdev/bios/i2c.c
drivers/gpu/drm/nouveau/core/subdev/bios/i2c.c
+21
-9
drivers/gpu/drm/nouveau/core/subdev/i2c/base.c
drivers/gpu/drm/nouveau/core/subdev/i2c/base.c
+49
-30
drivers/gpu/drm/nouveau/core/subdev/i2c/nv94.c
drivers/gpu/drm/nouveau/core/subdev/i2c/nv94.c
+2
-2
未找到文件。
drivers/gpu/drm/nouveau/core/include/subdev/bios/i2c.h
浏览文件 @
309a5702
...
...
@@ -16,6 +16,7 @@ struct dcb_i2c_entry {
u8
drive
;
u8
sense
;
u8
share
;
u8
auxch
;
};
u16
dcb_i2c_table
(
struct
nouveau_bios
*
,
u8
*
ver
,
u8
*
hdr
,
u8
*
cnt
,
u8
*
len
);
...
...
drivers/gpu/drm/nouveau/core/subdev/bios/i2c.c
浏览文件 @
309a5702
...
...
@@ -39,6 +39,11 @@ dcb_i2c_table(struct nouveau_bios *bios, u8 *ver, u8 *hdr, u8 *cnt, u8 *len)
i2c
=
nv_ro16
(
bios
,
dcb
+
4
);
}
if
(
i2c
&&
*
ver
>=
0x41
)
{
nv_warn
(
bios
,
"ccb %02x not supported
\n
"
,
*
ver
);
return
0x0000
;
}
if
(
i2c
&&
*
ver
>=
0x30
)
{
*
ver
=
nv_ro08
(
bios
,
i2c
+
0
);
*
hdr
=
nv_ro08
(
bios
,
i2c
+
1
);
...
...
@@ -70,14 +75,19 @@ dcb_i2c_parse(struct nouveau_bios *bios, u8 idx, struct dcb_i2c_entry *info)
u8
ver
,
len
;
u16
ent
=
dcb_i2c_entry
(
bios
,
idx
,
&
ver
,
&
len
);
if
(
ent
)
{
i
nfo
->
type
=
nv_ro08
(
bios
,
ent
+
3
);
info
->
share
=
DCB_I2C_UNUSED
;
if
(
ver
<
0x30
)
{
info
->
type
&=
0x07
;
i
f
(
ver
>=
0x30
)
{
info
->
type
=
nv_ro08
(
bios
,
ent
+
0x03
)
;
}
else
{
info
->
type
=
nv_ro08
(
bios
,
ent
+
0x03
)
&
0x07
;
if
(
info
->
type
==
0x07
)
info
->
type
=
DCB_I2C_UNUSED
;
}
info
->
drive
=
DCB_I2C_UNUSED
;
info
->
sense
=
DCB_I2C_UNUSED
;
info
->
share
=
DCB_I2C_UNUSED
;
info
->
auxch
=
DCB_I2C_UNUSED
;
switch
(
info
->
type
)
{
case
DCB_I2C_NV04_BIT
:
info
->
drive
=
nv_ro08
(
bios
,
ent
+
0
);
...
...
@@ -87,12 +97,14 @@ dcb_i2c_parse(struct nouveau_bios *bios, u8 idx, struct dcb_i2c_entry *info)
info
->
drive
=
nv_ro08
(
bios
,
ent
+
1
);
return
0
;
case
DCB_I2C_NVIO_BIT
:
case
DCB_I2C_NVIO_AUX
:
info
->
drive
=
nv_ro08
(
bios
,
ent
+
0
)
&
0x0f
;
if
(
nv_ro08
(
bios
,
ent
+
1
)
&
0x01
)
{
info
->
share
=
nv_ro08
(
bios
,
ent
+
1
)
>>
1
;
info
->
share
&=
0x0f
;
}
if
(
nv_ro08
(
bios
,
ent
+
1
)
&
0x01
)
info
->
share
=
nv_ro08
(
bios
,
ent
+
1
)
>>
1
;
return
0
;
case
DCB_I2C_NVIO_AUX
:
info
->
auxch
=
nv_ro08
(
bios
,
ent
+
0
)
&
0x0f
;
if
(
nv_ro08
(
bios
,
ent
+
1
)
&
0x01
)
info
->
share
=
info
->
auxch
;
return
0
;
case
DCB_I2C_UNUSED
:
return
0
;
...
...
drivers/gpu/drm/nouveau/core/subdev/i2c/base.c
浏览文件 @
309a5702
...
...
@@ -473,18 +473,56 @@ nouveau_i2c_extdev_sclass[] = {
nouveau_anx9805_sclass
,
};
static
void
nouveau_i2c_create_port
(
struct
nouveau_i2c
*
i2c
,
int
index
,
u8
type
,
struct
dcb_i2c_entry
*
info
)
{
const
struct
nouveau_i2c_impl
*
impl
=
(
void
*
)
nv_oclass
(
i2c
);
struct
nouveau_oclass
*
oclass
;
struct
nouveau_object
*
parent
;
struct
nouveau_object
*
object
;
int
ret
,
pad
;
if
(
info
->
share
!=
DCB_I2C_UNUSED
)
{
pad
=
info
->
share
;
oclass
=
impl
->
pad_s
;
}
else
{
if
(
type
!=
DCB_I2C_NVIO_AUX
)
pad
=
0x100
+
info
->
drive
;
else
pad
=
0x100
+
info
->
auxch
;
oclass
=
impl
->
pad_x
;
}
ret
=
nouveau_object_ctor
(
NULL
,
nv_object
(
i2c
),
oclass
,
NULL
,
pad
,
&
parent
);
if
(
ret
<
0
)
return
;
oclass
=
impl
->
sclass
;
do
{
ret
=
-
EINVAL
;
if
(
oclass
->
handle
==
type
)
{
ret
=
nouveau_object_ctor
(
parent
,
nv_object
(
i2c
),
oclass
,
info
,
index
,
&
object
);
}
}
while
(
ret
&&
(
++
oclass
)
->
handle
);
nouveau_object_ref
(
NULL
,
&
parent
);
}
int
nouveau_i2c_create_
(
struct
nouveau_object
*
parent
,
struct
nouveau_object
*
engine
,
struct
nouveau_oclass
*
oclass
,
int
length
,
void
**
pobject
)
{
const
struct
nouveau_i2c_impl
*
impl
=
(
void
*
)
oclass
;
struct
nouveau_bios
*
bios
=
nouveau_bios
(
parent
);
struct
nouveau_i2c
*
i2c
;
struct
nouveau_object
*
object
;
struct
dcb_i2c_entry
info
;
int
ret
,
i
,
j
,
index
=
-
1
,
pad
;
int
ret
,
i
,
j
,
index
=
-
1
;
struct
dcb_output
outp
;
u8
ver
,
hdr
;
u32
data
;
...
...
@@ -507,36 +545,17 @@ nouveau_i2c_create_(struct nouveau_object *parent,
INIT_LIST_HEAD
(
&
i2c
->
ports
);
while
(
!
dcb_i2c_parse
(
bios
,
++
index
,
&
info
))
{
if
(
info
.
type
==
DCB_I2C_UNUSED
)
switch
(
info
.
type
)
{
case
DCB_I2C_NV04_BIT
:
case
DCB_I2C_NV4E_BIT
:
case
DCB_I2C_NVIO_BIT
:
case
DCB_I2C_NVIO_AUX
:
nouveau_i2c_create_port
(
i2c
,
index
,
info
.
type
,
&
info
);
break
;
case
DCB_I2C_UNUSED
:
default:
continue
;
if
(
info
.
share
!=
DCB_I2C_UNUSED
)
{
if
(
info
.
type
==
DCB_I2C_NVIO_AUX
)
pad
=
info
.
drive
;
else
pad
=
info
.
share
;
oclass
=
impl
->
pad_s
;
}
else
{
pad
=
0x100
+
info
.
drive
;
oclass
=
impl
->
pad_x
;
}
ret
=
nouveau_object_ctor
(
NULL
,
*
pobject
,
oclass
,
NULL
,
pad
,
&
parent
);
if
(
ret
<
0
)
continue
;
oclass
=
impl
->
sclass
;
do
{
ret
=
-
EINVAL
;
if
(
oclass
->
handle
==
info
.
type
)
{
ret
=
nouveau_object_ctor
(
parent
,
*
pobject
,
oclass
,
&
info
,
index
,
&
object
);
}
}
while
(
ret
&&
(
++
oclass
)
->
handle
);
nouveau_object_ref
(
NULL
,
&
parent
);
}
/* in addition to the busses specified in the i2c table, there
...
...
drivers/gpu/drm/nouveau/core/subdev/i2c/nv94.c
浏览文件 @
309a5702
...
...
@@ -238,8 +238,8 @@ nv94_aux_port_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
if
(
ret
)
return
ret
;
port
->
base
.
aux
=
info
->
drive
;
port
->
addr
=
info
->
drive
;
port
->
base
.
aux
=
info
->
auxch
;
port
->
addr
=
info
->
auxch
;
return
0
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录