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
2621a416
Commit
2621a416
authored
Nov 03, 2015
by
Ben Skeggs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
drm/nouveau/abi16: implement limited interoperability with usif/nvif
Signed-off-by:
Ben Skeggs
<
bskeggs@redhat.com
>
parent
786a57ef
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
53 additions
and
2 deletions
+53
-2
drivers/gpu/drm/nouveau/nouveau_abi16.c
drivers/gpu/drm/nouveau/nouveau_abi16.c
+39
-0
drivers/gpu/drm/nouveau/nouveau_abi16.h
drivers/gpu/drm/nouveau/nouveau_abi16.h
+1
-0
drivers/gpu/drm/nouveau/nouveau_usif.c
drivers/gpu/drm/nouveau/nouveau_usif.c
+13
-2
No files found.
drivers/gpu/drm/nouveau/nouveau_abi16.c
View file @
2621a416
...
@@ -25,6 +25,7 @@
...
@@ -25,6 +25,7 @@
#include <nvif/driver.h>
#include <nvif/driver.h>
#include <nvif/ioctl.h>
#include <nvif/ioctl.h>
#include <nvif/class.h>
#include <nvif/class.h>
#include <nvif/unpack.h>
#include "nouveau_drm.h"
#include "nouveau_drm.h"
#include "nouveau_dma.h"
#include "nouveau_dma.h"
...
@@ -346,6 +347,44 @@ nouveau_abi16_chan(struct nouveau_abi16 *abi16, int channel)
...
@@ -346,6 +347,44 @@ nouveau_abi16_chan(struct nouveau_abi16 *abi16, int channel)
return
NULL
;
return
NULL
;
}
}
int
nouveau_abi16_usif
(
struct
drm_file
*
file_priv
,
void
*
data
,
u32
size
)
{
union
{
struct
nvif_ioctl_v0
v0
;
}
*
args
=
data
;
struct
nouveau_abi16_chan
*
chan
;
struct
nouveau_abi16
*
abi16
;
int
ret
;
if
(
nvif_unpack
(
args
->
v0
,
0
,
0
,
true
))
{
switch
(
args
->
v0
.
type
)
{
case
NVIF_IOCTL_V0_NEW
:
case
NVIF_IOCTL_V0_MTHD
:
case
NVIF_IOCTL_V0_SCLASS
:
break
;
default:
return
-
EACCES
;
}
}
else
return
ret
;
if
(
!
(
abi16
=
nouveau_abi16
(
file_priv
)))
return
-
ENOMEM
;
if
(
args
->
v0
.
token
!=
~
0ULL
)
{
if
(
!
(
chan
=
nouveau_abi16_chan
(
abi16
,
args
->
v0
.
token
)))
return
-
EINVAL
;
args
->
v0
.
object
=
nvif_handle
(
&
chan
->
chan
->
user
);
args
->
v0
.
owner
=
NVIF_IOCTL_V0_OWNER_ANY
;
return
0
;
}
args
->
v0
.
object
=
nvif_handle
(
&
abi16
->
device
.
object
);
args
->
v0
.
owner
=
NVIF_IOCTL_V0_OWNER_ANY
;
return
0
;
}
int
int
nouveau_abi16_ioctl_channel_free
(
ABI16_IOCTL_ARGS
)
nouveau_abi16_ioctl_channel_free
(
ABI16_IOCTL_ARGS
)
{
{
...
...
drivers/gpu/drm/nouveau/nouveau_abi16.h
View file @
2621a416
...
@@ -37,6 +37,7 @@ struct nouveau_abi16 *nouveau_abi16_get(struct drm_file *);
...
@@ -37,6 +37,7 @@ struct nouveau_abi16 *nouveau_abi16_get(struct drm_file *);
int
nouveau_abi16_put
(
struct
nouveau_abi16
*
,
int
);
int
nouveau_abi16_put
(
struct
nouveau_abi16
*
,
int
);
void
nouveau_abi16_fini
(
struct
nouveau_abi16
*
);
void
nouveau_abi16_fini
(
struct
nouveau_abi16
*
);
s32
nouveau_abi16_swclass
(
struct
nouveau_drm
*
);
s32
nouveau_abi16_swclass
(
struct
nouveau_drm
*
);
int
nouveau_abi16_usif
(
struct
drm_file
*
,
void
*
data
,
u32
size
);
#define NOUVEAU_GEM_DOMAIN_VRAM (1 << 1)
#define NOUVEAU_GEM_DOMAIN_VRAM (1 << 1)
#define NOUVEAU_GEM_DOMAIN_GART (1 << 2)
#define NOUVEAU_GEM_DOMAIN_GART (1 << 2)
...
...
drivers/gpu/drm/nouveau/nouveau_usif.c
View file @
2621a416
...
@@ -24,6 +24,7 @@
...
@@ -24,6 +24,7 @@
#include "nouveau_drm.h"
#include "nouveau_drm.h"
#include "nouveau_usif.h"
#include "nouveau_usif.h"
#include "nouveau_abi16.h"
#include <nvif/notify.h>
#include <nvif/notify.h>
#include <nvif/unpack.h>
#include <nvif/unpack.h>
...
@@ -316,11 +317,21 @@ usif_ioctl(struct drm_file *filp, void __user *user, u32 argc)
...
@@ -316,11 +317,21 @@ usif_ioctl(struct drm_file *filp, void __user *user, u32 argc)
}
else
}
else
goto
done
;
goto
done
;
/* USIF slightly abuses some return-only ioctl members in order
* to provide interoperability with the older ABI16 objects
*/
mutex_lock
(
&
cli
->
mutex
);
mutex_lock
(
&
cli
->
mutex
);
if
(
argv
->
v0
.
route
)
{
if
(
ret
=
-
EINVAL
,
argv
->
v0
.
route
==
0xff
)
ret
=
nouveau_abi16_usif
(
filp
,
argv
,
argc
);
if
(
ret
)
{
mutex_unlock
(
&
cli
->
mutex
);
goto
done
;
}
}
switch
(
argv
->
v0
.
type
)
{
switch
(
argv
->
v0
.
type
)
{
case
NVIF_IOCTL_V0_NEW
:
case
NVIF_IOCTL_V0_NEW
:
/* ... except if we're creating children */
argv
->
v0
.
owner
=
NVIF_IOCTL_V0_OWNER_ANY
;
ret
=
usif_object_new
(
filp
,
data
,
size
,
argv
,
argc
);
ret
=
usif_object_new
(
filp
,
data
,
size
,
argv
,
argc
);
break
;
break
;
case
NVIF_IOCTL_V0_NTFY_NEW
:
case
NVIF_IOCTL_V0_NTFY_NEW
:
...
...
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