Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
f9f9f536
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看板
提交
f9f9f536
编写于
10月 12, 2011
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nouveau/bios: pass drm_device to ROMPTR, rather than nvbios
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
816af2f2
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
28 addition
and
27 deletion
+28
-27
drivers/gpu/drm/nouveau/nouveau_bios.c
drivers/gpu/drm/nouveau/nouveau_bios.c
+5
-5
drivers/gpu/drm/nouveau/nouveau_bios.h
drivers/gpu/drm/nouveau/nouveau_bios.h
+8
-3
drivers/gpu/drm/nouveau/nouveau_dp.c
drivers/gpu/drm/nouveau/nouveau_dp.c
+3
-6
drivers/gpu/drm/nouveau/nouveau_mem.c
drivers/gpu/drm/nouveau/nouveau_mem.c
+2
-2
drivers/gpu/drm/nouveau/nouveau_perf.c
drivers/gpu/drm/nouveau/nouveau_perf.c
+5
-6
drivers/gpu/drm/nouveau/nouveau_temp.c
drivers/gpu/drm/nouveau/nouveau_temp.c
+2
-2
drivers/gpu/drm/nouveau/nouveau_volt.c
drivers/gpu/drm/nouveau/nouveau_volt.c
+3
-3
未找到文件。
drivers/gpu/drm/nouveau/nouveau_bios.c
浏览文件 @
f9f9f536
...
@@ -4541,7 +4541,7 @@ nouveau_bios_run_display_table(struct drm_device *dev, u16 type, int pclk,
...
@@ -4541,7 +4541,7 @@ nouveau_bios_run_display_table(struct drm_device *dev, u16 type, int pclk,
NV_DEBUG_KMS
(
dev
,
"Searching for output entry for %d %d %d
\n
"
,
NV_DEBUG_KMS
(
dev
,
"Searching for output entry for %d %d %d
\n
"
,
dcbent
->
type
,
dcbent
->
location
,
dcbent
->
or
);
dcbent
->
type
,
dcbent
->
location
,
dcbent
->
or
);
for
(
i
=
0
;
i
<
table
[
3
];
i
++
)
{
for
(
i
=
0
;
i
<
table
[
3
];
i
++
)
{
otable
=
ROMPTR
(
bios
,
table
[
table
[
1
]
+
(
i
*
table
[
2
])]);
otable
=
ROMPTR
(
dev
,
table
[
table
[
1
]
+
(
i
*
table
[
2
])]);
if
(
otable
&&
bios_encoder_match
(
dcbent
,
ROM32
(
otable
[
0
])))
if
(
otable
&&
bios_encoder_match
(
dcbent
,
ROM32
(
otable
[
0
])))
break
;
break
;
}
}
...
@@ -5493,7 +5493,7 @@ bit_table(struct drm_device *dev, u8 id, struct bit_entry *bit)
...
@@ -5493,7 +5493,7 @@ bit_table(struct drm_device *dev, u8 id, struct bit_entry *bit)
bit
->
version
=
entry
[
1
];
bit
->
version
=
entry
[
1
];
bit
->
length
=
ROM16
(
entry
[
2
]);
bit
->
length
=
ROM16
(
entry
[
2
]);
bit
->
offset
=
ROM16
(
entry
[
4
]);
bit
->
offset
=
ROM16
(
entry
[
4
]);
bit
->
data
=
ROMPTR
(
bios
,
entry
[
4
]);
bit
->
data
=
ROMPTR
(
dev
,
entry
[
4
]);
return
0
;
return
0
;
}
}
...
@@ -5807,9 +5807,9 @@ parse_dcb_gpio_table(struct nvbios *bios)
...
@@ -5807,9 +5807,9 @@ parse_dcb_gpio_table(struct nvbios *bios)
u8
*
dcb
,
*
gpio
=
NULL
,
*
entry
;
u8
*
dcb
,
*
gpio
=
NULL
,
*
entry
;
int
i
;
int
i
;
dcb
=
ROMPTR
(
bios
,
bios
->
data
[
0x36
]);
dcb
=
ROMPTR
(
dev
,
bios
->
data
[
0x36
]);
if
(
dcb
[
0
]
>=
0x30
)
{
if
(
dcb
[
0
]
>=
0x30
)
{
gpio
=
ROMPTR
(
bios
,
dcb
[
10
]);
gpio
=
ROMPTR
(
dev
,
dcb
[
10
]);
if
(
!
gpio
)
if
(
!
gpio
)
goto
no_table
;
goto
no_table
;
...
@@ -5818,7 +5818,7 @@ parse_dcb_gpio_table(struct nvbios *bios)
...
@@ -5818,7 +5818,7 @@ parse_dcb_gpio_table(struct nvbios *bios)
recordlen
=
gpio
[
3
];
recordlen
=
gpio
[
3
];
}
else
}
else
if
(
dcb
[
0
]
>=
0x22
&&
dcb
[
-
1
]
>=
0x13
)
{
if
(
dcb
[
0
]
>=
0x22
&&
dcb
[
-
1
]
>=
0x13
)
{
gpio
=
ROMPTR
(
bios
,
dcb
[
-
15
]);
gpio
=
ROMPTR
(
dev
,
dcb
[
-
15
]);
if
(
!
gpio
)
if
(
!
gpio
)
goto
no_table
;
goto
no_table
;
...
...
drivers/gpu/drm/nouveau/nouveau_bios.h
浏览文件 @
f9f9f536
...
@@ -34,9 +34,14 @@
...
@@ -34,9 +34,14 @@
#define DCB_LOC_ON_CHIP 0
#define DCB_LOC_ON_CHIP 0
#define ROM16(x) le16_to_cpu(*(uint16_t *)&(x))
#define ROM16(x) le16_to_cpu(*(u16 *)&(x))
#define ROM32(x) le32_to_cpu(*(uint32_t *)&(x))
#define ROM32(x) le32_to_cpu(*(u32 *)&(x))
#define ROMPTR(bios, x) (ROM16(x) ? &(bios)->data[ROM16(x)] : NULL)
#define ROM48(x) ({ u8 *p = &(x); (u64)ROM16(p[4]) << 32 | ROM32(p[0]); })
#define ROM64(x) le64_to_cpu(*(u64 *)&(x))
#define ROMPTR(d,x) ({ \
struct drm_nouveau_private *dev_priv = (d)->dev_private; \
ROM16(x) ? &dev_priv->vbios.data[ROM16(x)] : NULL; \
})
struct
bit_entry
{
struct
bit_entry
{
uint8_t
id
;
uint8_t
id
;
...
...
drivers/gpu/drm/nouveau/nouveau_dp.c
浏览文件 @
f9f9f536
...
@@ -273,8 +273,6 @@ nouveau_dp_tu_update(struct drm_device *dev, int or, int link, u32 clk, u32 bpp)
...
@@ -273,8 +273,6 @@ nouveau_dp_tu_update(struct drm_device *dev, int or, int link, u32 clk, u32 bpp)
u8
*
u8
*
nouveau_dp_bios_data
(
struct
drm_device
*
dev
,
struct
dcb_entry
*
dcb
,
u8
**
entry
)
nouveau_dp_bios_data
(
struct
drm_device
*
dev
,
struct
dcb_entry
*
dcb
,
u8
**
entry
)
{
{
struct
drm_nouveau_private
*
dev_priv
=
dev
->
dev_private
;
struct
nvbios
*
bios
=
&
dev_priv
->
vbios
;
struct
bit_entry
d
;
struct
bit_entry
d
;
u8
*
table
;
u8
*
table
;
int
i
;
int
i
;
...
@@ -289,7 +287,7 @@ nouveau_dp_bios_data(struct drm_device *dev, struct dcb_entry *dcb, u8 **entry)
...
@@ -289,7 +287,7 @@ nouveau_dp_bios_data(struct drm_device *dev, struct dcb_entry *dcb, u8 **entry)
return
NULL
;
return
NULL
;
}
}
table
=
ROMPTR
(
bios
,
d
.
data
[
0
]);
table
=
ROMPTR
(
dev
,
d
.
data
[
0
]);
if
(
!
table
)
{
if
(
!
table
)
{
NV_ERROR
(
dev
,
"displayport table pointer invalid
\n
"
);
NV_ERROR
(
dev
,
"displayport table pointer invalid
\n
"
);
return
NULL
;
return
NULL
;
...
@@ -306,7 +304,7 @@ nouveau_dp_bios_data(struct drm_device *dev, struct dcb_entry *dcb, u8 **entry)
...
@@ -306,7 +304,7 @@ nouveau_dp_bios_data(struct drm_device *dev, struct dcb_entry *dcb, u8 **entry)
}
}
for
(
i
=
0
;
i
<
table
[
3
];
i
++
)
{
for
(
i
=
0
;
i
<
table
[
3
];
i
++
)
{
*
entry
=
ROMPTR
(
bios
,
table
[
table
[
1
]
+
(
i
*
table
[
2
])]);
*
entry
=
ROMPTR
(
dev
,
table
[
table
[
1
]
+
(
i
*
table
[
2
])]);
if
(
*
entry
&&
bios_encoder_match
(
dcb
,
ROM32
((
*
entry
)[
0
])))
if
(
*
entry
&&
bios_encoder_match
(
dcb
,
ROM32
((
*
entry
)[
0
])))
return
table
;
return
table
;
}
}
...
@@ -336,7 +334,6 @@ struct dp_state {
...
@@ -336,7 +334,6 @@ struct dp_state {
static
void
static
void
dp_set_link_config
(
struct
drm_device
*
dev
,
struct
dp_state
*
dp
)
dp_set_link_config
(
struct
drm_device
*
dev
,
struct
dp_state
*
dp
)
{
{
struct
drm_nouveau_private
*
dev_priv
=
dev
->
dev_private
;
int
or
=
dp
->
or
,
link
=
dp
->
link
;
int
or
=
dp
->
or
,
link
=
dp
->
link
;
u8
*
entry
,
sink
[
2
];
u8
*
entry
,
sink
[
2
];
u32
dp_ctrl
;
u32
dp_ctrl
;
...
@@ -360,7 +357,7 @@ dp_set_link_config(struct drm_device *dev, struct dp_state *dp)
...
@@ -360,7 +357,7 @@ dp_set_link_config(struct drm_device *dev, struct dp_state *dp)
* table, that has (among other things) pointers to more scripts that
* table, that has (among other things) pointers to more scripts that
* need to be executed, this time depending on link speed.
* need to be executed, this time depending on link speed.
*/
*/
entry
=
ROMPTR
(
&
dev_priv
->
vbios
,
dp
->
entry
[
10
]);
entry
=
ROMPTR
(
dev
,
dp
->
entry
[
10
]);
if
(
entry
)
{
if
(
entry
)
{
if
(
dp
->
table
[
0
]
<
0x30
)
{
if
(
dp
->
table
[
0
]
<
0x30
)
{
while
(
dp
->
link_bw
<
(
ROM16
(
entry
[
0
])
*
10
))
while
(
dp
->
link_bw
<
(
ROM16
(
entry
[
0
])
*
10
))
...
...
drivers/gpu/drm/nouveau/nouveau_mem.c
浏览文件 @
f9f9f536
...
@@ -644,10 +644,10 @@ nouveau_mem_timing_init(struct drm_device *dev)
...
@@ -644,10 +644,10 @@ nouveau_mem_timing_init(struct drm_device *dev)
return
;
return
;
if
(
P
.
version
==
1
)
if
(
P
.
version
==
1
)
hdr
=
(
struct
nouveau_pm_tbl_header
*
)
ROMPTR
(
bios
,
P
.
data
[
4
]);
hdr
=
(
struct
nouveau_pm_tbl_header
*
)
ROMPTR
(
dev
,
P
.
data
[
4
]);
else
else
if
(
P
.
version
==
2
)
if
(
P
.
version
==
2
)
hdr
=
(
struct
nouveau_pm_tbl_header
*
)
ROMPTR
(
bios
,
P
.
data
[
8
]);
hdr
=
(
struct
nouveau_pm_tbl_header
*
)
ROMPTR
(
dev
,
P
.
data
[
8
]);
else
{
else
{
NV_WARN
(
dev
,
"unknown mem for BIT P %d
\n
"
,
P
.
version
);
NV_WARN
(
dev
,
"unknown mem for BIT P %d
\n
"
,
P
.
version
);
}
}
...
...
drivers/gpu/drm/nouveau/nouveau_perf.c
浏览文件 @
f9f9f536
...
@@ -41,7 +41,7 @@ legacy_perf_init(struct drm_device *dev)
...
@@ -41,7 +41,7 @@ legacy_perf_init(struct drm_device *dev)
return
;
return
;
}
}
perf
=
ROMPTR
(
bios
,
bmp
[
0x73
]);
perf
=
ROMPTR
(
dev
,
bmp
[
0x73
]);
if
(
!
perf
)
{
if
(
!
perf
)
{
NV_DEBUG
(
dev
,
"No memclock table pointer found.
\n
"
);
NV_DEBUG
(
dev
,
"No memclock table pointer found.
\n
"
);
return
;
return
;
...
@@ -87,7 +87,7 @@ nouveau_perf_timing(struct drm_device *dev, struct bit_entry *P,
...
@@ -87,7 +87,7 @@ nouveau_perf_timing(struct drm_device *dev, struct bit_entry *P,
* ramcfg to select the correct subentry
* ramcfg to select the correct subentry
*/
*/
if
(
P
->
version
==
2
)
{
if
(
P
->
version
==
2
)
{
u8
*
tmap
=
ROMPTR
(
bios
,
P
->
data
[
4
]);
u8
*
tmap
=
ROMPTR
(
dev
,
P
->
data
[
4
]);
if
(
!
tmap
)
{
if
(
!
tmap
)
{
NV_DEBUG
(
dev
,
"no timing map pointer
\n
"
);
NV_DEBUG
(
dev
,
"no timing map pointer
\n
"
);
return
NULL
;
return
NULL
;
...
@@ -140,7 +140,6 @@ nouveau_perf_voltage(struct drm_device *dev, struct bit_entry *P,
...
@@ -140,7 +140,6 @@ nouveau_perf_voltage(struct drm_device *dev, struct bit_entry *P,
struct
nouveau_pm_level
*
perflvl
)
struct
nouveau_pm_level
*
perflvl
)
{
{
struct
drm_nouveau_private
*
dev_priv
=
dev
->
dev_private
;
struct
drm_nouveau_private
*
dev_priv
=
dev
->
dev_private
;
struct
nvbios
*
bios
=
&
dev_priv
->
vbios
;
u8
*
vmap
;
u8
*
vmap
;
int
id
;
int
id
;
...
@@ -165,7 +164,7 @@ nouveau_perf_voltage(struct drm_device *dev, struct bit_entry *P,
...
@@ -165,7 +164,7 @@ nouveau_perf_voltage(struct drm_device *dev, struct bit_entry *P,
return
;
return
;
}
}
vmap
=
ROMPTR
(
bios
,
P
->
data
[
32
]);
vmap
=
ROMPTR
(
dev
,
P
->
data
[
32
]);
if
(
!
vmap
)
{
if
(
!
vmap
)
{
NV_DEBUG
(
dev
,
"volt map table pointer invalid
\n
"
);
NV_DEBUG
(
dev
,
"volt map table pointer invalid
\n
"
);
return
;
return
;
...
@@ -200,7 +199,7 @@ nouveau_perf_init(struct drm_device *dev)
...
@@ -200,7 +199,7 @@ nouveau_perf_init(struct drm_device *dev)
return
;
return
;
}
}
perf
=
ROMPTR
(
bios
,
P
.
data
[
0
]);
perf
=
ROMPTR
(
dev
,
P
.
data
[
0
]);
version
=
perf
[
0
];
version
=
perf
[
0
];
headerlen
=
perf
[
1
];
headerlen
=
perf
[
1
];
if
(
version
<
0x40
)
{
if
(
version
<
0x40
)
{
...
@@ -218,7 +217,7 @@ nouveau_perf_init(struct drm_device *dev)
...
@@ -218,7 +217,7 @@ nouveau_perf_init(struct drm_device *dev)
return
;
return
;
}
}
perf
=
ROMPTR
(
bios
,
bios
->
data
[
bios
->
offset
+
0x94
]);
perf
=
ROMPTR
(
dev
,
bios
->
data
[
bios
->
offset
+
0x94
]);
if
(
!
perf
)
{
if
(
!
perf
)
{
NV_DEBUG
(
dev
,
"perf table pointer invalid
\n
"
);
NV_DEBUG
(
dev
,
"perf table pointer invalid
\n
"
);
return
;
return
;
...
...
drivers/gpu/drm/nouveau/nouveau_temp.c
浏览文件 @
f9f9f536
...
@@ -316,9 +316,9 @@ nouveau_temp_init(struct drm_device *dev)
...
@@ -316,9 +316,9 @@ nouveau_temp_init(struct drm_device *dev)
return
;
return
;
if
(
P
.
version
==
1
)
if
(
P
.
version
==
1
)
temp
=
ROMPTR
(
bios
,
P
.
data
[
12
]);
temp
=
ROMPTR
(
dev
,
P
.
data
[
12
]);
else
if
(
P
.
version
==
2
)
else
if
(
P
.
version
==
2
)
temp
=
ROMPTR
(
bios
,
P
.
data
[
16
]);
temp
=
ROMPTR
(
dev
,
P
.
data
[
16
]);
else
else
NV_WARN
(
dev
,
"unknown temp for BIT P %d
\n
"
,
P
.
version
);
NV_WARN
(
dev
,
"unknown temp for BIT P %d
\n
"
,
P
.
version
);
...
...
drivers/gpu/drm/nouveau/nouveau_volt.c
浏览文件 @
f9f9f536
...
@@ -117,10 +117,10 @@ nouveau_volt_init(struct drm_device *dev)
...
@@ -117,10 +117,10 @@ nouveau_volt_init(struct drm_device *dev)
return
;
return
;
if
(
P
.
version
==
1
)
if
(
P
.
version
==
1
)
volt
=
ROMPTR
(
bios
,
P
.
data
[
16
]);
volt
=
ROMPTR
(
dev
,
P
.
data
[
16
]);
else
else
if
(
P
.
version
==
2
)
if
(
P
.
version
==
2
)
volt
=
ROMPTR
(
bios
,
P
.
data
[
12
]);
volt
=
ROMPTR
(
dev
,
P
.
data
[
12
]);
else
{
else
{
NV_WARN
(
dev
,
"unknown volt for BIT P %d
\n
"
,
P
.
version
);
NV_WARN
(
dev
,
"unknown volt for BIT P %d
\n
"
,
P
.
version
);
}
}
...
@@ -130,7 +130,7 @@ nouveau_volt_init(struct drm_device *dev)
...
@@ -130,7 +130,7 @@ nouveau_volt_init(struct drm_device *dev)
return
;
return
;
}
}
volt
=
ROMPTR
(
bios
,
bios
->
data
[
bios
->
offset
+
0x98
]);
volt
=
ROMPTR
(
dev
,
bios
->
data
[
bios
->
offset
+
0x98
]);
}
}
if
(
!
volt
)
{
if
(
!
volt
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录