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
nexedi
linux
Commits
10ffe0fa
Commit
10ffe0fa
authored
May 08, 2018
by
Ben Skeggs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
drm/nouveau/kms/nv50-: abstract head interfaces so the code can be split
Signed-off-by:
Ben Skeggs
<
bskeggs@redhat.com
>
parent
9ca6f1eb
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
50 additions
and
14 deletions
+50
-14
drivers/gpu/drm/nouveau/dispnv50/disp.c
drivers/gpu/drm/nouveau/dispnv50/disp.c
+50
-14
No files found.
drivers/gpu/drm/nouveau/dispnv50/disp.c
View file @
10ffe0fa
...
@@ -436,6 +436,7 @@ struct nv50_sync {
...
@@ -436,6 +436,7 @@ struct nv50_sync {
};
};
struct
nv50_head
{
struct
nv50_head
{
const
struct
nv50_head_func
*
func
;
struct
nouveau_crtc
base
;
struct
nouveau_crtc
base
;
struct
{
struct
{
struct
nouveau_bo
*
nvbo
[
2
];
struct
nouveau_bo
*
nvbo
[
2
];
...
@@ -443,7 +444,22 @@ struct nv50_head {
...
@@ -443,7 +444,22 @@ struct nv50_head {
}
lut
;
}
lut
;
};
};
#define nv50_head(c) ((struct nv50_head *)nouveau_crtc(c))
struct
nv50_head_func
{
void
(
*
view
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
mode
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
ilut_set
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
ilut_clr
)(
struct
nv50_head
*
);
void
(
*
core_set
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
core_clr
)(
struct
nv50_head
*
);
void
(
*
curs_set
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
curs_clr
)(
struct
nv50_head
*
);
void
(
*
base
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
ovly
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
dither
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
procamp
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
};
#define nv50_head(c) container_of((c), struct nv50_head, base.base)
struct
nv50_disp
{
struct
nv50_disp
{
struct
nvif_disp
*
disp
;
struct
nvif_disp
*
disp
;
...
@@ -470,6 +486,7 @@ struct nv50_core {
...
@@ -470,6 +486,7 @@ struct nv50_core {
};
};
struct
nv50_core_func
{
struct
nv50_core_func
{
const
struct
nv50_head_func
*
head
;
};
};
static
int
static
int
...
@@ -2002,22 +2019,38 @@ nv50_head_view(struct nv50_head *head, struct nv50_head_atom *asyh)
...
@@ -2002,22 +2019,38 @@ nv50_head_view(struct nv50_head *head, struct nv50_head_atom *asyh)
}
}
}
}
static
const
struct
nv50_head_func
head507d
=
{
.
view
=
nv50_head_view
,
.
mode
=
nv50_head_mode
,
.
ilut_set
=
nv50_head_lut_set
,
.
ilut_clr
=
nv50_head_lut_clr
,
.
core_set
=
nv50_head_core_set
,
.
core_clr
=
nv50_head_core_clr
,
.
curs_set
=
nv50_head_curs_set
,
.
curs_clr
=
nv50_head_curs_clr
,
.
base
=
nv50_head_base
,
.
ovly
=
nv50_head_ovly
,
.
dither
=
nv50_head_dither
,
.
procamp
=
nv50_head_procamp
,
};
static
void
static
void
nv50_head_flush_clr
(
struct
nv50_head
*
head
,
struct
nv50_head_atom
*
asyh
,
bool
y
)
nv50_head_flush_clr
(
struct
nv50_head
*
head
,
struct
nv50_head_atom
*
asyh
,
bool
y
)
{
{
if
(
asyh
->
clr
.
ilut
&&
(
!
asyh
->
set
.
ilut
||
y
))
if
(
asyh
->
clr
.
ilut
&&
(
!
asyh
->
set
.
ilut
||
y
))
nv50_head_
lut_clr
(
head
);
head
->
func
->
i
lut_clr
(
head
);
if
(
asyh
->
clr
.
core
&&
(
!
asyh
->
set
.
core
||
y
))
if
(
asyh
->
clr
.
core
&&
(
!
asyh
->
set
.
core
||
y
))
nv50_head_
core_clr
(
head
);
head
->
func
->
core_clr
(
head
);
if
(
asyh
->
clr
.
curs
&&
(
!
asyh
->
set
.
curs
||
y
))
if
(
asyh
->
clr
.
curs
&&
(
!
asyh
->
set
.
curs
||
y
))
nv50_head_
curs_clr
(
head
);
head
->
func
->
curs_clr
(
head
);
}
}
static
void
static
void
nv50_head_flush_set
(
struct
nv50_head
*
head
,
struct
nv50_head_atom
*
asyh
)
nv50_head_flush_set
(
struct
nv50_head
*
head
,
struct
nv50_head_atom
*
asyh
)
{
{
if
(
asyh
->
set
.
view
)
nv50_head_
view
(
head
,
asyh
);
if
(
asyh
->
set
.
view
)
head
->
func
->
view
(
head
,
asyh
);
if
(
asyh
->
set
.
mode
)
nv50_head_
mode
(
head
,
asyh
);
if
(
asyh
->
set
.
mode
)
head
->
func
->
mode
(
head
,
asyh
);
if
(
asyh
->
set
.
ilut
)
{
if
(
asyh
->
set
.
ilut
)
{
struct
nouveau_bo
*
nvbo
=
head
->
lut
.
nvbo
[
head
->
lut
.
next
];
struct
nouveau_bo
*
nvbo
=
head
->
lut
.
nvbo
[
head
->
lut
.
next
];
struct
drm_property_blob
*
blob
=
asyh
->
state
.
gamma_lut
;
struct
drm_property_blob
*
blob
=
asyh
->
state
.
gamma_lut
;
...
@@ -2025,14 +2058,14 @@ nv50_head_flush_set(struct nv50_head *head, struct nv50_head_atom *asyh)
...
@@ -2025,14 +2058,14 @@ nv50_head_flush_set(struct nv50_head *head, struct nv50_head_atom *asyh)
nv50_head_lut_load
(
blob
,
asyh
->
lut
.
mode
,
nvbo
);
nv50_head_lut_load
(
blob
,
asyh
->
lut
.
mode
,
nvbo
);
asyh
->
lut
.
offset
=
nvbo
->
bo
.
offset
;
asyh
->
lut
.
offset
=
nvbo
->
bo
.
offset
;
head
->
lut
.
next
^=
1
;
head
->
lut
.
next
^=
1
;
nv50_head_
lut_set
(
head
,
asyh
);
head
->
func
->
i
lut_set
(
head
,
asyh
);
}
}
if
(
asyh
->
set
.
core
)
nv50_head_
core_set
(
head
,
asyh
);
if
(
asyh
->
set
.
core
)
head
->
func
->
core_set
(
head
,
asyh
);
if
(
asyh
->
set
.
curs
)
nv50_head_
curs_set
(
head
,
asyh
);
if
(
asyh
->
set
.
curs
)
head
->
func
->
curs_set
(
head
,
asyh
);
if
(
asyh
->
set
.
base
)
nv50_head_
base
(
head
,
asyh
);
if
(
asyh
->
set
.
base
)
head
->
func
->
base
(
head
,
asyh
);
if
(
asyh
->
set
.
ovly
)
nv50_head_
ovly
(
head
,
asyh
);
if
(
asyh
->
set
.
ovly
)
head
->
func
->
ovly
(
head
,
asyh
);
if
(
asyh
->
set
.
dither
)
nv50_head_
dither
(
head
,
asyh
);
if
(
asyh
->
set
.
dither
)
head
->
func
->
dither
(
head
,
asyh
);
if
(
asyh
->
set
.
procamp
)
nv50_head_
procamp
(
head
,
asyh
);
if
(
asyh
->
set
.
procamp
)
head
->
func
->
procamp
(
head
,
asyh
);
}
}
static
void
static
void
...
@@ -2422,7 +2455,7 @@ nv50_head_destroy(struct drm_crtc *crtc)
...
@@ -2422,7 +2455,7 @@ nv50_head_destroy(struct drm_crtc *crtc)
nouveau_bo_unmap_unpin_unref
(
&
head
->
lut
.
nvbo
[
i
]);
nouveau_bo_unmap_unpin_unref
(
&
head
->
lut
.
nvbo
[
i
]);
drm_crtc_cleanup
(
crtc
);
drm_crtc_cleanup
(
crtc
);
kfree
(
crtc
);
kfree
(
head
);
}
}
static
const
struct
drm_crtc_funcs
static
const
struct
drm_crtc_funcs
...
@@ -2440,6 +2473,7 @@ static int
...
@@ -2440,6 +2473,7 @@ static int
nv50_head_create
(
struct
drm_device
*
dev
,
int
index
)
nv50_head_create
(
struct
drm_device
*
dev
,
int
index
)
{
{
struct
nouveau_drm
*
drm
=
nouveau_drm
(
dev
);
struct
nouveau_drm
*
drm
=
nouveau_drm
(
dev
);
struct
nv50_disp
*
disp
=
nv50_disp
(
dev
);
struct
nv50_head
*
head
;
struct
nv50_head
*
head
;
struct
nv50_wndw
*
curs
,
*
wndw
;
struct
nv50_wndw
*
curs
,
*
wndw
;
struct
drm_crtc
*
crtc
;
struct
drm_crtc
*
crtc
;
...
@@ -2449,6 +2483,7 @@ nv50_head_create(struct drm_device *dev, int index)
...
@@ -2449,6 +2483,7 @@ nv50_head_create(struct drm_device *dev, int index)
if
(
!
head
)
if
(
!
head
)
return
-
ENOMEM
;
return
-
ENOMEM
;
head
->
func
=
disp
->
core
->
func
->
head
;
head
->
base
.
index
=
index
;
head
->
base
.
index
=
index
;
ret
=
nv50_base_new
(
drm
,
head
->
base
.
index
,
&
wndw
);
ret
=
nv50_base_new
(
drm
,
head
->
base
.
index
,
&
wndw
);
if
(
ret
==
0
)
if
(
ret
==
0
)
...
@@ -2482,6 +2517,7 @@ nv50_head_create(struct drm_device *dev, int index)
...
@@ -2482,6 +2517,7 @@ nv50_head_create(struct drm_device *dev, int index)
static
const
struct
nv50_core_func
static
const
struct
nv50_core_func
core507d
=
{
core507d
=
{
.
head
=
&
head507d
,
};
};
static
int
static
int
...
...
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