Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
75139063
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
75139063
编写于
7月 03, 2011
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nouveau/bios: fix INIT_GPIO for new chipsets
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
d7f8172c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
51 addition
and
22 deletion
+51
-22
drivers/gpu/drm/nouveau/nouveau_bios.c
drivers/gpu/drm/nouveau/nouveau_bios.c
+51
-22
未找到文件。
drivers/gpu/drm/nouveau/nouveau_bios.c
浏览文件 @
75139063
...
...
@@ -3221,6 +3221,49 @@ init_8d(struct nvbios *bios, uint16_t offset, struct init_exec *iexec)
return
1
;
}
static
void
init_gpio_unknv50
(
struct
nvbios
*
bios
,
struct
dcb_gpio_entry
*
gpio
)
{
const
uint32_t
nv50_gpio_ctl
[
2
]
=
{
0xe100
,
0xe28c
};
u32
r
,
s
,
v
;
/* Not a clue, needs de-magicing */
r
=
nv50_gpio_ctl
[
gpio
->
line
>>
4
];
s
=
(
gpio
->
line
&
0x0f
);
v
=
bios_rd32
(
bios
,
r
)
&
~
(
0x00010001
<<
s
);
switch
((
gpio
->
entry
&
0x06000000
)
>>
25
)
{
case
1
:
v
|=
(
0x00000001
<<
s
);
break
;
case
2
:
v
|=
(
0x00010000
<<
s
);
break
;
default:
break
;
}
bios_wr32
(
bios
,
r
,
v
);
}
static
void
init_gpio_unknvd0
(
struct
nvbios
*
bios
,
struct
dcb_gpio_entry
*
gpio
)
{
u32
v
,
i
;
v
=
bios_rd32
(
bios
,
0x00d610
+
(
gpio
->
line
*
4
));
v
&=
0xffffff00
;
v
|=
(
gpio
->
entry
&
0x00ff0000
)
>>
16
;
bios_wr32
(
bios
,
0x00d610
+
(
gpio
->
line
*
4
),
v
);
i
=
(
gpio
->
entry
&
0x1f000000
)
>>
24
;
if
(
i
)
{
v
=
bios_rd32
(
bios
,
0x00d640
+
((
i
-
1
)
*
4
));
v
&=
0xffffff00
;
v
|=
gpio
->
line
;
bios_wr32
(
bios
,
0x00d640
+
((
i
-
1
)
*
4
),
v
);
}
}
static
int
init_gpio
(
struct
nvbios
*
bios
,
uint16_t
offset
,
struct
init_exec
*
iexec
)
{
...
...
@@ -3235,7 +3278,6 @@ init_gpio(struct nvbios *bios, uint16_t offset, struct init_exec *iexec)
struct
drm_nouveau_private
*
dev_priv
=
bios
->
dev
->
dev_private
;
struct
nouveau_gpio_engine
*
pgpio
=
&
dev_priv
->
engine
.
gpio
;
const
uint32_t
nv50_gpio_ctl
[
2
]
=
{
0xe100
,
0xe28c
};
int
i
;
if
(
dev_priv
->
card_type
<
NV_50
)
{
...
...
@@ -3248,33 +3290,20 @@ init_gpio(struct nvbios *bios, uint16_t offset, struct init_exec *iexec)
for
(
i
=
0
;
i
<
bios
->
dcb
.
gpio
.
entries
;
i
++
)
{
struct
dcb_gpio_entry
*
gpio
=
&
bios
->
dcb
.
gpio
.
entry
[
i
];
uint32_t
r
,
s
,
v
;
BIOSLOG
(
bios
,
"0x%04X: Entry: 0x%08X
\n
"
,
offset
,
gpio
->
entry
);
BIOSLOG
(
bios
,
"0x%04X: set gpio 0x%02x, state %d
\n
"
,
offset
,
gpio
->
tag
,
gpio
->
state_default
);
if
(
bios
->
execute
)
pgpio
->
set
(
bios
->
dev
,
gpio
->
tag
,
gpio
->
state_default
);
/* The NVIDIA binary driver doesn't appear to actually do
* any of this, my VBIOS does however.
*/
/* Not a clue, needs de-magicing */
r
=
nv50_gpio_ctl
[
gpio
->
line
>>
4
];
s
=
(
gpio
->
line
&
0x0f
);
v
=
bios_rd32
(
bios
,
r
)
&
~
(
0x00010001
<<
s
);
switch
((
gpio
->
entry
&
0x06000000
)
>>
25
)
{
case
1
:
v
|=
(
0x00000001
<<
s
);
break
;
case
2
:
v
|=
(
0x00010000
<<
s
);
break
;
default:
break
;
}
bios_wr32
(
bios
,
r
,
v
);
if
(
!
bios
->
execute
)
continue
;
pgpio
->
set
(
bios
->
dev
,
gpio
->
tag
,
gpio
->
state_default
);
if
(
dev_priv
->
card_type
<
NV_D0
)
init_gpio_unknv50
(
bios
,
gpio
);
else
init_gpio_unknvd0
(
bios
,
gpio
);
}
return
1
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录