Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
2ea7249f
Commit
2ea7249f
authored
Aug 20, 2015
by
Ben Skeggs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
drm/nouveau/gpio: convert to new-style nvkm_subdev
Signed-off-by:
Ben Skeggs
<
bskeggs@redhat.com
>
parent
c5fcafa5
Changes
30
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
30 changed files
with
252 additions
and
370 deletions
+252
-370
drivers/gpu/drm/nouveau/dispnv04/dac.c
drivers/gpu/drm/nouveau/dispnv04/dac.c
+6
-6
drivers/gpu/drm/nouveau/dispnv04/tvnv17.c
drivers/gpu/drm/nouveau/dispnv04/tvnv17.c
+8
-8
drivers/gpu/drm/nouveau/include/nvif/device.h
drivers/gpu/drm/nouveau/include/nvif/device.h
+1
-1
drivers/gpu/drm/nouveau/include/nvkm/subdev/gpio.h
drivers/gpu/drm/nouveau/include/nvkm/subdev/gpio.h
+12
-17
drivers/gpu/drm/nouveau/nouveau_connector.c
drivers/gpu/drm/nouveau/nouveau_connector.c
+3
-3
drivers/gpu/drm/nouveau/nvkm/engine/device/base.c
drivers/gpu/drm/nouveau/nvkm/engine/device/base.c
+65
-65
drivers/gpu/drm/nouveau/nvkm/engine/device/gf100.c
drivers/gpu/drm/nouveau/nvkm/engine/device/gf100.c
+0
-9
drivers/gpu/drm/nouveau/nvkm/engine/device/gk104.c
drivers/gpu/drm/nouveau/nvkm/engine/device/gk104.c
+0
-7
drivers/gpu/drm/nouveau/nvkm/engine/device/gm100.c
drivers/gpu/drm/nouveau/nvkm/engine/device/gm100.c
+0
-3
drivers/gpu/drm/nouveau/nvkm/engine/device/nv10.c
drivers/gpu/drm/nouveau/nvkm/engine/device/nv10.c
+0
-8
drivers/gpu/drm/nouveau/nvkm/engine/device/nv20.c
drivers/gpu/drm/nouveau/nvkm/engine/device/nv20.c
+0
-4
drivers/gpu/drm/nouveau/nvkm/engine/device/nv30.c
drivers/gpu/drm/nouveau/nvkm/engine/device/nv30.c
+0
-5
drivers/gpu/drm/nouveau/nvkm/engine/device/nv40.c
drivers/gpu/drm/nouveau/nvkm/engine/device/nv40.c
+0
-16
drivers/gpu/drm/nouveau/nvkm/engine/device/nv50.c
drivers/gpu/drm/nouveau/nvkm/engine/device/nv50.c
+0
-14
drivers/gpu/drm/nouveau/nvkm/engine/disp/conn.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/conn.c
+2
-2
drivers/gpu/drm/nouveau/nvkm/subdev/bios/init.c
drivers/gpu/drm/nouveau/nvkm/subdev/bios/init.c
+4
-4
drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramgk104.c
drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramgk104.c
+2
-2
drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramgt215.c
drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramgt215.c
+4
-4
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/Kbuild
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/Kbuild
+1
-1
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/base.c
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/base.c
+56
-83
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/g94.c
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/g94.c
+9
-10
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/gf119.c
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/gf119.c
+16
-17
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/gk104.c
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/gk104.c
+12
-13
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/nv10.c
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/nv10.c
+9
-10
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/nv50.c
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/nv50.c
+10
-11
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/priv.h
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/priv.h
+8
-29
drivers/gpu/drm/nouveau/nvkm/subdev/therm/fan.c
drivers/gpu/drm/nouveau/nvkm/subdev/therm/fan.c
+10
-6
drivers/gpu/drm/nouveau/nvkm/subdev/therm/fanpwm.c
drivers/gpu/drm/nouveau/nvkm/subdev/therm/fanpwm.c
+4
-3
drivers/gpu/drm/nouveau/nvkm/subdev/therm/fantog.c
drivers/gpu/drm/nouveau/nvkm/subdev/therm/fantog.c
+5
-4
drivers/gpu/drm/nouveau/nvkm/subdev/volt/gpio.c
drivers/gpu/drm/nouveau/nvkm/subdev/volt/gpio.c
+5
-5
No files found.
drivers/gpu/drm/nouveau/dispnv04/dac.c
View file @
2ea7249f
...
@@ -270,10 +270,10 @@ uint32_t nv17_dac_sample_load(struct drm_encoder *encoder)
...
@@ -270,10 +270,10 @@ uint32_t nv17_dac_sample_load(struct drm_encoder *encoder)
}
}
if
(
gpio
)
{
if
(
gpio
)
{
saved_gpio1
=
gpio
->
get
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
);
saved_gpio1
=
nvkm_gpio_
get
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
);
saved_gpio0
=
gpio
->
get
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
);
saved_gpio0
=
nvkm_gpio_
get
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
);
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
,
dcb
->
type
==
DCB_OUTPUT_TV
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
,
dcb
->
type
==
DCB_OUTPUT_TV
);
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
,
dcb
->
type
==
DCB_OUTPUT_TV
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
,
dcb
->
type
==
DCB_OUTPUT_TV
);
}
}
msleep
(
4
);
msleep
(
4
);
...
@@ -325,8 +325,8 @@ uint32_t nv17_dac_sample_load(struct drm_encoder *encoder)
...
@@ -325,8 +325,8 @@ uint32_t nv17_dac_sample_load(struct drm_encoder *encoder)
nvif_wr32
(
device
,
NV_PBUS_POWERCTRL_2
,
saved_powerctrl_2
);
nvif_wr32
(
device
,
NV_PBUS_POWERCTRL_2
,
saved_powerctrl_2
);
if
(
gpio
)
{
if
(
gpio
)
{
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
,
saved_gpio1
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
,
saved_gpio1
);
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
,
saved_gpio0
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
,
saved_gpio0
);
}
}
return
sample
;
return
sample
;
...
...
drivers/gpu/drm/nouveau/dispnv04/tvnv17.c
View file @
2ea7249f
...
@@ -62,8 +62,8 @@ static uint32_t nv42_tv_sample_load(struct drm_encoder *encoder)
...
@@ -62,8 +62,8 @@ static uint32_t nv42_tv_sample_load(struct drm_encoder *encoder)
head
=
(
dacclk
&
0x100
)
>>
8
;
head
=
(
dacclk
&
0x100
)
>>
8
;
/* Save the previous state. */
/* Save the previous state. */
gpio1
=
gpio
->
get
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
);
gpio1
=
nvkm_gpio_
get
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
);
gpio0
=
gpio
->
get
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
);
gpio0
=
nvkm_gpio_
get
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
);
fp_htotal
=
NVReadRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HTOTAL
);
fp_htotal
=
NVReadRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HTOTAL
);
fp_hsync_start
=
NVReadRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HSYNC_START
);
fp_hsync_start
=
NVReadRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HSYNC_START
);
fp_hsync_end
=
NVReadRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HSYNC_END
);
fp_hsync_end
=
NVReadRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HSYNC_END
);
...
@@ -74,8 +74,8 @@ static uint32_t nv42_tv_sample_load(struct drm_encoder *encoder)
...
@@ -74,8 +74,8 @@ static uint32_t nv42_tv_sample_load(struct drm_encoder *encoder)
ctv_6c
=
NVReadRAMDAC
(
dev
,
head
,
0x680c6c
);
ctv_6c
=
NVReadRAMDAC
(
dev
,
head
,
0x680c6c
);
/* Prepare the DAC for load detection. */
/* Prepare the DAC for load detection. */
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
,
true
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
,
true
);
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
,
true
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
,
true
);
NVWriteRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HTOTAL
,
1343
);
NVWriteRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HTOTAL
,
1343
);
NVWriteRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HSYNC_START
,
1047
);
NVWriteRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HSYNC_START
,
1047
);
...
@@ -120,8 +120,8 @@ static uint32_t nv42_tv_sample_load(struct drm_encoder *encoder)
...
@@ -120,8 +120,8 @@ static uint32_t nv42_tv_sample_load(struct drm_encoder *encoder)
NVWriteRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HSYNC_END
,
fp_hsync_end
);
NVWriteRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HSYNC_END
,
fp_hsync_end
);
NVWriteRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HSYNC_START
,
fp_hsync_start
);
NVWriteRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HSYNC_START
,
fp_hsync_start
);
NVWriteRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HTOTAL
,
fp_htotal
);
NVWriteRAMDAC
(
dev
,
head
,
NV_PRAMDAC_FP_HTOTAL
,
fp_htotal
);
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
,
gpio1
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
,
gpio1
);
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
,
gpio0
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
,
gpio0
);
return
sample
;
return
sample
;
}
}
...
@@ -395,8 +395,8 @@ static void nv17_tv_dpms(struct drm_encoder *encoder, int mode)
...
@@ -395,8 +395,8 @@ static void nv17_tv_dpms(struct drm_encoder *encoder, int mode)
nv_load_ptv
(
dev
,
regs
,
200
);
nv_load_ptv
(
dev
,
regs
,
200
);
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
,
mode
==
DRM_MODE_DPMS_ON
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_TVDAC1
,
0xff
,
mode
==
DRM_MODE_DPMS_ON
);
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
,
mode
==
DRM_MODE_DPMS_ON
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_TVDAC0
,
0xff
,
mode
==
DRM_MODE_DPMS_ON
);
nv04_dac_update_dacclk
(
encoder
,
mode
==
DRM_MODE_DPMS_ON
);
nv04_dac_update_dacclk
(
encoder
,
mode
==
DRM_MODE_DPMS_ON
);
}
}
...
...
drivers/gpu/drm/nouveau/include/nvif/device.h
View file @
2ea7249f
...
@@ -54,7 +54,7 @@ u64 nvif_device_time(struct nvif_device *);
...
@@ -54,7 +54,7 @@ u64 nvif_device_time(struct nvif_device *);
#define nvxx_fb(a) nvxx_device(a)->fb
#define nvxx_fb(a) nvxx_device(a)->fb
#define nvxx_mmu(a) nvkm_mmu(nvxx_device(a))
#define nvxx_mmu(a) nvkm_mmu(nvxx_device(a))
#define nvxx_bar(a) nvxx_device(a)->bar
#define nvxx_bar(a) nvxx_device(a)->bar
#define nvxx_gpio(a) nv
km_gpio(nvxx_device(a))
#define nvxx_gpio(a) nv
xx_device(a)->gpio
#define nvxx_clk(a) nvxx_device(a)->clk
#define nvxx_clk(a) nvxx_device(a)->clk
#define nvxx_i2c(a) nvkm_i2c(nvxx_device(a))
#define nvxx_i2c(a) nvkm_i2c(nvxx_device(a))
#define nvxx_therm(a) nvkm_therm(nvxx_device(a))
#define nvxx_therm(a) nvkm_therm(nvxx_device(a))
...
...
drivers/gpu/drm/nouveau/include/nvkm/subdev/gpio.h
View file @
2ea7249f
...
@@ -19,26 +19,21 @@ struct nvkm_gpio_ntfy_rep {
...
@@ -19,26 +19,21 @@ struct nvkm_gpio_ntfy_rep {
};
};
struct
nvkm_gpio
{
struct
nvkm_gpio
{
const
struct
nvkm_gpio_func
*
func
;
struct
nvkm_subdev
subdev
;
struct
nvkm_subdev
subdev
;
struct
nvkm_event
event
;
struct
nvkm_event
event
;
void
(
*
reset
)(
struct
nvkm_gpio
*
,
u8
func
);
int
(
*
find
)(
struct
nvkm_gpio
*
,
int
idx
,
u8
tag
,
u8
line
,
struct
dcb_gpio_func
*
);
int
(
*
set
)(
struct
nvkm_gpio
*
,
int
idx
,
u8
tag
,
u8
line
,
int
state
);
int
(
*
get
)(
struct
nvkm_gpio
*
,
int
idx
,
u8
tag
,
u8
line
);
};
};
static
inline
struct
nvkm_gpio
*
void
nvkm_gpio_reset
(
struct
nvkm_gpio
*
,
u8
func
);
nvkm_gpio
(
void
*
obj
)
int
nvkm_gpio_find
(
struct
nvkm_gpio
*
,
int
idx
,
u8
tag
,
u8
line
,
{
struct
dcb_gpio_func
*
);
return
(
void
*
)
nvkm_subdev
(
obj
,
NVDEV_SUBDEV_GPIO
);
int
nvkm_gpio_set
(
struct
nvkm_gpio
*
,
int
idx
,
u8
tag
,
u8
line
,
int
state
);
}
int
nvkm_gpio_get
(
struct
nvkm_gpio
*
,
int
idx
,
u8
tag
,
u8
line
);
extern
struct
nvkm_oclass
*
nv10_gpio_oclass
;
int
nv10_gpio_new
(
struct
nvkm_device
*
,
int
,
struct
nvkm_gpio
**
)
;
extern
struct
nvkm_oclass
*
nv50_gpio_oclass
;
int
nv50_gpio_new
(
struct
nvkm_device
*
,
int
,
struct
nvkm_gpio
**
)
;
extern
struct
nvkm_oclass
*
g94_gpio_oclass
;
int
g94_gpio_new
(
struct
nvkm_device
*
,
int
,
struct
nvkm_gpio
**
)
;
extern
struct
nvkm_oclass
*
gf110_gpio_oclass
;
int
gf119_gpio_new
(
struct
nvkm_device
*
,
int
,
struct
nvkm_gpio
**
)
;
extern
struct
nvkm_oclass
*
gk104_gpio_oclass
;
int
gk104_gpio_new
(
struct
nvkm_device
*
,
int
,
struct
nvkm_gpio
**
)
;
#endif
#endif
drivers/gpu/drm/nouveau/nouveau_connector.c
View file @
2ea7249f
...
@@ -125,9 +125,9 @@ nouveau_connector_ddc_detect(struct drm_connector *connector)
...
@@ -125,9 +125,9 @@ nouveau_connector_ddc_detect(struct drm_connector *connector)
* is handled by the SOR itself, and not required for LVDS DDC.
* is handled by the SOR itself, and not required for LVDS DDC.
*/
*/
if
(
nv_connector
->
type
==
DCB_CONNECTOR_eDP
)
{
if
(
nv_connector
->
type
==
DCB_CONNECTOR_eDP
)
{
panel
=
gpio
->
get
(
gpio
,
0
,
DCB_GPIO_PANEL_POWER
,
0xff
);
panel
=
nvkm_gpio_
get
(
gpio
,
0
,
DCB_GPIO_PANEL_POWER
,
0xff
);
if
(
panel
==
0
)
{
if
(
panel
==
0
)
{
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_PANEL_POWER
,
0xff
,
1
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_PANEL_POWER
,
0xff
,
1
);
msleep
(
300
);
msleep
(
300
);
}
}
}
}
...
@@ -157,7 +157,7 @@ nouveau_connector_ddc_detect(struct drm_connector *connector)
...
@@ -157,7 +157,7 @@ nouveau_connector_ddc_detect(struct drm_connector *connector)
* state to avoid confusing the SOR for other output types.
* state to avoid confusing the SOR for other output types.
*/
*/
if
(
!
nv_encoder
&&
panel
==
0
)
if
(
!
nv_encoder
&&
panel
==
0
)
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_PANEL_POWER
,
0xff
,
panel
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_PANEL_POWER
,
0xff
,
panel
);
return
nv_encoder
;
return
nv_encoder
;
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/engine/device/base.c
View file @
2ea7249f
This diff is collapsed.
Click to expand it.
drivers/gpu/drm/nouveau/nvkm/engine/device/gf100.c
View file @
2ea7249f
...
@@ -28,7 +28,6 @@ gf100_identify(struct nvkm_device *device)
...
@@ -28,7 +28,6 @@ gf100_identify(struct nvkm_device *device)
{
{
switch
(
device
->
chipset
)
{
switch
(
device
->
chipset
)
{
case
0xc0
:
case
0xc0
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -53,7 +52,6 @@ gf100_identify(struct nvkm_device *device)
...
@@ -53,7 +52,6 @@ gf100_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
break
;
break
;
case
0xc4
:
case
0xc4
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -78,7 +76,6 @@ gf100_identify(struct nvkm_device *device)
...
@@ -78,7 +76,6 @@ gf100_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
break
;
break
;
case
0xc3
:
case
0xc3
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -102,7 +99,6 @@ gf100_identify(struct nvkm_device *device)
...
@@ -102,7 +99,6 @@ gf100_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
break
;
break
;
case
0xce
:
case
0xce
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -127,7 +123,6 @@ gf100_identify(struct nvkm_device *device)
...
@@ -127,7 +123,6 @@ gf100_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
break
;
break
;
case
0xcf
:
case
0xcf
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -151,7 +146,6 @@ gf100_identify(struct nvkm_device *device)
...
@@ -151,7 +146,6 @@ gf100_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
break
;
break
;
case
0xc1
:
case
0xc1
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -175,7 +169,6 @@ gf100_identify(struct nvkm_device *device)
...
@@ -175,7 +169,6 @@ gf100_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf108_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf108_pm_oclass
;
break
;
break
;
case
0xc8
:
case
0xc8
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -200,7 +193,6 @@ gf100_identify(struct nvkm_device *device)
...
@@ -200,7 +193,6 @@ gf100_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf100_pm_oclass
;
break
;
break
;
case
0xd9
:
case
0xd9
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gf110_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gf110_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gf110_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -224,7 +216,6 @@ gf100_identify(struct nvkm_device *device)
...
@@ -224,7 +216,6 @@ gf100_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf117_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gf117_pm_oclass
;
break
;
break
;
case
0xd7
:
case
0xd7
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gf110_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gf117_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gf117_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/device/gk104.c
View file @
2ea7249f
...
@@ -28,7 +28,6 @@ gk104_identify(struct nvkm_device *device)
...
@@ -28,7 +28,6 @@ gk104_identify(struct nvkm_device *device)
{
{
switch
(
device
->
chipset
)
{
switch
(
device
->
chipset
)
{
case
0xe4
:
case
0xe4
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gk104_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -54,7 +53,6 @@ gk104_identify(struct nvkm_device *device)
...
@@ -54,7 +53,6 @@ gk104_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gk104_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gk104_pm_oclass
;
break
;
break
;
case
0xe7
:
case
0xe7
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gk104_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -80,7 +78,6 @@ gk104_identify(struct nvkm_device *device)
...
@@ -80,7 +78,6 @@ gk104_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gk104_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gk104_pm_oclass
;
break
;
break
;
case
0xe6
:
case
0xe6
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gk104_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -122,7 +119,6 @@ gk104_identify(struct nvkm_device *device)
...
@@ -122,7 +119,6 @@ gk104_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_SUBDEV_PMU
]
=
gk20a_pmu_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_PMU
]
=
gk20a_pmu_oclass
;
break
;
break
;
case
0xf0
:
case
0xf0
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gk104_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -148,7 +144,6 @@ gk104_identify(struct nvkm_device *device)
...
@@ -148,7 +144,6 @@ gk104_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
&
gk110_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
&
gk110_pm_oclass
;
break
;
break
;
case
0xf1
:
case
0xf1
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gk104_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gf110_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gf110_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -174,7 +169,6 @@ gk104_identify(struct nvkm_device *device)
...
@@ -174,7 +169,6 @@ gk104_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
&
gk110_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
&
gk110_pm_oclass
;
break
;
break
;
case
0x106
:
case
0x106
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gk104_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -199,7 +193,6 @@ gk104_identify(struct nvkm_device *device)
...
@@ -199,7 +193,6 @@ gk104_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_MSPPP
]
=
&
gf100_msppp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_MSPPP
]
=
&
gf100_msppp_oclass
;
break
;
break
;
case
0x108
:
case
0x108
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gk104_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gk104_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gf110_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/device/gm100.c
View file @
2ea7249f
...
@@ -28,7 +28,6 @@ gm100_identify(struct nvkm_device *device)
...
@@ -28,7 +28,6 @@ gm100_identify(struct nvkm_device *device)
{
{
switch
(
device
->
chipset
)
{
switch
(
device
->
chipset
)
{
case
0x117
:
case
0x117
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gk104_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gf110_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gf110_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gm107_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gm107_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -60,7 +59,6 @@ gm100_identify(struct nvkm_device *device)
...
@@ -60,7 +59,6 @@ gm100_identify(struct nvkm_device *device)
#endif
#endif
break
;
break
;
case
0x124
:
case
0x124
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gk104_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gm204_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gm204_i2c_oclass
;
#if 0
#if 0
/* looks to be some non-trivial changes */
/* looks to be some non-trivial changes */
...
@@ -93,7 +91,6 @@ gm100_identify(struct nvkm_device *device)
...
@@ -93,7 +91,6 @@ gm100_identify(struct nvkm_device *device)
#endif
#endif
break
;
break
;
case
0x126
:
case
0x126
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
gk104_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gm204_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
gm204_i2c_oclass
;
#if 0
#if 0
/* looks to be some non-trivial changes */
/* looks to be some non-trivial changes */
...
...
drivers/gpu/drm/nouveau/nvkm/engine/device/nv10.c
View file @
2ea7249f
...
@@ -28,7 +28,6 @@ nv10_identify(struct nvkm_device *device)
...
@@ -28,7 +28,6 @@ nv10_identify(struct nvkm_device *device)
{
{
switch
(
device
->
chipset
)
{
switch
(
device
->
chipset
)
{
case
0x10
:
case
0x10
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -39,7 +38,6 @@ nv10_identify(struct nvkm_device *device)
...
@@ -39,7 +38,6 @@ nv10_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x15
:
case
0x15
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -52,7 +50,6 @@ nv10_identify(struct nvkm_device *device)
...
@@ -52,7 +50,6 @@ nv10_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x16
:
case
0x16
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -65,7 +62,6 @@ nv10_identify(struct nvkm_device *device)
...
@@ -65,7 +62,6 @@ nv10_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x1a
:
case
0x1a
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -78,7 +74,6 @@ nv10_identify(struct nvkm_device *device)
...
@@ -78,7 +74,6 @@ nv10_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x11
:
case
0x11
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -91,7 +86,6 @@ nv10_identify(struct nvkm_device *device)
...
@@ -91,7 +86,6 @@ nv10_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x17
:
case
0x17
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -104,7 +98,6 @@ nv10_identify(struct nvkm_device *device)
...
@@ -104,7 +98,6 @@ nv10_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x1f
:
case
0x1f
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -117,7 +110,6 @@ nv10_identify(struct nvkm_device *device)
...
@@ -117,7 +110,6 @@ nv10_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x18
:
case
0x18
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/device/nv20.c
View file @
2ea7249f
...
@@ -28,7 +28,6 @@ nv20_identify(struct nvkm_device *device)
...
@@ -28,7 +28,6 @@ nv20_identify(struct nvkm_device *device)
{
{
switch
(
device
->
chipset
)
{
switch
(
device
->
chipset
)
{
case
0x20
:
case
0x20
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -41,7 +40,6 @@ nv20_identify(struct nvkm_device *device)
...
@@ -41,7 +40,6 @@ nv20_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x25
:
case
0x25
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -54,7 +52,6 @@ nv20_identify(struct nvkm_device *device)
...
@@ -54,7 +52,6 @@ nv20_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x28
:
case
0x28
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -67,7 +64,6 @@ nv20_identify(struct nvkm_device *device)
...
@@ -67,7 +64,6 @@ nv20_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x2a
:
case
0x2a
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/device/nv30.c
View file @
2ea7249f
...
@@ -28,7 +28,6 @@ nv30_identify(struct nvkm_device *device)
...
@@ -28,7 +28,6 @@ nv30_identify(struct nvkm_device *device)
{
{
switch
(
device
->
chipset
)
{
switch
(
device
->
chipset
)
{
case
0x30
:
case
0x30
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -41,7 +40,6 @@ nv30_identify(struct nvkm_device *device)
...
@@ -41,7 +40,6 @@ nv30_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x35
:
case
0x35
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -54,7 +52,6 @@ nv30_identify(struct nvkm_device *device)
...
@@ -54,7 +52,6 @@ nv30_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x31
:
case
0x31
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -68,7 +65,6 @@ nv30_identify(struct nvkm_device *device)
...
@@ -68,7 +65,6 @@ nv30_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x36
:
case
0x36
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
@@ -82,7 +78,6 @@ nv30_identify(struct nvkm_device *device)
...
@@ -82,7 +78,6 @@ nv30_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
device
->
oclass
[
NVDEV_ENGINE_DISP
]
=
nv04_disp_oclass
;
break
;
break
;
case
0x34
:
case
0x34
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv04_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_TIMER
]
=
&
nv04_timer_oclass
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/device/nv40.c
View file @
2ea7249f
...
@@ -28,7 +28,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -28,7 +28,6 @@ nv40_identify(struct nvkm_device *device)
{
{
switch
(
device
->
chipset
)
{
switch
(
device
->
chipset
)
{
case
0x40
:
case
0x40
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
...
@@ -45,7 +44,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -45,7 +44,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x41
:
case
0x41
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
...
@@ -62,7 +60,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -62,7 +60,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x42
:
case
0x42
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
...
@@ -79,7 +76,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -79,7 +76,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x43
:
case
0x43
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
...
@@ -96,7 +92,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -96,7 +92,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x45
:
case
0x45
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
...
@@ -113,7 +108,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -113,7 +108,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x47
:
case
0x47
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
...
@@ -130,7 +124,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -130,7 +124,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x49
:
case
0x49
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
...
@@ -147,7 +140,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -147,7 +140,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x4b
:
case
0x4b
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv40_mc_oclass
;
...
@@ -164,7 +156,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -164,7 +156,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x44
:
case
0x44
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv44_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv44_mc_oclass
;
...
@@ -181,7 +172,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -181,7 +172,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x46
:
case
0x46
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
...
@@ -198,7 +188,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -198,7 +188,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x4a
:
case
0x4a
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv44_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv44_mc_oclass
;
...
@@ -215,7 +204,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -215,7 +204,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x4c
:
case
0x4c
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
...
@@ -232,7 +220,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -232,7 +220,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x4e
:
case
0x4e
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv4e_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv4e_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
...
@@ -249,7 +236,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -249,7 +236,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x63
:
case
0x63
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
...
@@ -266,7 +252,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -266,7 +252,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x67
:
case
0x67
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
...
@@ -283,7 +268,6 @@ nv40_identify(struct nvkm_device *device)
...
@@ -283,7 +268,6 @@ nv40_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv40_pm_oclass
;
break
;
break
;
case
0x68
:
case
0x68
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv10_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv04_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv40_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MC
]
=
nv4c_mc_oclass
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/device/nv50.c
View file @
2ea7249f
...
@@ -28,7 +28,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -28,7 +28,6 @@ nv50_identify(struct nvkm_device *device)
{
{
switch
(
device
->
chipset
)
{
switch
(
device
->
chipset
)
{
case
0x50
:
case
0x50
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv50_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv50_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv50_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv50_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
nv50_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -46,7 +45,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -46,7 +45,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv50_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
nv50_pm_oclass
;
break
;
break
;
case
0x84
:
case
0x84
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv50_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv50_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv50_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -67,7 +65,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -67,7 +65,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
break
;
break
;
case
0x86
:
case
0x86
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv50_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv50_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv50_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -88,7 +85,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -88,7 +85,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
break
;
break
;
case
0x92
:
case
0x92
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
nv50_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv50_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv50_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -109,7 +105,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -109,7 +105,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
break
;
break
;
case
0x94
:
case
0x94
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -130,7 +125,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -130,7 +125,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
break
;
break
;
case
0x96
:
case
0x96
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -151,7 +145,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -151,7 +145,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
break
;
break
;
case
0x98
:
case
0x98
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -172,7 +165,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -172,7 +165,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
break
;
break
;
case
0xa0
:
case
0xa0
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv50_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
nv50_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -193,7 +185,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -193,7 +185,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gt200_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gt200_pm_oclass
;
break
;
break
;
case
0xaa
:
case
0xaa
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -214,7 +205,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -214,7 +205,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
break
;
break
;
case
0xac
:
case
0xac
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
g84_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -235,7 +225,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -235,7 +225,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
g84_pm_oclass
;
break
;
break
;
case
0xa3
:
case
0xa3
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -258,7 +247,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -258,7 +247,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gt215_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gt215_pm_oclass
;
break
;
break
;
case
0xa5
:
case
0xa5
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -280,7 +268,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -280,7 +268,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gt215_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gt215_pm_oclass
;
break
;
break
;
case
0xa8
:
case
0xa8
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
@@ -302,7 +289,6 @@ nv50_identify(struct nvkm_device *device)
...
@@ -302,7 +289,6 @@ nv50_identify(struct nvkm_device *device)
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gt215_pm_oclass
;
device
->
oclass
[
NVDEV_ENGINE_PM
]
=
gt215_pm_oclass
;
break
;
break
;
case
0xaf
:
case
0xaf
:
device
->
oclass
[
NVDEV_SUBDEV_GPIO
]
=
g94_gpio_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_I2C
]
=
g94_i2c_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_THERM
]
=
&
gt215_therm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
device
->
oclass
[
NVDEV_SUBDEV_MXM
]
=
&
nv50_mxm_oclass
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/conn.c
View file @
2ea7249f
...
@@ -41,7 +41,7 @@ nvkm_connector_hpd(struct nvkm_notify *notify)
...
@@ -41,7 +41,7 @@ nvkm_connector_hpd(struct nvkm_notify *notify)
CONN_DBG
(
conn
,
"HPD: %d"
,
line
->
mask
);
CONN_DBG
(
conn
,
"HPD: %d"
,
line
->
mask
);
if
(
!
gpio
->
get
(
gpio
,
0
,
DCB_GPIO_UNUSED
,
conn
->
hpd
.
index
))
if
(
!
nvkm_gpio_
get
(
gpio
,
0
,
DCB_GPIO_UNUSED
,
conn
->
hpd
.
index
))
rep
.
mask
=
NVIF_NOTIFY_CONN_V0_UNPLUG
;
rep
.
mask
=
NVIF_NOTIFY_CONN_V0_UNPLUG
;
else
else
rep
.
mask
=
NVIF_NOTIFY_CONN_V0_PLUG
;
rep
.
mask
=
NVIF_NOTIFY_CONN_V0_PLUG
;
...
@@ -98,7 +98,7 @@ nvkm_connector_ctor(struct nvkm_disp *disp, int index,
...
@@ -98,7 +98,7 @@ nvkm_connector_ctor(struct nvkm_disp *disp, int index,
}
}
info
->
hpd
=
hpd
[
info
->
hpd
];
info
->
hpd
=
hpd
[
info
->
hpd
];
ret
=
gpio
->
find
(
gpio
,
0
,
info
->
hpd
,
DCB_GPIO_UNUSED
,
&
func
);
ret
=
nvkm_gpio_
find
(
gpio
,
0
,
info
->
hpd
,
DCB_GPIO_UNUSED
,
&
func
);
if
(
ret
)
{
if
(
ret
)
{
CONN_ERR
(
conn
,
"func %02x lookup failed, %d"
,
CONN_ERR
(
conn
,
"func %02x lookup failed, %d"
,
info
->
hpd
,
ret
);
info
->
hpd
,
ret
);
...
...
drivers/gpu/drm/nouveau/nvkm/subdev/bios/init.c
View file @
2ea7249f
...
@@ -1933,8 +1933,8 @@ init_gpio(struct nvbios_init *init)
...
@@ -1933,8 +1933,8 @@ init_gpio(struct nvbios_init *init)
trace
(
"GPIO
\n
"
);
trace
(
"GPIO
\n
"
);
init
->
offset
+=
1
;
init
->
offset
+=
1
;
if
(
init_exec
(
init
)
&&
gpio
&&
gpio
->
reset
)
if
(
init_exec
(
init
))
gpio
->
reset
(
gpio
,
DCB_GPIO_UNUSED
);
nvkm_gpio_
reset
(
gpio
,
DCB_GPIO_UNUSED
);
}
}
/**
/**
...
@@ -2179,8 +2179,8 @@ init_gpio_ne(struct nvbios_init *init)
...
@@ -2179,8 +2179,8 @@ init_gpio_ne(struct nvbios_init *init)
trace
(
"
\t
FUNC[0x%02x]"
,
func
.
func
);
trace
(
"
\t
FUNC[0x%02x]"
,
func
.
func
);
if
(
i
==
(
init
->
offset
+
count
))
{
if
(
i
==
(
init
->
offset
+
count
))
{
cont
(
" *"
);
cont
(
" *"
);
if
(
init_exec
(
init
)
&&
gpio
&&
gpio
->
reset
)
if
(
init_exec
(
init
))
gpio
->
reset
(
gpio
,
func
.
func
);
nvkm_gpio_
reset
(
gpio
,
func
.
func
);
}
}
cont
(
"
\n
"
);
cont
(
"
\n
"
);
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramgk104.c
View file @
2ea7249f
...
@@ -1522,14 +1522,14 @@ gk104_ram_new(struct nvkm_fb *fb, struct nvkm_ram **pram)
...
@@ -1522,14 +1522,14 @@ gk104_ram_new(struct nvkm_fb *fb, struct nvkm_ram **pram)
}
}
/* lookup memory voltage gpios */
/* lookup memory voltage gpios */
ret
=
gpio
->
find
(
gpio
,
0
,
0x18
,
DCB_GPIO_UNUSED
,
&
func
);
ret
=
nvkm_gpio_
find
(
gpio
,
0
,
0x18
,
DCB_GPIO_UNUSED
,
&
func
);
if
(
ret
==
0
)
{
if
(
ret
==
0
)
{
ram
->
fuc
.
r_gpioMV
=
ramfuc_reg
(
0x00d610
+
(
func
.
line
*
0x04
));
ram
->
fuc
.
r_gpioMV
=
ramfuc_reg
(
0x00d610
+
(
func
.
line
*
0x04
));
ram
->
fuc
.
r_funcMV
[
0
]
=
(
func
.
log
[
0
]
^
2
)
<<
12
;
ram
->
fuc
.
r_funcMV
[
0
]
=
(
func
.
log
[
0
]
^
2
)
<<
12
;
ram
->
fuc
.
r_funcMV
[
1
]
=
(
func
.
log
[
1
]
^
2
)
<<
12
;
ram
->
fuc
.
r_funcMV
[
1
]
=
(
func
.
log
[
1
]
^
2
)
<<
12
;
}
}
ret
=
gpio
->
find
(
gpio
,
0
,
0x2e
,
DCB_GPIO_UNUSED
,
&
func
);
ret
=
nvkm_gpio_
find
(
gpio
,
0
,
0x2e
,
DCB_GPIO_UNUSED
,
&
func
);
if
(
ret
==
0
)
{
if
(
ret
==
0
)
{
ram
->
fuc
.
r_gpio2E
=
ramfuc_reg
(
0x00d610
+
(
func
.
line
*
0x04
));
ram
->
fuc
.
r_gpio2E
=
ramfuc_reg
(
0x00d610
+
(
func
.
line
*
0x04
));
ram
->
fuc
.
r_func2E
[
0
]
=
(
func
.
log
[
0
]
^
2
)
<<
12
;
ram
->
fuc
.
r_func2E
[
0
]
=
(
func
.
log
[
0
]
^
2
)
<<
12
;
...
...
drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramgt215.c
View file @
2ea7249f
...
@@ -468,13 +468,13 @@ gt215_ram_lock_pll(struct gt215_ramfuc *fuc, struct gt215_clk_info *mclk)
...
@@ -468,13 +468,13 @@ gt215_ram_lock_pll(struct gt215_ramfuc *fuc, struct gt215_clk_info *mclk)
static
void
static
void
gt215_ram_fbvref
(
struct
gt215_ramfuc
*
fuc
,
u32
val
)
gt215_ram_fbvref
(
struct
gt215_ramfuc
*
fuc
,
u32
val
)
{
{
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
fuc
->
base
.
fb
)
;
struct
nvkm_gpio
*
gpio
=
fuc
->
base
.
fb
->
subdev
.
device
->
gpio
;
struct
dcb_gpio_func
func
;
struct
dcb_gpio_func
func
;
u32
reg
,
sh
,
gpio_val
;
u32
reg
,
sh
,
gpio_val
;
int
ret
;
int
ret
;
if
(
gpio
->
get
(
gpio
,
0
,
0x2e
,
DCB_GPIO_UNUSED
)
!=
val
)
{
if
(
nvkm_gpio_
get
(
gpio
,
0
,
0x2e
,
DCB_GPIO_UNUSED
)
!=
val
)
{
ret
=
gpio
->
find
(
gpio
,
0
,
0x2e
,
DCB_GPIO_UNUSED
,
&
func
);
ret
=
nvkm_gpio_
find
(
gpio
,
0
,
0x2e
,
DCB_GPIO_UNUSED
,
&
func
);
if
(
ret
)
if
(
ret
)
return
;
return
;
...
@@ -982,7 +982,7 @@ gt215_ram_new(struct nvkm_fb *fb, struct nvkm_ram **pram)
...
@@ -982,7 +982,7 @@ gt215_ram_new(struct nvkm_fb *fb, struct nvkm_ram **pram)
ram
->
fuc
.
r_mr
[
3
]
=
ramfuc_reg
(
0x1002e4
);
ram
->
fuc
.
r_mr
[
3
]
=
ramfuc_reg
(
0x1002e4
);
}
}
ret
=
gpio
->
find
(
gpio
,
0
,
0x2e
,
DCB_GPIO_UNUSED
,
&
func
);
ret
=
nvkm_gpio_
find
(
gpio
,
0
,
0x2e
,
DCB_GPIO_UNUSED
,
&
func
);
if
(
ret
==
0
)
{
if
(
ret
==
0
)
{
nv50_gpio_location
(
func
.
line
,
&
reg
,
&
shift
);
nv50_gpio_location
(
func
.
line
,
&
reg
,
&
shift
);
ram
->
fuc
.
r_gpioFBVREF
=
ramfuc_reg
(
reg
);
ram
->
fuc
.
r_gpioFBVREF
=
ramfuc_reg
(
reg
);
...
...
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/Kbuild
View file @
2ea7249f
...
@@ -2,5 +2,5 @@ nvkm-y += nvkm/subdev/gpio/base.o
...
@@ -2,5 +2,5 @@ nvkm-y += nvkm/subdev/gpio/base.o
nvkm-y += nvkm/subdev/gpio/nv10.o
nvkm-y += nvkm/subdev/gpio/nv10.o
nvkm-y += nvkm/subdev/gpio/nv50.o
nvkm-y += nvkm/subdev/gpio/nv50.o
nvkm-y += nvkm/subdev/gpio/g94.o
nvkm-y += nvkm/subdev/gpio/g94.o
nvkm-y += nvkm/subdev/gpio/gf11
0
.o
nvkm-y += nvkm/subdev/gpio/gf11
9
.o
nvkm-y += nvkm/subdev/gpio/gk104.o
nvkm-y += nvkm/subdev/gpio/gk104.o
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/base.c
View file @
2ea7249f
...
@@ -28,18 +28,23 @@
...
@@ -28,18 +28,23 @@
static
int
static
int
nvkm_gpio_drive
(
struct
nvkm_gpio
*
gpio
,
int
idx
,
int
line
,
int
dir
,
int
out
)
nvkm_gpio_drive
(
struct
nvkm_gpio
*
gpio
,
int
idx
,
int
line
,
int
dir
,
int
out
)
{
{
const
struct
nvkm_gpio_impl
*
impl
=
(
void
*
)
nv_object
(
gpio
)
->
oclass
;
return
gpio
->
func
->
drive
(
gpio
,
line
,
dir
,
out
);
return
impl
->
drive
?
impl
->
drive
(
gpio
,
line
,
dir
,
out
)
:
-
ENODEV
;
}
}
static
int
static
int
nvkm_gpio_sense
(
struct
nvkm_gpio
*
gpio
,
int
idx
,
int
line
)
nvkm_gpio_sense
(
struct
nvkm_gpio
*
gpio
,
int
idx
,
int
line
)
{
{
const
struct
nvkm_gpio_impl
*
impl
=
(
void
*
)
nv_object
(
gpio
)
->
oclass
;
return
gpio
->
func
->
sense
(
gpio
,
line
);
return
impl
->
sense
?
impl
->
sense
(
gpio
,
line
)
:
-
ENODEV
;
}
}
static
int
void
nvkm_gpio_reset
(
struct
nvkm_gpio
*
gpio
,
u8
func
)
{
if
(
gpio
->
func
->
reset
)
gpio
->
func
->
reset
(
gpio
,
func
);
}
int
nvkm_gpio_find
(
struct
nvkm_gpio
*
gpio
,
int
idx
,
u8
tag
,
u8
line
,
nvkm_gpio_find
(
struct
nvkm_gpio
*
gpio
,
int
idx
,
u8
tag
,
u8
line
,
struct
dcb_gpio_func
*
func
)
struct
dcb_gpio_func
*
func
)
{
{
...
@@ -71,7 +76,7 @@ nvkm_gpio_find(struct nvkm_gpio *gpio, int idx, u8 tag, u8 line,
...
@@ -71,7 +76,7 @@ nvkm_gpio_find(struct nvkm_gpio *gpio, int idx, u8 tag, u8 line,
return
-
ENOENT
;
return
-
ENOENT
;
}
}
static
int
int
nvkm_gpio_set
(
struct
nvkm_gpio
*
gpio
,
int
idx
,
u8
tag
,
u8
line
,
int
state
)
nvkm_gpio_set
(
struct
nvkm_gpio
*
gpio
,
int
idx
,
u8
tag
,
u8
line
,
int
state
)
{
{
struct
dcb_gpio_func
func
;
struct
dcb_gpio_func
func
;
...
@@ -87,7 +92,7 @@ nvkm_gpio_set(struct nvkm_gpio *gpio, int idx, u8 tag, u8 line, int state)
...
@@ -87,7 +92,7 @@ nvkm_gpio_set(struct nvkm_gpio *gpio, int idx, u8 tag, u8 line, int state)
return
ret
;
return
ret
;
}
}
static
int
int
nvkm_gpio_get
(
struct
nvkm_gpio
*
gpio
,
int
idx
,
u8
tag
,
u8
line
)
nvkm_gpio_get
(
struct
nvkm_gpio
*
gpio
,
int
idx
,
u8
tag
,
u8
line
)
{
{
struct
dcb_gpio_func
func
;
struct
dcb_gpio_func
func
;
...
@@ -107,16 +112,14 @@ static void
...
@@ -107,16 +112,14 @@ static void
nvkm_gpio_intr_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
index
)
nvkm_gpio_intr_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
index
)
{
{
struct
nvkm_gpio
*
gpio
=
container_of
(
event
,
typeof
(
*
gpio
),
event
);
struct
nvkm_gpio
*
gpio
=
container_of
(
event
,
typeof
(
*
gpio
),
event
);
const
struct
nvkm_gpio_impl
*
impl
=
(
void
*
)
nv_object
(
gpio
)
->
oclass
;
gpio
->
func
->
intr_mask
(
gpio
,
type
,
1
<<
index
,
0
);
impl
->
intr_mask
(
gpio
,
type
,
1
<<
index
,
0
);
}
}
static
void
static
void
nvkm_gpio_intr_init
(
struct
nvkm_event
*
event
,
int
type
,
int
index
)
nvkm_gpio_intr_init
(
struct
nvkm_event
*
event
,
int
type
,
int
index
)
{
{
struct
nvkm_gpio
*
gpio
=
container_of
(
event
,
typeof
(
*
gpio
),
event
);
struct
nvkm_gpio
*
gpio
=
container_of
(
event
,
typeof
(
*
gpio
),
event
);
const
struct
nvkm_gpio_impl
*
impl
=
(
void
*
)
nv_object
(
gpio
)
->
oclass
;
gpio
->
func
->
intr_mask
(
gpio
,
type
,
1
<<
index
,
1
<<
index
);
impl
->
intr_mask
(
gpio
,
type
,
1
<<
index
,
1
<<
index
);
}
}
static
int
static
int
...
@@ -133,16 +136,22 @@ nvkm_gpio_intr_ctor(struct nvkm_object *object, void *data, u32 size,
...
@@ -133,16 +136,22 @@ nvkm_gpio_intr_ctor(struct nvkm_object *object, void *data, u32 size,
return
-
EINVAL
;
return
-
EINVAL
;
}
}
static
const
struct
nvkm_event_func
nvkm_gpio_intr_func
=
{
.
ctor
=
nvkm_gpio_intr_ctor
,
.
init
=
nvkm_gpio_intr_init
,
.
fini
=
nvkm_gpio_intr_fini
,
};
static
void
static
void
nvkm_gpio_intr
(
struct
nvkm_subdev
*
subdev
)
nvkm_gpio_intr
(
struct
nvkm_subdev
*
subdev
)
{
{
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
subdev
);
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
subdev
);
const
struct
nvkm_gpio_impl
*
impl
=
(
void
*
)
nv_object
(
gpio
)
->
oclass
;
u32
hi
,
lo
,
i
;
u32
hi
,
lo
,
i
;
impl
->
intr_stat
(
gpio
,
&
hi
,
&
lo
);
gpio
->
func
->
intr_stat
(
gpio
,
&
hi
,
&
lo
);
for
(
i
=
0
;
(
hi
|
lo
)
&&
i
<
impl
->
lines
;
i
++
)
{
for
(
i
=
0
;
(
hi
|
lo
)
&&
i
<
gpio
->
func
->
lines
;
i
++
)
{
struct
nvkm_gpio_ntfy_rep
rep
=
{
struct
nvkm_gpio_ntfy_rep
rep
=
{
.
mask
=
(
NVKM_GPIO_HI
*
!!
(
hi
&
(
1
<<
i
)))
|
.
mask
=
(
NVKM_GPIO_HI
*
!!
(
hi
&
(
1
<<
i
)))
|
(
NVKM_GPIO_LO
*
!!
(
lo
&
(
1
<<
i
))),
(
NVKM_GPIO_LO
*
!!
(
lo
&
(
1
<<
i
))),
...
@@ -151,24 +160,15 @@ nvkm_gpio_intr(struct nvkm_subdev *subdev)
...
@@ -151,24 +160,15 @@ nvkm_gpio_intr(struct nvkm_subdev *subdev)
}
}
}
}
static
const
struct
nvkm_event_func
static
int
nvkm_gpio_intr_func
=
{
nvkm_gpio_fini
(
struct
nvkm_subdev
*
subdev
,
bool
suspend
)
.
ctor
=
nvkm_gpio_intr_ctor
,
.
init
=
nvkm_gpio_intr_init
,
.
fini
=
nvkm_gpio_intr_fini
,
};
int
_nvkm_gpio_fini
(
struct
nvkm_object
*
object
,
bool
suspend
)
{
{
const
struct
nvkm_gpio_impl
*
impl
=
(
void
*
)
object
->
oclass
;
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
subdev
);
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
object
);
u32
mask
=
(
1
<<
gpio
->
func
->
lines
)
-
1
;
u32
mask
=
(
1
<<
impl
->
lines
)
-
1
;
impl
->
intr_mask
(
gpio
,
NVKM_GPIO_TOGGLED
,
mask
,
0
);
impl
->
intr_stat
(
gpio
,
&
mask
,
&
mask
);
return
nvkm_subdev_fini_old
(
&
gpio
->
subdev
,
suspend
);
gpio
->
func
->
intr_mask
(
gpio
,
NVKM_GPIO_TOGGLED
,
mask
,
0
);
gpio
->
func
->
intr_stat
(
gpio
,
&
mask
,
&
mask
);
return
0
;
}
}
static
struct
dmi_system_id
gpio_reset_ids
[]
=
{
static
struct
dmi_system_id
gpio_reset_ids
[]
=
{
...
@@ -182,70 +182,43 @@ static struct dmi_system_id gpio_reset_ids[] = {
...
@@ -182,70 +182,43 @@ static struct dmi_system_id gpio_reset_ids[] = {
{
}
{
}
};
};
int
static
int
_nvkm_gpio_init
(
struct
nvkm_object
*
object
)
nvkm_gpio_init
(
struct
nvkm_subdev
*
subdev
)
{
{
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
object
);
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
subdev
);
int
ret
;
if
(
dmi_check_system
(
gpio_reset_ids
))
nvkm_gpio_reset
(
gpio
,
DCB_GPIO_UNUSED
);
ret
=
nvkm_subdev_init_old
(
&
gpio
->
subdev
);
return
0
;
if
(
ret
)
return
ret
;
if
(
gpio
->
reset
&&
dmi_check_system
(
gpio_reset_ids
))
gpio
->
reset
(
gpio
,
DCB_GPIO_UNUSED
);
return
ret
;
}
}
void
static
void
*
_nvkm_gpio_dtor
(
struct
nvkm_object
*
object
)
nvkm_gpio_dtor
(
struct
nvkm_subdev
*
subdev
)
{
{
struct
nvkm_gpio
*
gpio
=
(
void
*
)
object
;
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
subdev
)
;
nvkm_event_fini
(
&
gpio
->
event
);
nvkm_event_fini
(
&
gpio
->
event
);
nvkm_subdev_destroy
(
&
gpio
->
subdev
)
;
return
gpio
;
}
}
int
static
const
struct
nvkm_subdev_func
nvkm_gpio_create_
(
struct
nvkm_object
*
parent
,
struct
nvkm_object
*
engine
,
nvkm_gpio
=
{
struct
nvkm_oclass
*
oclass
,
int
length
,
void
**
pobject
)
.
dtor
=
nvkm_gpio_dtor
,
{
.
init
=
nvkm_gpio_init
,
const
struct
nvkm_gpio_impl
*
impl
=
(
void
*
)
oclass
;
.
fini
=
nvkm_gpio_fini
,
struct
nvkm_gpio
*
gpio
;
.
intr
=
nvkm_gpio_intr
,
int
ret
;
};
ret
=
nvkm_subdev_create_
(
parent
,
engine
,
oclass
,
0
,
"GPIO"
,
"gpio"
,
length
,
pobject
);
gpio
=
*
pobject
;
if
(
ret
)
return
ret
;
gpio
->
find
=
nvkm_gpio_find
;
gpio
->
set
=
nvkm_gpio_set
;
gpio
->
get
=
nvkm_gpio_get
;
gpio
->
reset
=
impl
->
reset
;
ret
=
nvkm_event_init
(
&
nvkm_gpio_intr_func
,
2
,
impl
->
lines
,
&
gpio
->
event
);
if
(
ret
)
return
ret
;
nv_subdev
(
gpio
)
->
intr
=
nvkm_gpio_intr
;
return
0
;
}
int
int
_nvkm_gpio_ctor
(
struct
nvkm_object
*
parent
,
struct
nvkm_object
*
engine
,
nvkm_gpio_new_
(
const
struct
nvkm_gpio_func
*
func
,
struct
nvkm_device
*
device
,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
int
index
,
struct
nvkm_gpio
**
pgpio
)
struct
nvkm_object
**
pobject
)
{
{
struct
nvkm_gpio
*
gpio
;
struct
nvkm_gpio
*
gpio
;
int
ret
;
ret
=
nvkm_gpio_create
(
parent
,
engine
,
oclass
,
&
gpio
);
if
(
!
(
gpio
=
*
pgpio
=
kzalloc
(
sizeof
(
*
gpio
),
GFP_KERNEL
)))
*
pobject
=
nv_object
(
gpio
);
return
-
ENOMEM
;
if
(
ret
)
return
ret
;
return
0
;
nvkm_subdev_ctor
(
&
nvkm_gpio
,
device
,
index
,
0
,
&
gpio
->
subdev
);
gpio
->
func
=
func
;
return
nvkm_event_init
(
&
nvkm_gpio_intr_func
,
2
,
func
->
lines
,
&
gpio
->
event
);
}
}
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/g94.c
View file @
2ea7249f
...
@@ -57,19 +57,18 @@ g94_gpio_intr_mask(struct nvkm_gpio *gpio, u32 type, u32 mask, u32 data)
...
@@ -57,19 +57,18 @@ g94_gpio_intr_mask(struct nvkm_gpio *gpio, u32 type, u32 mask, u32 data)
nvkm_wr32
(
device
,
0x00e070
,
inte1
);
nvkm_wr32
(
device
,
0x00e070
,
inte1
);
}
}
struct
nvkm_oclass
*
static
const
struct
nvkm_gpio_func
g94_gpio_oclass
=
&
(
struct
nvkm_gpio_impl
)
{
g94_gpio
=
{
.
base
.
handle
=
NV_SUBDEV
(
GPIO
,
0x94
),
.
base
.
ofuncs
=
&
(
struct
nvkm_ofuncs
)
{
.
ctor
=
_nvkm_gpio_ctor
,
.
dtor
=
_nvkm_gpio_dtor
,
.
init
=
_nvkm_gpio_init
,
.
fini
=
_nvkm_gpio_fini
,
},
.
lines
=
32
,
.
lines
=
32
,
.
intr_stat
=
g94_gpio_intr_stat
,
.
intr_stat
=
g94_gpio_intr_stat
,
.
intr_mask
=
g94_gpio_intr_mask
,
.
intr_mask
=
g94_gpio_intr_mask
,
.
drive
=
nv50_gpio_drive
,
.
drive
=
nv50_gpio_drive
,
.
sense
=
nv50_gpio_sense
,
.
sense
=
nv50_gpio_sense
,
.
reset
=
nv50_gpio_reset
,
.
reset
=
nv50_gpio_reset
,
}.
base
;
};
int
g94_gpio_new
(
struct
nvkm_device
*
device
,
int
index
,
struct
nvkm_gpio
**
pgpio
)
{
return
nvkm_gpio_new_
(
&
g94_gpio
,
device
,
index
,
pgpio
);
}
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/gf11
0
.c
→
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/gf11
9
.c
View file @
2ea7249f
...
@@ -24,7 +24,7 @@
...
@@ -24,7 +24,7 @@
#include "priv.h"
#include "priv.h"
void
void
gf11
0
_gpio_reset
(
struct
nvkm_gpio
*
gpio
,
u8
match
)
gf11
9
_gpio_reset
(
struct
nvkm_gpio
*
gpio
,
u8
match
)
{
{
struct
nvkm_device
*
device
=
gpio
->
subdev
.
device
;
struct
nvkm_device
*
device
=
gpio
->
subdev
.
device
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
...
@@ -44,7 +44,7 @@ gf110_gpio_reset(struct nvkm_gpio *gpio, u8 match)
...
@@ -44,7 +44,7 @@ gf110_gpio_reset(struct nvkm_gpio *gpio, u8 match)
(
match
!=
DCB_GPIO_UNUSED
&&
match
!=
func
))
(
match
!=
DCB_GPIO_UNUSED
&&
match
!=
func
))
continue
;
continue
;
gpio
->
set
(
gpio
,
0
,
func
,
line
,
defs
);
nvkm_gpio_
set
(
gpio
,
0
,
func
,
line
,
defs
);
nvkm_mask
(
device
,
0x00d610
+
(
line
*
4
),
0xff
,
unk0
);
nvkm_mask
(
device
,
0x00d610
+
(
line
*
4
),
0xff
,
unk0
);
if
(
unk1
--
)
if
(
unk1
--
)
...
@@ -53,7 +53,7 @@ gf110_gpio_reset(struct nvkm_gpio *gpio, u8 match)
...
@@ -53,7 +53,7 @@ gf110_gpio_reset(struct nvkm_gpio *gpio, u8 match)
}
}
int
int
gf11
0
_gpio_drive
(
struct
nvkm_gpio
*
gpio
,
int
line
,
int
dir
,
int
out
)
gf11
9
_gpio_drive
(
struct
nvkm_gpio
*
gpio
,
int
line
,
int
dir
,
int
out
)
{
{
struct
nvkm_device
*
device
=
gpio
->
subdev
.
device
;
struct
nvkm_device
*
device
=
gpio
->
subdev
.
device
;
u32
data
=
((
dir
^
1
)
<<
13
)
|
(
out
<<
12
);
u32
data
=
((
dir
^
1
)
<<
13
)
|
(
out
<<
12
);
...
@@ -63,25 +63,24 @@ gf110_gpio_drive(struct nvkm_gpio *gpio, int line, int dir, int out)
...
@@ -63,25 +63,24 @@ gf110_gpio_drive(struct nvkm_gpio *gpio, int line, int dir, int out)
}
}
int
int
gf11
0
_gpio_sense
(
struct
nvkm_gpio
*
gpio
,
int
line
)
gf11
9
_gpio_sense
(
struct
nvkm_gpio
*
gpio
,
int
line
)
{
{
struct
nvkm_device
*
device
=
gpio
->
subdev
.
device
;
struct
nvkm_device
*
device
=
gpio
->
subdev
.
device
;
return
!!
(
nvkm_rd32
(
device
,
0x00d610
+
(
line
*
4
))
&
0x00004000
);
return
!!
(
nvkm_rd32
(
device
,
0x00d610
+
(
line
*
4
))
&
0x00004000
);
}
}
struct
nvkm_oclass
*
static
const
struct
nvkm_gpio_func
gf110_gpio_oclass
=
&
(
struct
nvkm_gpio_impl
)
{
gf119_gpio
=
{
.
base
.
handle
=
NV_SUBDEV
(
GPIO
,
0xd0
),
.
base
.
ofuncs
=
&
(
struct
nvkm_ofuncs
)
{
.
ctor
=
_nvkm_gpio_ctor
,
.
dtor
=
_nvkm_gpio_dtor
,
.
init
=
_nvkm_gpio_init
,
.
fini
=
_nvkm_gpio_fini
,
},
.
lines
=
32
,
.
lines
=
32
,
.
intr_stat
=
g94_gpio_intr_stat
,
.
intr_stat
=
g94_gpio_intr_stat
,
.
intr_mask
=
g94_gpio_intr_mask
,
.
intr_mask
=
g94_gpio_intr_mask
,
.
drive
=
gf110_gpio_drive
,
.
drive
=
gf119_gpio_drive
,
.
sense
=
gf110_gpio_sense
,
.
sense
=
gf119_gpio_sense
,
.
reset
=
gf110_gpio_reset
,
.
reset
=
gf119_gpio_reset
,
}.
base
;
};
int
gf119_gpio_new
(
struct
nvkm_device
*
device
,
int
index
,
struct
nvkm_gpio
**
pgpio
)
{
return
nvkm_gpio_new_
(
&
gf119_gpio
,
device
,
index
,
pgpio
);
}
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/gk104.c
View file @
2ea7249f
...
@@ -57,19 +57,18 @@ gk104_gpio_intr_mask(struct nvkm_gpio *gpio, u32 type, u32 mask, u32 data)
...
@@ -57,19 +57,18 @@ gk104_gpio_intr_mask(struct nvkm_gpio *gpio, u32 type, u32 mask, u32 data)
nvkm_wr32
(
device
,
0x00dc88
,
inte1
);
nvkm_wr32
(
device
,
0x00dc88
,
inte1
);
}
}
struct
nvkm_oclass
*
static
const
struct
nvkm_gpio_func
gk104_gpio_oclass
=
&
(
struct
nvkm_gpio_impl
)
{
gk104_gpio
=
{
.
base
.
handle
=
NV_SUBDEV
(
GPIO
,
0xe0
),
.
base
.
ofuncs
=
&
(
struct
nvkm_ofuncs
)
{
.
ctor
=
_nvkm_gpio_ctor
,
.
dtor
=
_nvkm_gpio_dtor
,
.
init
=
_nvkm_gpio_init
,
.
fini
=
_nvkm_gpio_fini
,
},
.
lines
=
32
,
.
lines
=
32
,
.
intr_stat
=
gk104_gpio_intr_stat
,
.
intr_stat
=
gk104_gpio_intr_stat
,
.
intr_mask
=
gk104_gpio_intr_mask
,
.
intr_mask
=
gk104_gpio_intr_mask
,
.
drive
=
gf110_gpio_drive
,
.
drive
=
gf119_gpio_drive
,
.
sense
=
gf110_gpio_sense
,
.
sense
=
gf119_gpio_sense
,
.
reset
=
gf110_gpio_reset
,
.
reset
=
gf119_gpio_reset
,
}.
base
;
};
int
gk104_gpio_new
(
struct
nvkm_device
*
device
,
int
index
,
struct
nvkm_gpio
**
pgpio
)
{
return
nvkm_gpio_new_
(
&
gk104_gpio
,
device
,
index
,
pgpio
);
}
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/nv10.c
View file @
2ea7249f
...
@@ -102,18 +102,17 @@ nv10_gpio_intr_mask(struct nvkm_gpio *gpio, u32 type, u32 mask, u32 data)
...
@@ -102,18 +102,17 @@ nv10_gpio_intr_mask(struct nvkm_gpio *gpio, u32 type, u32 mask, u32 data)
nvkm_wr32
(
device
,
0x001144
,
inte
);
nvkm_wr32
(
device
,
0x001144
,
inte
);
}
}
struct
nvkm_oclass
*
static
const
struct
nvkm_gpio_func
nv10_gpio_oclass
=
&
(
struct
nvkm_gpio_impl
)
{
nv10_gpio
=
{
.
base
.
handle
=
NV_SUBDEV
(
GPIO
,
0x10
),
.
base
.
ofuncs
=
&
(
struct
nvkm_ofuncs
)
{
.
ctor
=
_nvkm_gpio_ctor
,
.
dtor
=
_nvkm_gpio_dtor
,
.
init
=
_nvkm_gpio_init
,
.
fini
=
_nvkm_gpio_fini
,
},
.
lines
=
16
,
.
lines
=
16
,
.
intr_stat
=
nv10_gpio_intr_stat
,
.
intr_stat
=
nv10_gpio_intr_stat
,
.
intr_mask
=
nv10_gpio_intr_mask
,
.
intr_mask
=
nv10_gpio_intr_mask
,
.
drive
=
nv10_gpio_drive
,
.
drive
=
nv10_gpio_drive
,
.
sense
=
nv10_gpio_sense
,
.
sense
=
nv10_gpio_sense
,
}.
base
;
};
int
nv10_gpio_new
(
struct
nvkm_device
*
device
,
int
index
,
struct
nvkm_gpio
**
pgpio
)
{
return
nvkm_gpio_new_
(
&
nv10_gpio
,
device
,
index
,
pgpio
);
}
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/nv50.c
View file @
2ea7249f
...
@@ -48,7 +48,7 @@ nv50_gpio_reset(struct nvkm_gpio *gpio, u8 match)
...
@@ -48,7 +48,7 @@ nv50_gpio_reset(struct nvkm_gpio *gpio, u8 match)
(
match
!=
DCB_GPIO_UNUSED
&&
match
!=
func
))
(
match
!=
DCB_GPIO_UNUSED
&&
match
!=
func
))
continue
;
continue
;
gpio
->
set
(
gpio
,
0
,
func
,
line
,
defs
);
nvkm_gpio_
set
(
gpio
,
0
,
func
,
line
,
defs
);
nvkm_mask
(
device
,
reg
,
0x00010001
<<
lsh
,
val
<<
lsh
);
nvkm_mask
(
device
,
reg
,
0x00010001
<<
lsh
,
val
<<
lsh
);
}
}
...
@@ -115,19 +115,18 @@ nv50_gpio_intr_mask(struct nvkm_gpio *gpio, u32 type, u32 mask, u32 data)
...
@@ -115,19 +115,18 @@ nv50_gpio_intr_mask(struct nvkm_gpio *gpio, u32 type, u32 mask, u32 data)
nvkm_wr32
(
device
,
0x00e050
,
inte
);
nvkm_wr32
(
device
,
0x00e050
,
inte
);
}
}
struct
nvkm_oclass
*
static
const
struct
nvkm_gpio_func
nv50_gpio_oclass
=
&
(
struct
nvkm_gpio_impl
)
{
nv50_gpio
=
{
.
base
.
handle
=
NV_SUBDEV
(
GPIO
,
0x50
),
.
base
.
ofuncs
=
&
(
struct
nvkm_ofuncs
)
{
.
ctor
=
_nvkm_gpio_ctor
,
.
dtor
=
_nvkm_gpio_dtor
,
.
init
=
_nvkm_gpio_init
,
.
fini
=
_nvkm_gpio_fini
,
},
.
lines
=
16
,
.
lines
=
16
,
.
intr_stat
=
nv50_gpio_intr_stat
,
.
intr_stat
=
nv50_gpio_intr_stat
,
.
intr_mask
=
nv50_gpio_intr_mask
,
.
intr_mask
=
nv50_gpio_intr_mask
,
.
drive
=
nv50_gpio_drive
,
.
drive
=
nv50_gpio_drive
,
.
sense
=
nv50_gpio_sense
,
.
sense
=
nv50_gpio_sense
,
.
reset
=
nv50_gpio_reset
,
.
reset
=
nv50_gpio_reset
,
}.
base
;
};
int
nv50_gpio_new
(
struct
nvkm_device
*
device
,
int
index
,
struct
nvkm_gpio
**
pgpio
)
{
return
nvkm_gpio_new_
(
&
nv50_gpio
,
device
,
index
,
pgpio
);
}
drivers/gpu/drm/nouveau/nvkm/subdev/gpio/priv.h
View file @
2ea7249f
#ifndef __NVKM_GPIO_PRIV_H__
#ifndef __NVKM_GPIO_PRIV_H__
#define __NVKM_GPIO_PRIV_H__
#define __NVKM_GPIO_PRIV_H__
#define nvkm_gpio(p) container_of((p), struct nvkm_gpio, subdev)
#include <subdev/gpio.h>
#include <subdev/gpio.h>
#define nvkm_gpio_create(p,e,o,d) \
struct
nvkm_gpio_func
{
nvkm_gpio_create_((p), (e), (o), sizeof(**d), (void **)d)
#define nvkm_gpio_destroy(p) ({ \
struct nvkm_gpio *gpio = (p); \
_nvkm_gpio_dtor(nv_object(gpio)); \
})
#define nvkm_gpio_init(p) ({ \
struct nvkm_gpio *gpio = (p); \
_nvkm_gpio_init(nv_object(gpio)); \
})
#define nvkm_gpio_fini(p,s) ({ \
struct nvkm_gpio *gpio = (p); \
_nvkm_gpio_fini(nv_object(gpio), (s)); \
})
int
nvkm_gpio_create_
(
struct
nvkm_object
*
,
struct
nvkm_object
*
,
struct
nvkm_oclass
*
,
int
,
void
**
);
int
_nvkm_gpio_ctor
(
struct
nvkm_object
*
,
struct
nvkm_object
*
,
struct
nvkm_oclass
*
,
void
*
,
u32
,
struct
nvkm_object
**
);
void
_nvkm_gpio_dtor
(
struct
nvkm_object
*
);
int
_nvkm_gpio_init
(
struct
nvkm_object
*
);
int
_nvkm_gpio_fini
(
struct
nvkm_object
*
,
bool
);
struct
nvkm_gpio_impl
{
struct
nvkm_oclass
base
;
int
lines
;
int
lines
;
/* read and ack pending interrupts, returning only data
/* read and ack pending interrupts, returning only data
...
@@ -51,6 +27,9 @@ struct nvkm_gpio_impl {
...
@@ -51,6 +27,9 @@ struct nvkm_gpio_impl {
void
(
*
reset
)(
struct
nvkm_gpio
*
,
u8
);
void
(
*
reset
)(
struct
nvkm_gpio
*
,
u8
);
};
};
int
nvkm_gpio_new_
(
const
struct
nvkm_gpio_func
*
,
struct
nvkm_device
*
,
int
index
,
struct
nvkm_gpio
**
);
void
nv50_gpio_reset
(
struct
nvkm_gpio
*
,
u8
);
void
nv50_gpio_reset
(
struct
nvkm_gpio
*
,
u8
);
int
nv50_gpio_drive
(
struct
nvkm_gpio
*
,
int
,
int
,
int
);
int
nv50_gpio_drive
(
struct
nvkm_gpio
*
,
int
,
int
,
int
);
int
nv50_gpio_sense
(
struct
nvkm_gpio
*
,
int
);
int
nv50_gpio_sense
(
struct
nvkm_gpio
*
,
int
);
...
@@ -58,7 +37,7 @@ int nv50_gpio_sense(struct nvkm_gpio *, int);
...
@@ -58,7 +37,7 @@ int nv50_gpio_sense(struct nvkm_gpio *, int);
void
g94_gpio_intr_stat
(
struct
nvkm_gpio
*
,
u32
*
,
u32
*
);
void
g94_gpio_intr_stat
(
struct
nvkm_gpio
*
,
u32
*
,
u32
*
);
void
g94_gpio_intr_mask
(
struct
nvkm_gpio
*
,
u32
,
u32
,
u32
);
void
g94_gpio_intr_mask
(
struct
nvkm_gpio
*
,
u32
,
u32
,
u32
);
void
gf11
0
_gpio_reset
(
struct
nvkm_gpio
*
,
u8
);
void
gf11
9
_gpio_reset
(
struct
nvkm_gpio
*
,
u8
);
int
gf11
0
_gpio_drive
(
struct
nvkm_gpio
*
,
int
,
int
,
int
);
int
gf11
9
_gpio_drive
(
struct
nvkm_gpio
*
,
int
,
int
,
int
);
int
gf11
0
_gpio_sense
(
struct
nvkm_gpio
*
,
int
);
int
gf11
9
_gpio_sense
(
struct
nvkm_gpio
*
,
int
);
#endif
#endif
drivers/gpu/drm/nouveau/nvkm/subdev/therm/fan.c
View file @
2ea7249f
...
@@ -126,8 +126,9 @@ int
...
@@ -126,8 +126,9 @@ int
nvkm_therm_fan_sense
(
struct
nvkm_therm
*
obj
)
nvkm_therm_fan_sense
(
struct
nvkm_therm
*
obj
)
{
{
struct
nvkm_therm_priv
*
therm
=
container_of
(
obj
,
typeof
(
*
therm
),
base
);
struct
nvkm_therm_priv
*
therm
=
container_of
(
obj
,
typeof
(
*
therm
),
base
);
struct
nvkm_timer
*
tmr
=
nvkm_timer
(
therm
);
struct
nvkm_device
*
device
=
therm
->
base
.
subdev
.
device
;
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
therm
);
struct
nvkm_timer
*
tmr
=
device
->
timer
;
struct
nvkm_gpio
*
gpio
=
device
->
gpio
;
u32
cycles
,
cur
,
prev
;
u32
cycles
,
cur
,
prev
;
u64
start
,
end
,
tach
;
u64
start
,
end
,
tach
;
...
@@ -139,12 +140,14 @@ nvkm_therm_fan_sense(struct nvkm_therm *obj)
...
@@ -139,12 +140,14 @@ nvkm_therm_fan_sense(struct nvkm_therm *obj)
* We get 4 changes (0 -> 1 -> 0 -> 1) per complete rotation.
* We get 4 changes (0 -> 1 -> 0 -> 1) per complete rotation.
*/
*/
start
=
tmr
->
read
(
tmr
);
start
=
tmr
->
read
(
tmr
);
prev
=
gpio
->
get
(
gpio
,
0
,
therm
->
fan
->
tach
.
func
,
therm
->
fan
->
tach
.
line
);
prev
=
nvkm_gpio_get
(
gpio
,
0
,
therm
->
fan
->
tach
.
func
,
therm
->
fan
->
tach
.
line
);
cycles
=
0
;
cycles
=
0
;
do
{
do
{
usleep_range
(
500
,
1000
);
/* supports 0 < rpm < 7500 */
usleep_range
(
500
,
1000
);
/* supports 0 < rpm < 7500 */
cur
=
gpio
->
get
(
gpio
,
0
,
therm
->
fan
->
tach
.
func
,
therm
->
fan
->
tach
.
line
);
cur
=
nvkm_gpio_get
(
gpio
,
0
,
therm
->
fan
->
tach
.
func
,
therm
->
fan
->
tach
.
line
);
if
(
prev
!=
cur
)
{
if
(
prev
!=
cur
)
{
if
(
!
start
)
if
(
!
start
)
start
=
tmr
->
read
(
tmr
);
start
=
tmr
->
read
(
tmr
);
...
@@ -237,7 +240,7 @@ nvkm_therm_fan_ctor(struct nvkm_therm *obj)
...
@@ -237,7 +240,7 @@ nvkm_therm_fan_ctor(struct nvkm_therm *obj)
int
ret
;
int
ret
;
/* attempt to locate a drivable fan, and determine control method */
/* attempt to locate a drivable fan, and determine control method */
ret
=
gpio
->
find
(
gpio
,
0
,
DCB_GPIO_FAN
,
0xff
,
&
func
);
ret
=
nvkm_gpio_
find
(
gpio
,
0
,
DCB_GPIO_FAN
,
0xff
,
&
func
);
if
(
ret
==
0
)
{
if
(
ret
==
0
)
{
/* FIXME: is this really the place to perform such checks ? */
/* FIXME: is this really the place to perform such checks ? */
if
(
func
.
line
!=
16
&&
func
.
log
[
0
]
&
DCB_GPIO_LOG_DIR_IN
)
{
if
(
func
.
line
!=
16
&&
func
.
log
[
0
]
&
DCB_GPIO_LOG_DIR_IN
)
{
...
@@ -263,7 +266,8 @@ nvkm_therm_fan_ctor(struct nvkm_therm *obj)
...
@@ -263,7 +266,8 @@ nvkm_therm_fan_ctor(struct nvkm_therm *obj)
therm
->
fan
->
percent
=
nvkm_therm_fan_get
(
&
therm
->
base
);
therm
->
fan
->
percent
=
nvkm_therm_fan_get
(
&
therm
->
base
);
/* attempt to detect a tachometer connection */
/* attempt to detect a tachometer connection */
ret
=
gpio
->
find
(
gpio
,
0
,
DCB_GPIO_FAN_SENSE
,
0xff
,
&
therm
->
fan
->
tach
);
ret
=
nvkm_gpio_find
(
gpio
,
0
,
DCB_GPIO_FAN_SENSE
,
0xff
,
&
therm
->
fan
->
tach
);
if
(
ret
)
if
(
ret
)
therm
->
fan
->
tach
.
func
=
DCB_GPIO_UNUSED
;
therm
->
fan
->
tach
.
func
=
DCB_GPIO_UNUSED
;
...
...
drivers/gpu/drm/nouveau/nvkm/subdev/therm/fanpwm.c
View file @
2ea7249f
...
@@ -39,8 +39,9 @@ nvkm_fanpwm_get(struct nvkm_therm *obj)
...
@@ -39,8 +39,9 @@ nvkm_fanpwm_get(struct nvkm_therm *obj)
{
{
struct
nvkm_therm_priv
*
therm
=
container_of
(
obj
,
typeof
(
*
therm
),
base
);
struct
nvkm_therm_priv
*
therm
=
container_of
(
obj
,
typeof
(
*
therm
),
base
);
struct
nvkm_fanpwm
*
fan
=
(
void
*
)
therm
->
fan
;
struct
nvkm_fanpwm
*
fan
=
(
void
*
)
therm
->
fan
;
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
therm
);
struct
nvkm_device
*
device
=
therm
->
base
.
subdev
.
device
;
int
card_type
=
nv_device
(
therm
)
->
card_type
;
struct
nvkm_gpio
*
gpio
=
device
->
gpio
;
int
card_type
=
device
->
card_type
;
u32
divs
,
duty
;
u32
divs
,
duty
;
int
ret
;
int
ret
;
...
@@ -52,7 +53,7 @@ nvkm_fanpwm_get(struct nvkm_therm *obj)
...
@@ -52,7 +53,7 @@ nvkm_fanpwm_get(struct nvkm_therm *obj)
return
(
duty
*
100
)
/
divs
;
return
(
duty
*
100
)
/
divs
;
}
}
return
gpio
->
get
(
gpio
,
0
,
fan
->
func
.
func
,
fan
->
func
.
line
)
*
100
;
return
nvkm_gpio_
get
(
gpio
,
0
,
fan
->
func
.
func
,
fan
->
func
.
line
)
*
100
;
}
}
static
int
static
int
...
...
drivers/gpu/drm/nouveau/nvkm/subdev/therm/fantog.c
View file @
2ea7249f
...
@@ -39,8 +39,9 @@ static void
...
@@ -39,8 +39,9 @@ static void
nvkm_fantog_update
(
struct
nvkm_fantog
*
fan
,
int
percent
)
nvkm_fantog_update
(
struct
nvkm_fantog
*
fan
,
int
percent
)
{
{
struct
nvkm_therm_priv
*
therm
=
(
void
*
)
fan
->
base
.
parent
;
struct
nvkm_therm_priv
*
therm
=
(
void
*
)
fan
->
base
.
parent
;
struct
nvkm_timer
*
tmr
=
nvkm_timer
(
therm
);
struct
nvkm_device
*
device
=
therm
->
base
.
subdev
.
device
;
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
therm
);
struct
nvkm_timer
*
tmr
=
device
->
timer
;
struct
nvkm_gpio
*
gpio
=
device
->
gpio
;
unsigned
long
flags
;
unsigned
long
flags
;
int
duty
;
int
duty
;
...
@@ -49,8 +50,8 @@ nvkm_fantog_update(struct nvkm_fantog *fan, int percent)
...
@@ -49,8 +50,8 @@ nvkm_fantog_update(struct nvkm_fantog *fan, int percent)
percent
=
fan
->
percent
;
percent
=
fan
->
percent
;
fan
->
percent
=
percent
;
fan
->
percent
=
percent
;
duty
=
!
gpio
->
get
(
gpio
,
0
,
DCB_GPIO_FAN
,
0xff
);
duty
=
!
nvkm_gpio_
get
(
gpio
,
0
,
DCB_GPIO_FAN
,
0xff
);
gpio
->
set
(
gpio
,
0
,
DCB_GPIO_FAN
,
0xff
,
duty
);
nvkm_gpio_
set
(
gpio
,
0
,
DCB_GPIO_FAN
,
0xff
,
duty
);
if
(
list_empty
(
&
fan
->
alarm
.
head
)
&&
percent
!=
(
duty
*
100
))
{
if
(
list_empty
(
&
fan
->
alarm
.
head
)
&&
percent
!=
(
duty
*
100
))
{
u64
next_change
=
(
percent
*
fan
->
period_us
)
/
100
;
u64
next_change
=
(
percent
*
fan
->
period_us
)
/
100
;
...
...
drivers/gpu/drm/nouveau/nvkm/subdev/volt/gpio.c
View file @
2ea7249f
...
@@ -34,13 +34,13 @@ static const u8 tags[] = {
...
@@ -34,13 +34,13 @@ static const u8 tags[] = {
int
int
nvkm_voltgpio_get
(
struct
nvkm_volt
*
volt
)
nvkm_voltgpio_get
(
struct
nvkm_volt
*
volt
)
{
{
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
volt
)
;
struct
nvkm_gpio
*
gpio
=
volt
->
subdev
.
device
->
gpio
;
u8
vid
=
0
;
u8
vid
=
0
;
int
i
;
int
i
;
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
tags
);
i
++
)
{
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
tags
);
i
++
)
{
if
(
volt
->
vid_mask
&
(
1
<<
i
))
{
if
(
volt
->
vid_mask
&
(
1
<<
i
))
{
int
ret
=
gpio
->
get
(
gpio
,
0
,
tags
[
i
],
0xff
);
int
ret
=
nvkm_gpio_
get
(
gpio
,
0
,
tags
[
i
],
0xff
);
if
(
ret
<
0
)
if
(
ret
<
0
)
return
ret
;
return
ret
;
vid
|=
ret
<<
i
;
vid
|=
ret
<<
i
;
...
@@ -53,12 +53,12 @@ nvkm_voltgpio_get(struct nvkm_volt *volt)
...
@@ -53,12 +53,12 @@ nvkm_voltgpio_get(struct nvkm_volt *volt)
int
int
nvkm_voltgpio_set
(
struct
nvkm_volt
*
volt
,
u8
vid
)
nvkm_voltgpio_set
(
struct
nvkm_volt
*
volt
,
u8
vid
)
{
{
struct
nvkm_gpio
*
gpio
=
nvkm_gpio
(
volt
)
;
struct
nvkm_gpio
*
gpio
=
volt
->
subdev
.
device
->
gpio
;
int
i
;
int
i
;
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
tags
);
i
++
,
vid
>>=
1
)
{
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
tags
);
i
++
,
vid
>>=
1
)
{
if
(
volt
->
vid_mask
&
(
1
<<
i
))
{
if
(
volt
->
vid_mask
&
(
1
<<
i
))
{
int
ret
=
gpio
->
set
(
gpio
,
0
,
tags
[
i
],
0xff
,
vid
&
1
);
int
ret
=
nvkm_gpio_
set
(
gpio
,
0
,
tags
[
i
],
0xff
,
vid
&
1
);
if
(
ret
<
0
)
if
(
ret
<
0
)
return
ret
;
return
ret
;
}
}
...
@@ -83,7 +83,7 @@ nvkm_voltgpio_init(struct nvkm_volt *volt)
...
@@ -83,7 +83,7 @@ nvkm_voltgpio_init(struct nvkm_volt *volt)
*/
*/
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
tags
);
i
++
)
{
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
tags
);
i
++
)
{
if
(
volt
->
vid_mask
&
(
1
<<
i
))
{
if
(
volt
->
vid_mask
&
(
1
<<
i
))
{
int
ret
=
gpio
->
find
(
gpio
,
0
,
tags
[
i
],
0xff
,
&
func
);
int
ret
=
nvkm_gpio_
find
(
gpio
,
0
,
tags
[
i
],
0xff
,
&
func
);
if
(
ret
)
{
if
(
ret
)
{
if
(
ret
!=
-
ENOENT
)
if
(
ret
!=
-
ENOENT
)
return
ret
;
return
ret
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment