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
01d380ab
Commit
01d380ab
authored
May 08, 2018
by
Ben Skeggs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
drm/nouveau/kms/gk104-: support additional cursor sizes
Signed-off-by:
Ben Skeggs
<
bskeggs@redhat.com
>
parent
b05d8738
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
65 additions
and
16 deletions
+65
-16
drivers/gpu/drm/nouveau/dispnv50/atom.h
drivers/gpu/drm/nouveau/dispnv50/atom.h
+1
-1
drivers/gpu/drm/nouveau/dispnv50/curs507a.c
drivers/gpu/drm/nouveau/dispnv50/curs507a.c
+7
-15
drivers/gpu/drm/nouveau/dispnv50/head.h
drivers/gpu/drm/nouveau/dispnv50/head.h
+8
-0
drivers/gpu/drm/nouveau/dispnv50/head507d.c
drivers/gpu/drm/nouveau/dispnv50/head507d.c
+28
-0
drivers/gpu/drm/nouveau/dispnv50/head827d.c
drivers/gpu/drm/nouveau/dispnv50/head827d.c
+2
-0
drivers/gpu/drm/nouveau/dispnv50/head907d.c
drivers/gpu/drm/nouveau/dispnv50/head907d.c
+2
-0
drivers/gpu/drm/nouveau/dispnv50/head917d.c
drivers/gpu/drm/nouveau/dispnv50/head917d.c
+17
-0
No files found.
drivers/gpu/drm/nouveau/dispnv50/atom.h
View file @
01d380ab
...
@@ -76,7 +76,7 @@ struct nv50_head_atom {
...
@@ -76,7 +76,7 @@ struct nv50_head_atom {
bool
visible
;
bool
visible
;
u32
handle
;
u32
handle
;
u64
offset
:
40
;
u64
offset
:
40
;
u8
layout
:
1
;
u8
layout
:
2
;
u8
format
:
1
;
u8
format
:
1
;
}
curs
;
}
curs
;
...
...
drivers/gpu/drm/nouveau/dispnv50/curs507a.c
View file @
01d380ab
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
*/
*/
#include "curs.h"
#include "curs.h"
#include "core.h"
#include "core.h"
#include "head.h"
#include <nvif/cl507a.h>
#include <nvif/cl507a.h>
...
@@ -70,6 +71,7 @@ static int
...
@@ -70,6 +71,7 @@ static int
curs507a_acquire
(
struct
nv50_wndw
*
wndw
,
struct
nv50_wndw_atom
*
asyw
,
curs507a_acquire
(
struct
nv50_wndw
*
wndw
,
struct
nv50_wndw_atom
*
asyw
,
struct
nv50_head_atom
*
asyh
)
struct
nv50_head_atom
*
asyh
)
{
{
struct
nv50_head
*
head
=
nv50_head
(
asyw
->
state
.
crtc
);
int
ret
;
int
ret
;
ret
=
drm_atomic_helper_check_plane_state
(
&
asyw
->
state
,
&
asyh
->
state
,
ret
=
drm_atomic_helper_check_plane_state
(
&
asyw
->
state
,
&
asyh
->
state
,
...
@@ -80,24 +82,14 @@ curs507a_acquire(struct nv50_wndw *wndw, struct nv50_wndw_atom *asyw,
...
@@ -80,24 +82,14 @@ curs507a_acquire(struct nv50_wndw *wndw, struct nv50_wndw_atom *asyw,
if
(
ret
||
!
asyh
->
curs
.
visible
)
if
(
ret
||
!
asyh
->
curs
.
visible
)
return
ret
;
return
ret
;
switch
(
asyw
->
state
.
fb
->
width
)
{
if
(
asyw
->
image
.
w
!=
asyw
->
image
.
h
)
case
32
:
asyh
->
curs
.
layout
=
0
;
break
;
case
64
:
asyh
->
curs
.
layout
=
1
;
break
;
default:
return
-
EINVAL
;
}
if
(
asyw
->
state
.
fb
->
width
!=
asyw
->
state
.
fb
->
height
)
return
-
EINVAL
;
return
-
EINVAL
;
switch
(
asyw
->
image
.
format
)
{
ret
=
head
->
func
->
curs_layout
(
head
,
asyw
,
asyh
);
case
0xcf
:
asyh
->
curs
.
format
=
1
;
break
;
if
(
ret
)
default:
return
ret
;
WARN_ON
(
1
);
return
-
EINVAL
;
}
return
0
;
return
head
->
func
->
curs_format
(
head
,
asyw
,
asyh
)
;
}
}
static
const
u32
static
const
u32
...
...
drivers/gpu/drm/nouveau/dispnv50/head.h
View file @
01d380ab
...
@@ -26,6 +26,10 @@ struct nv50_head_func {
...
@@ -26,6 +26,10 @@ struct nv50_head_func {
void
(
*
core_calc
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
core_calc
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
core_set
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
core_set
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
core_clr
)(
struct
nv50_head
*
);
void
(
*
core_clr
)(
struct
nv50_head
*
);
int
(
*
curs_layout
)(
struct
nv50_head
*
,
struct
nv50_wndw_atom
*
,
struct
nv50_head_atom
*
);
int
(
*
curs_format
)(
struct
nv50_head
*
,
struct
nv50_wndw_atom
*
,
struct
nv50_head_atom
*
);
void
(
*
curs_set
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
curs_set
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
curs_clr
)(
struct
nv50_head
*
);
void
(
*
curs_clr
)(
struct
nv50_head
*
);
void
(
*
base
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
(
*
base
)(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
...
@@ -41,6 +45,10 @@ void head507d_mode(struct nv50_head *, struct nv50_head_atom *);
...
@@ -41,6 +45,10 @@ void head507d_mode(struct nv50_head *, struct nv50_head_atom *);
void
head507d_olut
(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
head507d_olut
(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
head507d_core_calc
(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
head507d_core_calc
(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
head507d_core_clr
(
struct
nv50_head
*
);
void
head507d_core_clr
(
struct
nv50_head
*
);
int
head507d_curs_layout
(
struct
nv50_head
*
,
struct
nv50_wndw_atom
*
,
struct
nv50_head_atom
*
);
int
head507d_curs_format
(
struct
nv50_head
*
,
struct
nv50_wndw_atom
*
,
struct
nv50_head_atom
*
);
void
head507d_base
(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
head507d_base
(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
head507d_ovly
(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
head507d_ovly
(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
head507d_dither
(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
void
head507d_dither
(
struct
nv50_head
*
,
struct
nv50_head_atom
*
);
...
...
drivers/gpu/drm/nouveau/dispnv50/head507d.c
View file @
01d380ab
...
@@ -128,6 +128,32 @@ head507d_curs_set(struct nv50_head *head, struct nv50_head_atom *asyh)
...
@@ -128,6 +128,32 @@ head507d_curs_set(struct nv50_head *head, struct nv50_head_atom *asyh)
}
}
}
}
int
head507d_curs_format
(
struct
nv50_head
*
head
,
struct
nv50_wndw_atom
*
asyw
,
struct
nv50_head_atom
*
asyh
)
{
switch
(
asyw
->
image
.
format
)
{
case
0xcf
:
asyh
->
curs
.
format
=
1
;
break
;
default:
WARN_ON
(
1
);
return
-
EINVAL
;
}
return
0
;
}
int
head507d_curs_layout
(
struct
nv50_head
*
head
,
struct
nv50_wndw_atom
*
asyw
,
struct
nv50_head_atom
*
asyh
)
{
switch
(
asyw
->
image
.
w
)
{
case
32
:
asyh
->
curs
.
layout
=
0
;
break
;
case
64
:
asyh
->
curs
.
layout
=
1
;
break
;
default:
return
-
EINVAL
;
}
return
0
;
}
void
void
head507d_core_clr
(
struct
nv50_head
*
head
)
head507d_core_clr
(
struct
nv50_head
*
head
)
{
{
...
@@ -287,6 +313,8 @@ head507d = {
...
@@ -287,6 +313,8 @@ head507d = {
.
core_calc
=
head507d_core_calc
,
.
core_calc
=
head507d_core_calc
,
.
core_set
=
head507d_core_set
,
.
core_set
=
head507d_core_set
,
.
core_clr
=
head507d_core_clr
,
.
core_clr
=
head507d_core_clr
,
.
curs_layout
=
head507d_curs_layout
,
.
curs_format
=
head507d_curs_format
,
.
curs_set
=
head507d_curs_set
,
.
curs_set
=
head507d_curs_set
,
.
curs_clr
=
head507d_curs_clr
,
.
curs_clr
=
head507d_curs_clr
,
.
base
=
head507d_base
,
.
base
=
head507d_base
,
...
...
drivers/gpu/drm/nouveau/dispnv50/head827d.c
View file @
01d380ab
...
@@ -113,6 +113,8 @@ head827d = {
...
@@ -113,6 +113,8 @@ head827d = {
.
core_calc
=
head507d_core_calc
,
.
core_calc
=
head507d_core_calc
,
.
core_set
=
head827d_core_set
,
.
core_set
=
head827d_core_set
,
.
core_clr
=
head507d_core_clr
,
.
core_clr
=
head507d_core_clr
,
.
curs_layout
=
head507d_curs_layout
,
.
curs_format
=
head507d_curs_format
,
.
curs_set
=
head827d_curs_set
,
.
curs_set
=
head827d_curs_set
,
.
curs_clr
=
head827d_curs_clr
,
.
curs_clr
=
head827d_curs_clr
,
.
base
=
head507d_base
,
.
base
=
head507d_base
,
...
...
drivers/gpu/drm/nouveau/dispnv50/head907d.c
View file @
01d380ab
...
@@ -270,6 +270,8 @@ head907d = {
...
@@ -270,6 +270,8 @@ head907d = {
.
core_calc
=
head507d_core_calc
,
.
core_calc
=
head507d_core_calc
,
.
core_set
=
head907d_core_set
,
.
core_set
=
head907d_core_set
,
.
core_clr
=
head907d_core_clr
,
.
core_clr
=
head907d_core_clr
,
.
curs_layout
=
head507d_curs_layout
,
.
curs_format
=
head507d_curs_format
,
.
curs_set
=
head907d_curs_set
,
.
curs_set
=
head907d_curs_set
,
.
curs_clr
=
head907d_curs_clr
,
.
curs_clr
=
head907d_curs_clr
,
.
base
=
head907d_base
,
.
base
=
head907d_base
,
...
...
drivers/gpu/drm/nouveau/dispnv50/head917d.c
View file @
01d380ab
...
@@ -63,6 +63,21 @@ head917d_base(struct nv50_head *head, struct nv50_head_atom *asyh)
...
@@ -63,6 +63,21 @@ head917d_base(struct nv50_head *head, struct nv50_head_atom *asyh)
}
}
}
}
static
int
head917d_curs_layout
(
struct
nv50_head
*
head
,
struct
nv50_wndw_atom
*
asyw
,
struct
nv50_head_atom
*
asyh
)
{
switch
(
asyw
->
state
.
fb
->
width
)
{
case
32
:
asyh
->
curs
.
layout
=
0
;
break
;
case
64
:
asyh
->
curs
.
layout
=
1
;
break
;
case
128
:
asyh
->
curs
.
layout
=
2
;
break
;
case
256
:
asyh
->
curs
.
layout
=
3
;
break
;
default:
return
-
EINVAL
;
}
return
0
;
}
const
struct
nv50_head_func
const
struct
nv50_head_func
head917d
=
{
head917d
=
{
.
view
=
head907d_view
,
.
view
=
head907d_view
,
...
@@ -73,6 +88,8 @@ head917d = {
...
@@ -73,6 +88,8 @@ head917d = {
.
core_calc
=
head507d_core_calc
,
.
core_calc
=
head507d_core_calc
,
.
core_set
=
head907d_core_set
,
.
core_set
=
head907d_core_set
,
.
core_clr
=
head907d_core_clr
,
.
core_clr
=
head907d_core_clr
,
.
curs_layout
=
head917d_curs_layout
,
.
curs_format
=
head507d_curs_format
,
.
curs_set
=
head907d_curs_set
,
.
curs_set
=
head907d_curs_set
,
.
curs_clr
=
head907d_curs_clr
,
.
curs_clr
=
head907d_curs_clr
,
.
base
=
head917d_base
,
.
base
=
head917d_base
,
...
...
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