Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
82e02935
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看板
提交
82e02935
编写于
8月 16, 2012
作者:
A
Alex Deucher
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/radeon: document radeon_atpx_handler.c (v2)
v2: rebase updates Signed-off-by:
N
Alex Deucher
<
alexander.deucher@amd.com
>
上级
492b49a2
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
111 addition
and
0 deletion
+111
-0
drivers/gpu/drm/radeon/radeon_atpx_handler.c
drivers/gpu/drm/radeon/radeon_atpx_handler.c
+111
-0
未找到文件。
drivers/gpu/drm/radeon/radeon_atpx_handler.c
浏览文件 @
82e02935
...
@@ -166,6 +166,16 @@ static int radeon_atpx_verify_interface(struct radeon_atpx *atpx)
...
@@ -166,6 +166,16 @@ static int radeon_atpx_verify_interface(struct radeon_atpx *atpx)
return
err
;
return
err
;
}
}
/**
* radeon_atpx_set_discrete_state - power up/down discrete GPU
*
* @atpx: atpx info struct
* @state: discrete GPU state (0 = power down, 1 = power up)
*
* Execute the ATPX_FUNCTION_POWER_CONTROL ATPX function to
* power down/up the discrete GPU (all asics).
* Returns 0 on success, error on failure.
*/
static
int
radeon_atpx_set_discrete_state
(
struct
radeon_atpx
*
atpx
,
u8
state
)
static
int
radeon_atpx_set_discrete_state
(
struct
radeon_atpx
*
atpx
,
u8
state
)
{
{
struct
acpi_buffer
params
;
struct
acpi_buffer
params
;
...
@@ -187,6 +197,17 @@ static int radeon_atpx_set_discrete_state(struct radeon_atpx *atpx, u8 state)
...
@@ -187,6 +197,17 @@ static int radeon_atpx_set_discrete_state(struct radeon_atpx *atpx, u8 state)
return
0
;
return
0
;
}
}
/**
* radeon_atpx_switch_disp_mux - switch display mux
*
* @atpx: atpx info struct
* @mux_id: mux state (0 = integrated GPU, 1 = discrete GPU)
*
* Execute the ATPX_FUNCTION_DISPLAY_MUX_CONTROL ATPX function to
* switch the display mux between the discrete GPU and integrated GPU
* (all asics).
* Returns 0 on success, error on failure.
*/
static
int
radeon_atpx_switch_disp_mux
(
struct
radeon_atpx
*
atpx
,
u16
mux_id
)
static
int
radeon_atpx_switch_disp_mux
(
struct
radeon_atpx
*
atpx
,
u16
mux_id
)
{
{
struct
acpi_buffer
params
;
struct
acpi_buffer
params
;
...
@@ -208,6 +229,17 @@ static int radeon_atpx_switch_disp_mux(struct radeon_atpx *atpx, u16 mux_id)
...
@@ -208,6 +229,17 @@ static int radeon_atpx_switch_disp_mux(struct radeon_atpx *atpx, u16 mux_id)
return
0
;
return
0
;
}
}
/**
* radeon_atpx_switch_i2c_mux - switch i2c/hpd mux
*
* @atpx: atpx info struct
* @mux_id: mux state (0 = integrated GPU, 1 = discrete GPU)
*
* Execute the ATPX_FUNCTION_I2C_MUX_CONTROL ATPX function to
* switch the i2c/hpd mux between the discrete GPU and integrated GPU
* (all asics).
* Returns 0 on success, error on failure.
*/
static
int
radeon_atpx_switch_i2c_mux
(
struct
radeon_atpx
*
atpx
,
u16
mux_id
)
static
int
radeon_atpx_switch_i2c_mux
(
struct
radeon_atpx
*
atpx
,
u16
mux_id
)
{
{
struct
acpi_buffer
params
;
struct
acpi_buffer
params
;
...
@@ -229,6 +261,17 @@ static int radeon_atpx_switch_i2c_mux(struct radeon_atpx *atpx, u16 mux_id)
...
@@ -229,6 +261,17 @@ static int radeon_atpx_switch_i2c_mux(struct radeon_atpx *atpx, u16 mux_id)
return
0
;
return
0
;
}
}
/**
* radeon_atpx_switch_start - notify the sbios of a GPU switch
*
* @atpx: atpx info struct
* @mux_id: mux state (0 = integrated GPU, 1 = discrete GPU)
*
* Execute the ATPX_FUNCTION_GRAPHICS_DEVICE_SWITCH_START_NOTIFICATION ATPX
* function to notify the sbios that a switch between the discrete GPU and
* integrated GPU has begun (all asics).
* Returns 0 on success, error on failure.
*/
static
int
radeon_atpx_switch_start
(
struct
radeon_atpx
*
atpx
,
u16
mux_id
)
static
int
radeon_atpx_switch_start
(
struct
radeon_atpx
*
atpx
,
u16
mux_id
)
{
{
struct
acpi_buffer
params
;
struct
acpi_buffer
params
;
...
@@ -250,6 +293,17 @@ static int radeon_atpx_switch_start(struct radeon_atpx *atpx, u16 mux_id)
...
@@ -250,6 +293,17 @@ static int radeon_atpx_switch_start(struct radeon_atpx *atpx, u16 mux_id)
return
0
;
return
0
;
}
}
/**
* radeon_atpx_switch_end - notify the sbios of a GPU switch
*
* @atpx: atpx info struct
* @mux_id: mux state (0 = integrated GPU, 1 = discrete GPU)
*
* Execute the ATPX_FUNCTION_GRAPHICS_DEVICE_SWITCH_END_NOTIFICATION ATPX
* function to notify the sbios that a switch between the discrete GPU and
* integrated GPU has ended (all asics).
* Returns 0 on success, error on failure.
*/
static
int
radeon_atpx_switch_end
(
struct
radeon_atpx
*
atpx
,
u16
mux_id
)
static
int
radeon_atpx_switch_end
(
struct
radeon_atpx
*
atpx
,
u16
mux_id
)
{
{
struct
acpi_buffer
params
;
struct
acpi_buffer
params
;
...
@@ -271,6 +325,15 @@ static int radeon_atpx_switch_end(struct radeon_atpx *atpx, u16 mux_id)
...
@@ -271,6 +325,15 @@ static int radeon_atpx_switch_end(struct radeon_atpx *atpx, u16 mux_id)
return
0
;
return
0
;
}
}
/**
* radeon_atpx_switchto - switch to the requested GPU
*
* @id: GPU to switch to
*
* Execute the necessary ATPX functions to switch between the discrete GPU and
* integrated GPU (all asics).
* Returns 0 on success, error on failure.
*/
static
int
radeon_atpx_switchto
(
enum
vga_switcheroo_client_id
id
)
static
int
radeon_atpx_switchto
(
enum
vga_switcheroo_client_id
id
)
{
{
u16
gpu_id
;
u16
gpu_id
;
...
@@ -288,6 +351,16 @@ static int radeon_atpx_switchto(enum vga_switcheroo_client_id id)
...
@@ -288,6 +351,16 @@ static int radeon_atpx_switchto(enum vga_switcheroo_client_id id)
return
0
;
return
0
;
}
}
/**
* radeon_atpx_switchto - switch to the requested GPU
*
* @id: GPU to switch to
* @state: requested power state (0 = off, 1 = on)
*
* Execute the necessary ATPX function to power down/up the discrete GPU
* (all asics).
* Returns 0 on success, error on failure.
*/
static
int
radeon_atpx_power_state
(
enum
vga_switcheroo_client_id
id
,
static
int
radeon_atpx_power_state
(
enum
vga_switcheroo_client_id
id
,
enum
vga_switcheroo_state
state
)
enum
vga_switcheroo_state
state
)
{
{
...
@@ -299,6 +372,14 @@ static int radeon_atpx_power_state(enum vga_switcheroo_client_id id,
...
@@ -299,6 +372,14 @@ static int radeon_atpx_power_state(enum vga_switcheroo_client_id id,
return
0
;
return
0
;
}
}
/**
* radeon_atpx_pci_probe_handle - look up the ATRM and ATPX handles
*
* @pdev: pci device
*
* Look up the ATPX and ATRM handles (all asics).
* Returns true if the handles are found, false if not.
*/
static
bool
radeon_atpx_pci_probe_handle
(
struct
pci_dev
*
pdev
)
static
bool
radeon_atpx_pci_probe_handle
(
struct
pci_dev
*
pdev
)
{
{
acpi_handle
dhandle
,
atpx_handle
;
acpi_handle
dhandle
,
atpx_handle
;
...
@@ -317,12 +398,26 @@ static bool radeon_atpx_pci_probe_handle(struct pci_dev *pdev)
...
@@ -317,12 +398,26 @@ static bool radeon_atpx_pci_probe_handle(struct pci_dev *pdev)
return
true
;
return
true
;
}
}
/**
* radeon_atpx_init - verify the ATPX interface
*
* Verify the ATPX interface (all asics).
* Returns 0 on success, error on failure.
*/
static
int
radeon_atpx_init
(
void
)
static
int
radeon_atpx_init
(
void
)
{
{
/* set up the ATPX handle */
/* set up the ATPX handle */
return
radeon_atpx_verify_interface
(
&
radeon_atpx_priv
.
atpx
);
return
radeon_atpx_verify_interface
(
&
radeon_atpx_priv
.
atpx
);
}
}
/**
* radeon_atpx_get_client_id - get the client id
*
* @pdev: pci device
*
* look up whether we are the integrated or discrete GPU (all asics).
* Returns the client id.
*/
static
int
radeon_atpx_get_client_id
(
struct
pci_dev
*
pdev
)
static
int
radeon_atpx_get_client_id
(
struct
pci_dev
*
pdev
)
{
{
if
(
radeon_atpx_priv
.
dhandle
==
DEVICE_ACPI_HANDLE
(
&
pdev
->
dev
))
if
(
radeon_atpx_priv
.
dhandle
==
DEVICE_ACPI_HANDLE
(
&
pdev
->
dev
))
...
@@ -338,6 +433,12 @@ static struct vga_switcheroo_handler radeon_atpx_handler = {
...
@@ -338,6 +433,12 @@ static struct vga_switcheroo_handler radeon_atpx_handler = {
.
get_client_id
=
radeon_atpx_get_client_id
,
.
get_client_id
=
radeon_atpx_get_client_id
,
};
};
/**
* radeon_atpx_detect - detect whether we have PX
*
* Check if we have a PX system (all asics).
* Returns true if we have a PX system, false if not.
*/
static
bool
radeon_atpx_detect
(
void
)
static
bool
radeon_atpx_detect
(
void
)
{
{
char
acpi_method_name
[
255
]
=
{
0
};
char
acpi_method_name
[
255
]
=
{
0
};
...
@@ -362,6 +463,11 @@ static bool radeon_atpx_detect(void)
...
@@ -362,6 +463,11 @@ static bool radeon_atpx_detect(void)
return
false
;
return
false
;
}
}
/**
* radeon_register_atpx_handler - register with vga_switcheroo
*
* Register the PX callbacks with vga_switcheroo (all asics).
*/
void
radeon_register_atpx_handler
(
void
)
void
radeon_register_atpx_handler
(
void
)
{
{
bool
r
;
bool
r
;
...
@@ -374,6 +480,11 @@ void radeon_register_atpx_handler(void)
...
@@ -374,6 +480,11 @@ void radeon_register_atpx_handler(void)
vga_switcheroo_register_handler
(
&
radeon_atpx_handler
);
vga_switcheroo_register_handler
(
&
radeon_atpx_handler
);
}
}
/**
* radeon_unregister_atpx_handler - unregister with vga_switcheroo
*
* Unregister the PX callbacks with vga_switcheroo (all asics).
*/
void
radeon_unregister_atpx_handler
(
void
)
void
radeon_unregister_atpx_handler
(
void
)
{
{
vga_switcheroo_unregister_handler
();
vga_switcheroo_unregister_handler
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录