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
e75276ad
Commit
e75276ad
authored
Feb 07, 2005
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://drm.bkbits.net/drm-linus
into ppc970.osdl.org:/home/torvalds/v2.6/linux
parents
e1920b53
7dcd6234
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
84 additions
and
104 deletions
+84
-104
drivers/char/drm/drm_drv.c
drivers/char/drm/drm_drv.c
+1
-1
drivers/char/drm/drm_os_linux.h
drivers/char/drm/drm_os_linux.h
+0
-3
drivers/char/drm/radeon_drv.h
drivers/char/drm/radeon_drv.h
+15
-13
drivers/char/drm/radeon_state.c
drivers/char/drm/radeon_state.c
+68
-87
No files found.
drivers/char/drm/drm_drv.c
View file @
e75276ad
...
@@ -516,7 +516,7 @@ int drm_ioctl( struct inode *inode, struct file *filp,
...
@@ -516,7 +516,7 @@ int drm_ioctl( struct inode *inode, struct file *filp,
if
(
nr
<
DRIVER_IOCTL_COUNT
)
if
(
nr
<
DRIVER_IOCTL_COUNT
)
ioctl
=
&
drm_ioctls
[
nr
];
ioctl
=
&
drm_ioctls
[
nr
];
else
if
((
nr
>=
DRM_COMMAND_BASE
)
||
(
nr
<
DRM_COMMAND_BASE
+
dev
->
driver
->
num_ioctls
))
else
if
((
nr
>=
DRM_COMMAND_BASE
)
&&
(
nr
<
DRM_COMMAND_BASE
+
dev
->
driver
->
num_ioctls
))
ioctl
=
&
dev
->
driver
->
ioctls
[
nr
-
DRM_COMMAND_BASE
];
ioctl
=
&
dev
->
driver
->
ioctls
[
nr
-
DRM_COMMAND_BASE
];
else
else
goto
err_i1
;
goto
err_i1
;
...
...
drivers/char/drm/drm_os_linux.h
View file @
e75276ad
...
@@ -96,9 +96,6 @@ static __inline__ int mtrr_del (int reg, unsigned long base,
...
@@ -96,9 +96,6 @@ static __inline__ int mtrr_del (int reg, unsigned long base,
__copy_to_user(arg1, arg2, arg3)
__copy_to_user(arg1, arg2, arg3)
#define DRM_GET_USER_UNCHECKED(val, uaddr) \
#define DRM_GET_USER_UNCHECKED(val, uaddr) \
__get_user(val, uaddr)
__get_user(val, uaddr)
#define DRM_PUT_USER_UNCHECKED(uaddr, val) \
__put_user(val, uaddr)
#define DRM_GET_PRIV_WITH_RETURN(_priv, _filp) _priv = _filp->private_data
#define DRM_GET_PRIV_WITH_RETURN(_priv, _filp) _priv = _filp->private_data
...
...
drivers/char/drm/radeon_drv.h
View file @
e75276ad
...
@@ -1027,25 +1027,27 @@ do { \
...
@@ -1027,25 +1027,27 @@ do { \
} while (0)
} while (0)
#define OUT_RING_
USER_TABLE( tab, sz ) do {
\
#define OUT_RING_
TABLE( tab, sz ) do {
\
int _size = (sz); \
int _size = (sz); \
int
__user *_tab = (tab);
\
int
*_tab = (int *)(tab);
\
\
\
if (write + _size > mask) { \
if (write + _size > mask) { \
int i = (mask+1) - write; \
int _i = (mask+1) - write; \
if (DRM_COPY_FROM_USER_UNCHECKED( (int *)(ring+write), \
_size -= _i; \
_tab, i*4 )) \
while (_i > 0 ) { \
return DRM_ERR(EFAULT); \
*(int *)(ring + write) = *_tab++; \
write++; \
_i--; \
} \
write = 0; \
write = 0; \
_size -= i; \
_tab += _i; \
_tab += i; \
} \
} \
\
\
if (_size && DRM_COPY_FROM_USER_UNCHECKED( (int *)(ring+write),
\
while (_size > 0) {
\
_tab, _size*4 ))
\
*(ring + write) = *_tab++;
\
return DRM_ERR(EFAULT);
\
write++;
\
\
_size--;
\
write += _size;
\
}
\
write &= mask; \
write &= mask; \
} while (0)
} while (0)
...
...
drivers/char/drm/radeon_state.c
View file @
e75276ad
...
@@ -93,21 +93,6 @@ static __inline__ int radeon_check_and_fixup_offset( drm_radeon_private_t *dev_p
...
@@ -93,21 +93,6 @@ static __inline__ int radeon_check_and_fixup_offset( drm_radeon_private_t *dev_p
return
0
;
return
0
;
}
}
static
__inline__
int
radeon_check_and_fixup_offset_user
(
drm_radeon_private_t
*
dev_priv
,
drm_file_t
*
filp_priv
,
u32
__user
*
offset
)
{
u32
off
;
DRM_GET_USER_UNCHECKED
(
off
,
offset
);
if
(
radeon_check_and_fixup_offset
(
dev_priv
,
filp_priv
,
&
off
)
)
return
DRM_ERR
(
EINVAL
);
DRM_PUT_USER_UNCHECKED
(
offset
,
off
);
return
0
;
}
static
__inline__
int
radeon_check_and_fixup_packets
(
drm_radeon_private_t
*
dev_priv
,
static
__inline__
int
radeon_check_and_fixup_packets
(
drm_radeon_private_t
*
dev_priv
,
drm_file_t
*
filp_priv
,
drm_file_t
*
filp_priv
,
int
id
,
int
id
,
...
@@ -115,18 +100,18 @@ static __inline__ int radeon_check_and_fixup_packets( drm_radeon_private_t *dev_
...
@@ -115,18 +100,18 @@ static __inline__ int radeon_check_and_fixup_packets( drm_radeon_private_t *dev_
switch
(
id
)
{
switch
(
id
)
{
case
RADEON_EMIT_PP_MISC
:
case
RADEON_EMIT_PP_MISC
:
if
(
radeon_check_and_fixup_offset
_user
(
dev_priv
,
filp_priv
,
if
(
radeon_check_and_fixup_offset
(
dev_priv
,
filp_priv
,
&
data
[(
RADEON_RB3D_DEPTHOFFSET
&
data
[(
RADEON_RB3D_DEPTHOFFSET
-
RADEON_PP_MISC
)
/
4
]
)
)
{
-
RADEON_PP_MISC
)
/
4
]
)
)
{
DRM_ERROR
(
"Invalid depth buffer offset
\n
"
);
DRM_ERROR
(
"Invalid depth buffer offset
\n
"
);
return
DRM_ERR
(
EINVAL
);
return
DRM_ERR
(
EINVAL
);
}
}
break
;
break
;
case
RADEON_EMIT_PP_CNTL
:
case
RADEON_EMIT_PP_CNTL
:
if
(
radeon_check_and_fixup_offset
_user
(
dev_priv
,
filp_priv
,
if
(
radeon_check_and_fixup_offset
(
dev_priv
,
filp_priv
,
&
data
[(
RADEON_RB3D_COLOROFFSET
&
data
[(
RADEON_RB3D_COLOROFFSET
-
RADEON_PP_CNTL
)
/
4
]
)
)
{
-
RADEON_PP_CNTL
)
/
4
]
)
)
{
DRM_ERROR
(
"Invalid colour buffer offset
\n
"
);
DRM_ERROR
(
"Invalid colour buffer offset
\n
"
);
return
DRM_ERR
(
EINVAL
);
return
DRM_ERR
(
EINVAL
);
}
}
...
@@ -138,8 +123,8 @@ static __inline__ int radeon_check_and_fixup_packets( drm_radeon_private_t *dev_
...
@@ -138,8 +123,8 @@ static __inline__ int radeon_check_and_fixup_packets( drm_radeon_private_t *dev_
case
R200_EMIT_PP_TXOFFSET_3
:
case
R200_EMIT_PP_TXOFFSET_3
:
case
R200_EMIT_PP_TXOFFSET_4
:
case
R200_EMIT_PP_TXOFFSET_4
:
case
R200_EMIT_PP_TXOFFSET_5
:
case
R200_EMIT_PP_TXOFFSET_5
:
if
(
radeon_check_and_fixup_offset
_user
(
dev_priv
,
filp_priv
,
if
(
radeon_check_and_fixup_offset
(
dev_priv
,
filp_priv
,
&
data
[
0
]
)
)
{
&
data
[
0
]
)
)
{
DRM_ERROR
(
"Invalid R200 texture offset
\n
"
);
DRM_ERROR
(
"Invalid R200 texture offset
\n
"
);
return
DRM_ERR
(
EINVAL
);
return
DRM_ERR
(
EINVAL
);
}
}
...
@@ -148,9 +133,9 @@ static __inline__ int radeon_check_and_fixup_packets( drm_radeon_private_t *dev_
...
@@ -148,9 +133,9 @@ static __inline__ int radeon_check_and_fixup_packets( drm_radeon_private_t *dev_
case
RADEON_EMIT_PP_TXFILTER_0
:
case
RADEON_EMIT_PP_TXFILTER_0
:
case
RADEON_EMIT_PP_TXFILTER_1
:
case
RADEON_EMIT_PP_TXFILTER_1
:
case
RADEON_EMIT_PP_TXFILTER_2
:
case
RADEON_EMIT_PP_TXFILTER_2
:
if
(
radeon_check_and_fixup_offset
_user
(
dev_priv
,
filp_priv
,
if
(
radeon_check_and_fixup_offset
(
dev_priv
,
filp_priv
,
&
data
[(
RADEON_PP_TXOFFSET_0
&
data
[(
RADEON_PP_TXOFFSET_0
-
RADEON_PP_TXFILTER_0
)
/
4
]
)
)
{
-
RADEON_PP_TXFILTER_0
)
/
4
]
)
)
{
DRM_ERROR
(
"Invalid R100 texture offset
\n
"
);
DRM_ERROR
(
"Invalid R100 texture offset
\n
"
);
return
DRM_ERR
(
EINVAL
);
return
DRM_ERR
(
EINVAL
);
}
}
...
@@ -164,9 +149,8 @@ static __inline__ int radeon_check_and_fixup_packets( drm_radeon_private_t *dev_
...
@@ -164,9 +149,8 @@ static __inline__ int radeon_check_and_fixup_packets( drm_radeon_private_t *dev_
case
R200_EMIT_PP_CUBIC_OFFSETS_5
:
{
case
R200_EMIT_PP_CUBIC_OFFSETS_5
:
{
int
i
;
int
i
;
for
(
i
=
0
;
i
<
5
;
i
++
)
{
for
(
i
=
0
;
i
<
5
;
i
++
)
{
if
(
radeon_check_and_fixup_offset_user
(
dev_priv
,
if
(
radeon_check_and_fixup_offset
(
dev_priv
,
filp_priv
,
filp_priv
,
&
data
[
i
]
)
)
{
&
data
[
i
]
)
)
{
DRM_ERROR
(
"Invalid R200 cubic texture offset
\n
"
);
DRM_ERROR
(
"Invalid R200 cubic texture offset
\n
"
);
return
DRM_ERR
(
EINVAL
);
return
DRM_ERR
(
EINVAL
);
}
}
...
@@ -250,17 +234,11 @@ static __inline__ int radeon_check_and_fixup_packet3( drm_radeon_private_t *dev_
...
@@ -250,17 +234,11 @@ static __inline__ int radeon_check_and_fixup_packet3( drm_radeon_private_t *dev_
drm_file_t
*
filp_priv
,
drm_file_t
*
filp_priv
,
drm_radeon_cmd_buffer_t
*
cmdbuf
,
drm_radeon_cmd_buffer_t
*
cmdbuf
,
unsigned
int
*
cmdsz
)
{
unsigned
int
*
cmdsz
)
{
u32
tmp
[
4
];
u32
*
cmd
=
(
u32
*
)
cmdbuf
->
buf
;
u32
__user
*
cmd
=
(
u32
__user
*
)
cmdbuf
->
buf
;
if
(
DRM_COPY_FROM_USER_UNCHECKED
(
tmp
,
cmd
,
sizeof
(
tmp
)
)
)
{
DRM_ERROR
(
"Failed to copy data from user space
\n
"
);
return
DRM_ERR
(
EFAULT
);
}
*
cmdsz
=
2
+
(
(
tmp
[
0
]
&
RADEON_CP_PACKET_COUNT_MASK
)
>>
16
);
*
cmdsz
=
2
+
(
(
cmd
[
0
]
&
RADEON_CP_PACKET_COUNT_MASK
)
>>
16
);
if
(
(
tmp
[
0
]
&
0xc0000000
)
!=
RADEON_CP_PACKET3
)
{
if
(
(
cmd
[
0
]
&
0xc0000000
)
!=
RADEON_CP_PACKET3
)
{
DRM_ERROR
(
"Not a type 3 packet
\n
"
);
DRM_ERROR
(
"Not a type 3 packet
\n
"
);
return
DRM_ERR
(
EINVAL
);
return
DRM_ERR
(
EINVAL
);
}
}
...
@@ -271,32 +249,27 @@ static __inline__ int radeon_check_and_fixup_packet3( drm_radeon_private_t *dev_
...
@@ -271,32 +249,27 @@ static __inline__ int radeon_check_and_fixup_packet3( drm_radeon_private_t *dev_
}
}
/* Check client state and fix it up if necessary */
/* Check client state and fix it up if necessary */
if
(
tmp
[
0
]
&
0x8000
)
{
/* MSB of opcode: next DWORD GUI_CNTL */
if
(
cmd
[
0
]
&
0x8000
)
{
/* MSB of opcode: next DWORD GUI_CNTL */
u32
offset
;
u32
offset
;
if
(
tmp
[
1
]
&
(
RADEON_GMC_SRC_PITCH_OFFSET_CNTL
if
(
cmd
[
1
]
&
(
RADEON_GMC_SRC_PITCH_OFFSET_CNTL
|
RADEON_GMC_DST_PITCH_OFFSET_CNTL
)
)
{
|
RADEON_GMC_DST_PITCH_OFFSET_CNTL
)
)
{
offset
=
tmp
[
2
]
<<
10
;
offset
=
cmd
[
2
]
<<
10
;
if
(
radeon_check_and_fixup_offset
(
dev_priv
,
filp_priv
,
&
offset
)
)
{
if
(
radeon_check_and_fixup_offset
(
dev_priv
,
filp_priv
,
&
offset
)
)
{
DRM_ERROR
(
"Invalid first packet offset
\n
"
);
DRM_ERROR
(
"Invalid first packet offset
\n
"
);
return
DRM_ERR
(
EINVAL
);
return
DRM_ERR
(
EINVAL
);
}
}
tmp
[
2
]
=
(
tmp
[
2
]
&
0xffc00000
)
|
offset
>>
10
;
cmd
[
2
]
=
(
cmd
[
2
]
&
0xffc00000
)
|
offset
>>
10
;
}
}
if
(
(
tmp
[
1
]
&
RADEON_GMC_SRC_PITCH_OFFSET_CNTL
)
&&
if
(
(
cmd
[
1
]
&
RADEON_GMC_SRC_PITCH_OFFSET_CNTL
)
&&
(
tmp
[
1
]
&
RADEON_GMC_DST_PITCH_OFFSET_CNTL
)
)
{
(
cmd
[
1
]
&
RADEON_GMC_DST_PITCH_OFFSET_CNTL
)
)
{
offset
=
tmp
[
3
]
<<
10
;
offset
=
cmd
[
3
]
<<
10
;
if
(
radeon_check_and_fixup_offset
(
dev_priv
,
filp_priv
,
&
offset
)
)
{
if
(
radeon_check_and_fixup_offset
(
dev_priv
,
filp_priv
,
&
offset
)
)
{
DRM_ERROR
(
"Invalid second packet offset
\n
"
);
DRM_ERROR
(
"Invalid second packet offset
\n
"
);
return
DRM_ERR
(
EINVAL
);
return
DRM_ERR
(
EINVAL
);
}
}
tmp
[
3
]
=
(
tmp
[
3
]
&
0xffc00000
)
|
offset
>>
10
;
cmd
[
3
]
=
(
cmd
[
3
]
&
0xffc00000
)
|
offset
>>
10
;
}
if
(
DRM_COPY_TO_USER_UNCHECKED
(
cmd
,
tmp
,
sizeof
(
tmp
)
)
)
{
DRM_ERROR
(
"Failed to copy data to user space
\n
"
);
return
DRM_ERR
(
EFAULT
);
}
}
}
}
...
@@ -2473,7 +2446,7 @@ static int radeon_emit_packets(
...
@@ -2473,7 +2446,7 @@ static int radeon_emit_packets(
{
{
int
id
=
(
int
)
header
.
packet
.
packet_id
;
int
id
=
(
int
)
header
.
packet
.
packet_id
;
int
sz
,
reg
;
int
sz
,
reg
;
int
__user
*
data
=
(
int
__user
*
)
cmdbuf
->
buf
;
int
*
data
=
(
int
*
)
cmdbuf
->
buf
;
RING_LOCALS
;
RING_LOCALS
;
if
(
id
>=
RADEON_MAX_STATE_PACKETS
)
if
(
id
>=
RADEON_MAX_STATE_PACKETS
)
...
@@ -2494,7 +2467,7 @@ static int radeon_emit_packets(
...
@@ -2494,7 +2467,7 @@ static int radeon_emit_packets(
BEGIN_RING
(
sz
+
1
);
BEGIN_RING
(
sz
+
1
);
OUT_RING
(
CP_PACKET0
(
reg
,
(
sz
-
1
)
)
);
OUT_RING
(
CP_PACKET0
(
reg
,
(
sz
-
1
)
)
);
OUT_RING_
USER_
TABLE
(
data
,
sz
);
OUT_RING_TABLE
(
data
,
sz
);
ADVANCE_RING
();
ADVANCE_RING
();
cmdbuf
->
buf
+=
sz
*
sizeof
(
int
);
cmdbuf
->
buf
+=
sz
*
sizeof
(
int
);
...
@@ -2508,7 +2481,6 @@ static __inline__ int radeon_emit_scalars(
...
@@ -2508,7 +2481,6 @@ static __inline__ int radeon_emit_scalars(
drm_radeon_cmd_buffer_t
*
cmdbuf
)
drm_radeon_cmd_buffer_t
*
cmdbuf
)
{
{
int
sz
=
header
.
scalars
.
count
;
int
sz
=
header
.
scalars
.
count
;
int
__user
*
data
=
(
int
__user
*
)
cmdbuf
->
buf
;
int
start
=
header
.
scalars
.
offset
;
int
start
=
header
.
scalars
.
offset
;
int
stride
=
header
.
scalars
.
stride
;
int
stride
=
header
.
scalars
.
stride
;
RING_LOCALS
;
RING_LOCALS
;
...
@@ -2517,7 +2489,7 @@ static __inline__ int radeon_emit_scalars(
...
@@ -2517,7 +2489,7 @@ static __inline__ int radeon_emit_scalars(
OUT_RING
(
CP_PACKET0
(
RADEON_SE_TCL_SCALAR_INDX_REG
,
0
)
);
OUT_RING
(
CP_PACKET0
(
RADEON_SE_TCL_SCALAR_INDX_REG
,
0
)
);
OUT_RING
(
start
|
(
stride
<<
RADEON_SCAL_INDX_DWORD_STRIDE_SHIFT
));
OUT_RING
(
start
|
(
stride
<<
RADEON_SCAL_INDX_DWORD_STRIDE_SHIFT
));
OUT_RING
(
CP_PACKET0_TABLE
(
RADEON_SE_TCL_SCALAR_DATA_REG
,
sz
-
1
)
);
OUT_RING
(
CP_PACKET0_TABLE
(
RADEON_SE_TCL_SCALAR_DATA_REG
,
sz
-
1
)
);
OUT_RING_
USER_TABLE
(
data
,
sz
);
OUT_RING_
TABLE
(
cmdbuf
->
buf
,
sz
);
ADVANCE_RING
();
ADVANCE_RING
();
cmdbuf
->
buf
+=
sz
*
sizeof
(
int
);
cmdbuf
->
buf
+=
sz
*
sizeof
(
int
);
cmdbuf
->
bufsz
-=
sz
*
sizeof
(
int
);
cmdbuf
->
bufsz
-=
sz
*
sizeof
(
int
);
...
@@ -2532,7 +2504,6 @@ static __inline__ int radeon_emit_scalars2(
...
@@ -2532,7 +2504,6 @@ static __inline__ int radeon_emit_scalars2(
drm_radeon_cmd_buffer_t
*
cmdbuf
)
drm_radeon_cmd_buffer_t
*
cmdbuf
)
{
{
int
sz
=
header
.
scalars
.
count
;
int
sz
=
header
.
scalars
.
count
;
int
__user
*
data
=
(
int
__user
*
)
cmdbuf
->
buf
;
int
start
=
((
unsigned
int
)
header
.
scalars
.
offset
)
+
0x100
;
int
start
=
((
unsigned
int
)
header
.
scalars
.
offset
)
+
0x100
;
int
stride
=
header
.
scalars
.
stride
;
int
stride
=
header
.
scalars
.
stride
;
RING_LOCALS
;
RING_LOCALS
;
...
@@ -2541,7 +2512,7 @@ static __inline__ int radeon_emit_scalars2(
...
@@ -2541,7 +2512,7 @@ static __inline__ int radeon_emit_scalars2(
OUT_RING
(
CP_PACKET0
(
RADEON_SE_TCL_SCALAR_INDX_REG
,
0
)
);
OUT_RING
(
CP_PACKET0
(
RADEON_SE_TCL_SCALAR_INDX_REG
,
0
)
);
OUT_RING
(
start
|
(
stride
<<
RADEON_SCAL_INDX_DWORD_STRIDE_SHIFT
));
OUT_RING
(
start
|
(
stride
<<
RADEON_SCAL_INDX_DWORD_STRIDE_SHIFT
));
OUT_RING
(
CP_PACKET0_TABLE
(
RADEON_SE_TCL_SCALAR_DATA_REG
,
sz
-
1
)
);
OUT_RING
(
CP_PACKET0_TABLE
(
RADEON_SE_TCL_SCALAR_DATA_REG
,
sz
-
1
)
);
OUT_RING_
USER_TABLE
(
data
,
sz
);
OUT_RING_
TABLE
(
cmdbuf
->
buf
,
sz
);
ADVANCE_RING
();
ADVANCE_RING
();
cmdbuf
->
buf
+=
sz
*
sizeof
(
int
);
cmdbuf
->
buf
+=
sz
*
sizeof
(
int
);
cmdbuf
->
bufsz
-=
sz
*
sizeof
(
int
);
cmdbuf
->
bufsz
-=
sz
*
sizeof
(
int
);
...
@@ -2554,7 +2525,6 @@ static __inline__ int radeon_emit_vectors(
...
@@ -2554,7 +2525,6 @@ static __inline__ int radeon_emit_vectors(
drm_radeon_cmd_buffer_t
*
cmdbuf
)
drm_radeon_cmd_buffer_t
*
cmdbuf
)
{
{
int
sz
=
header
.
vectors
.
count
;
int
sz
=
header
.
vectors
.
count
;
int
__user
*
data
=
(
int
__user
*
)
cmdbuf
->
buf
;
int
start
=
header
.
vectors
.
offset
;
int
start
=
header
.
vectors
.
offset
;
int
stride
=
header
.
vectors
.
stride
;
int
stride
=
header
.
vectors
.
stride
;
RING_LOCALS
;
RING_LOCALS
;
...
@@ -2563,7 +2533,7 @@ static __inline__ int radeon_emit_vectors(
...
@@ -2563,7 +2533,7 @@ static __inline__ int radeon_emit_vectors(
OUT_RING
(
CP_PACKET0
(
RADEON_SE_TCL_VECTOR_INDX_REG
,
0
)
);
OUT_RING
(
CP_PACKET0
(
RADEON_SE_TCL_VECTOR_INDX_REG
,
0
)
);
OUT_RING
(
start
|
(
stride
<<
RADEON_VEC_INDX_OCTWORD_STRIDE_SHIFT
));
OUT_RING
(
start
|
(
stride
<<
RADEON_VEC_INDX_OCTWORD_STRIDE_SHIFT
));
OUT_RING
(
CP_PACKET0_TABLE
(
RADEON_SE_TCL_VECTOR_DATA_REG
,
(
sz
-
1
)
)
);
OUT_RING
(
CP_PACKET0_TABLE
(
RADEON_SE_TCL_VECTOR_DATA_REG
,
(
sz
-
1
)
)
);
OUT_RING_
USER_TABLE
(
data
,
sz
);
OUT_RING_
TABLE
(
cmdbuf
->
buf
,
sz
);
ADVANCE_RING
();
ADVANCE_RING
();
cmdbuf
->
buf
+=
sz
*
sizeof
(
int
);
cmdbuf
->
buf
+=
sz
*
sizeof
(
int
);
...
@@ -2578,7 +2548,6 @@ static int radeon_emit_packet3( drm_device_t *dev,
...
@@ -2578,7 +2548,6 @@ static int radeon_emit_packet3( drm_device_t *dev,
{
{
drm_radeon_private_t
*
dev_priv
=
dev
->
dev_private
;
drm_radeon_private_t
*
dev_priv
=
dev
->
dev_private
;
unsigned
int
cmdsz
;
unsigned
int
cmdsz
;
int
__user
*
cmd
=
(
int
__user
*
)
cmdbuf
->
buf
;
int
ret
;
int
ret
;
RING_LOCALS
;
RING_LOCALS
;
...
@@ -2591,7 +2560,7 @@ static int radeon_emit_packet3( drm_device_t *dev,
...
@@ -2591,7 +2560,7 @@ static int radeon_emit_packet3( drm_device_t *dev,
}
}
BEGIN_RING
(
cmdsz
);
BEGIN_RING
(
cmdsz
);
OUT_RING_
USER_TABLE
(
cmd
,
cmdsz
);
OUT_RING_
TABLE
(
cmdbuf
->
buf
,
cmdsz
);
ADVANCE_RING
();
ADVANCE_RING
();
cmdbuf
->
buf
+=
cmdsz
*
4
;
cmdbuf
->
buf
+=
cmdsz
*
4
;
...
@@ -2608,7 +2577,6 @@ static int radeon_emit_packet3_cliprect( drm_device_t *dev,
...
@@ -2608,7 +2577,6 @@ static int radeon_emit_packet3_cliprect( drm_device_t *dev,
drm_radeon_private_t
*
dev_priv
=
dev
->
dev_private
;
drm_radeon_private_t
*
dev_priv
=
dev
->
dev_private
;
drm_clip_rect_t
box
;
drm_clip_rect_t
box
;
unsigned
int
cmdsz
;
unsigned
int
cmdsz
;
int
__user
*
cmd
=
(
int
__user
*
)
cmdbuf
->
buf
;
int
ret
;
int
ret
;
drm_clip_rect_t
__user
*
boxes
=
cmdbuf
->
boxes
;
drm_clip_rect_t
__user
*
boxes
=
cmdbuf
->
boxes
;
int
i
=
0
;
int
i
=
0
;
...
@@ -2627,7 +2595,7 @@ static int radeon_emit_packet3_cliprect( drm_device_t *dev,
...
@@ -2627,7 +2595,7 @@ static int radeon_emit_packet3_cliprect( drm_device_t *dev,
do
{
do
{
if
(
i
<
cmdbuf
->
nbox
)
{
if
(
i
<
cmdbuf
->
nbox
)
{
if
(
DRM_COPY_FROM_USER
_UNCHECKED
(
&
box
,
&
boxes
[
i
],
sizeof
(
box
)
))
if
(
DRM_COPY_FROM_USER
(
&
box
,
&
boxes
[
i
],
sizeof
(
box
)
))
return
DRM_ERR
(
EFAULT
);
return
DRM_ERR
(
EFAULT
);
/* FIXME The second and subsequent times round
/* FIXME The second and subsequent times round
* this loop, send a WAIT_UNTIL_3D_IDLE before
* this loop, send a WAIT_UNTIL_3D_IDLE before
...
@@ -2650,7 +2618,7 @@ static int radeon_emit_packet3_cliprect( drm_device_t *dev,
...
@@ -2650,7 +2618,7 @@ static int radeon_emit_packet3_cliprect( drm_device_t *dev,
}
}
BEGIN_RING
(
cmdsz
);
BEGIN_RING
(
cmdsz
);
OUT_RING_
USER_TABLE
(
cmd
,
cmdsz
);
OUT_RING_
TABLE
(
cmdbuf
->
buf
,
cmdsz
);
ADVANCE_RING
();
ADVANCE_RING
();
}
while
(
++
i
<
cmdbuf
->
nbox
);
}
while
(
++
i
<
cmdbuf
->
nbox
);
...
@@ -2703,7 +2671,8 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
...
@@ -2703,7 +2671,8 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
int
idx
;
int
idx
;
drm_radeon_cmd_buffer_t
cmdbuf
;
drm_radeon_cmd_buffer_t
cmdbuf
;
drm_radeon_cmd_header_t
header
;
drm_radeon_cmd_header_t
header
;
int
orig_nbox
;
int
orig_nbox
,
orig_bufsz
;
char
*
kbuf
=
NULL
;
LOCK_TEST_WITH_RETURN
(
dev
,
filp
);
LOCK_TEST_WITH_RETURN
(
dev
,
filp
);
...
@@ -2720,24 +2689,29 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
...
@@ -2720,24 +2689,29 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
RING_SPACE_TEST_WITH_RETURN
(
dev_priv
);
RING_SPACE_TEST_WITH_RETURN
(
dev_priv
);
VB_AGE_TEST_WITH_RETURN
(
dev_priv
);
VB_AGE_TEST_WITH_RETURN
(
dev_priv
);
if
(
cmdbuf
.
bufsz
>
64
*
1024
||
cmdbuf
.
bufsz
<
0
)
{
return
DRM_ERR
(
EINVAL
);
}
if
(
DRM_VERIFYAREA_READ
(
cmdbuf
.
buf
,
cmdbuf
.
bufsz
))
/* Allocate an in-kernel area and copy in the cmdbuf. Do this to avoid
return
DRM_ERR
(
EFAULT
);
* races between checking values and using those values in other code,
* and simply to avoid a lot of function calls to copy in data.
if
(
cmdbuf
.
nbox
&&
*/
DRM_VERIFYAREA_READ
(
cmdbuf
.
boxes
,
orig_bufsz
=
cmdbuf
.
bufsz
;
cmdbuf
.
nbox
*
sizeof
(
drm_clip_rect_t
)))
if
(
orig_bufsz
!=
0
)
{
return
DRM_ERR
(
EFAULT
);
kbuf
=
drm_alloc
(
cmdbuf
.
bufsz
,
DRM_MEM_DRIVER
);
if
(
kbuf
==
NULL
)
return
DRM_ERR
(
ENOMEM
);
if
(
DRM_COPY_FROM_USER
(
kbuf
,
cmdbuf
.
buf
,
cmdbuf
.
bufsz
))
return
DRM_ERR
(
EFAULT
);
cmdbuf
.
buf
=
kbuf
;
}
orig_nbox
=
cmdbuf
.
nbox
;
orig_nbox
=
cmdbuf
.
nbox
;
while
(
cmdbuf
.
bufsz
>=
sizeof
(
header
)
)
{
while
(
cmdbuf
.
bufsz
>=
sizeof
(
header
)
)
{
if
(
DRM_GET_USER_UNCHECKED
(
header
.
i
,
(
int
__user
*
)
cmdbuf
.
buf
))
{
DRM_ERROR
(
"__get_user %p
\n
"
,
cmdbuf
.
buf
);
return
DRM_ERR
(
EFAULT
);
}
header
.
i
=
*
(
int
*
)
cmdbuf
.
buf
;
cmdbuf
.
buf
+=
sizeof
(
header
);
cmdbuf
.
buf
+=
sizeof
(
header
);
cmdbuf
.
bufsz
-=
sizeof
(
header
);
cmdbuf
.
bufsz
-=
sizeof
(
header
);
...
@@ -2746,7 +2720,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
...
@@ -2746,7 +2720,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
DRM_DEBUG
(
"RADEON_CMD_PACKET
\n
"
);
DRM_DEBUG
(
"RADEON_CMD_PACKET
\n
"
);
if
(
radeon_emit_packets
(
dev_priv
,
filp_priv
,
header
,
&
cmdbuf
))
{
if
(
radeon_emit_packets
(
dev_priv
,
filp_priv
,
header
,
&
cmdbuf
))
{
DRM_ERROR
(
"radeon_emit_packets failed
\n
"
);
DRM_ERROR
(
"radeon_emit_packets failed
\n
"
);
return
DRM_ERR
(
EINVAL
)
;
goto
err
;
}
}
break
;
break
;
...
@@ -2754,7 +2728,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
...
@@ -2754,7 +2728,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
DRM_DEBUG
(
"RADEON_CMD_SCALARS
\n
"
);
DRM_DEBUG
(
"RADEON_CMD_SCALARS
\n
"
);
if
(
radeon_emit_scalars
(
dev_priv
,
header
,
&
cmdbuf
))
{
if
(
radeon_emit_scalars
(
dev_priv
,
header
,
&
cmdbuf
))
{
DRM_ERROR
(
"radeon_emit_scalars failed
\n
"
);
DRM_ERROR
(
"radeon_emit_scalars failed
\n
"
);
return
DRM_ERR
(
EINVAL
)
;
goto
err
;
}
}
break
;
break
;
...
@@ -2762,7 +2736,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
...
@@ -2762,7 +2736,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
DRM_DEBUG
(
"RADEON_CMD_VECTORS
\n
"
);
DRM_DEBUG
(
"RADEON_CMD_VECTORS
\n
"
);
if
(
radeon_emit_vectors
(
dev_priv
,
header
,
&
cmdbuf
))
{
if
(
radeon_emit_vectors
(
dev_priv
,
header
,
&
cmdbuf
))
{
DRM_ERROR
(
"radeon_emit_vectors failed
\n
"
);
DRM_ERROR
(
"radeon_emit_vectors failed
\n
"
);
return
DRM_ERR
(
EINVAL
)
;
goto
err
;
}
}
break
;
break
;
...
@@ -2772,14 +2746,14 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
...
@@ -2772,14 +2746,14 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
if
(
idx
<
0
||
idx
>=
dma
->
buf_count
)
{
if
(
idx
<
0
||
idx
>=
dma
->
buf_count
)
{
DRM_ERROR
(
"buffer index %d (of %d max)
\n
"
,
DRM_ERROR
(
"buffer index %d (of %d max)
\n
"
,
idx
,
dma
->
buf_count
-
1
);
idx
,
dma
->
buf_count
-
1
);
return
DRM_ERR
(
EINVAL
)
;
goto
err
;
}
}
buf
=
dma
->
buflist
[
idx
];
buf
=
dma
->
buflist
[
idx
];
if
(
buf
->
filp
!=
filp
||
buf
->
pending
)
{
if
(
buf
->
filp
!=
filp
||
buf
->
pending
)
{
DRM_ERROR
(
"bad buffer %p %p %d
\n
"
,
DRM_ERROR
(
"bad buffer %p %p %d
\n
"
,
buf
->
filp
,
filp
,
buf
->
pending
);
buf
->
filp
,
filp
,
buf
->
pending
);
return
DRM_ERR
(
EINVAL
)
;
goto
err
;
}
}
radeon_cp_discard_buffer
(
dev
,
buf
);
radeon_cp_discard_buffer
(
dev
,
buf
);
...
@@ -2789,7 +2763,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
...
@@ -2789,7 +2763,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
DRM_DEBUG
(
"RADEON_CMD_PACKET3
\n
"
);
DRM_DEBUG
(
"RADEON_CMD_PACKET3
\n
"
);
if
(
radeon_emit_packet3
(
dev
,
filp_priv
,
&
cmdbuf
))
{
if
(
radeon_emit_packet3
(
dev
,
filp_priv
,
&
cmdbuf
))
{
DRM_ERROR
(
"radeon_emit_packet3 failed
\n
"
);
DRM_ERROR
(
"radeon_emit_packet3 failed
\n
"
);
return
DRM_ERR
(
EINVAL
)
;
goto
err
;
}
}
break
;
break
;
...
@@ -2797,7 +2771,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
...
@@ -2797,7 +2771,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
DRM_DEBUG
(
"RADEON_CMD_PACKET3_CLIP
\n
"
);
DRM_DEBUG
(
"RADEON_CMD_PACKET3_CLIP
\n
"
);
if
(
radeon_emit_packet3_cliprect
(
dev
,
filp_priv
,
&
cmdbuf
,
orig_nbox
))
{
if
(
radeon_emit_packet3_cliprect
(
dev
,
filp_priv
,
&
cmdbuf
,
orig_nbox
))
{
DRM_ERROR
(
"radeon_emit_packet3_clip failed
\n
"
);
DRM_ERROR
(
"radeon_emit_packet3_clip failed
\n
"
);
return
DRM_ERR
(
EINVAL
)
;
goto
err
;
}
}
break
;
break
;
...
@@ -2805,7 +2779,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
...
@@ -2805,7 +2779,7 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
DRM_DEBUG
(
"RADEON_CMD_SCALARS2
\n
"
);
DRM_DEBUG
(
"RADEON_CMD_SCALARS2
\n
"
);
if
(
radeon_emit_scalars2
(
dev_priv
,
header
,
&
cmdbuf
))
{
if
(
radeon_emit_scalars2
(
dev_priv
,
header
,
&
cmdbuf
))
{
DRM_ERROR
(
"radeon_emit_scalars2 failed
\n
"
);
DRM_ERROR
(
"radeon_emit_scalars2 failed
\n
"
);
return
DRM_ERR
(
EINVAL
)
;
goto
err
;
}
}
break
;
break
;
...
@@ -2813,21 +2787,28 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
...
@@ -2813,21 +2787,28 @@ int radeon_cp_cmdbuf( DRM_IOCTL_ARGS )
DRM_DEBUG
(
"RADEON_CMD_WAIT
\n
"
);
DRM_DEBUG
(
"RADEON_CMD_WAIT
\n
"
);
if
(
radeon_emit_wait
(
dev
,
header
.
wait
.
flags
))
{
if
(
radeon_emit_wait
(
dev
,
header
.
wait
.
flags
))
{
DRM_ERROR
(
"radeon_emit_wait failed
\n
"
);
DRM_ERROR
(
"radeon_emit_wait failed
\n
"
);
return
DRM_ERR
(
EINVAL
)
;
goto
err
;
}
}
break
;
break
;
default:
default:
DRM_ERROR
(
"bad cmd_type %d at %p
\n
"
,
DRM_ERROR
(
"bad cmd_type %d at %p
\n
"
,
header
.
header
.
cmd_type
,
header
.
header
.
cmd_type
,
cmdbuf
.
buf
-
sizeof
(
header
));
cmdbuf
.
buf
-
sizeof
(
header
));
return
DRM_ERR
(
EINVAL
)
;
goto
err
;
}
}
}
}
if
(
orig_bufsz
!=
0
)
drm_free
(
kbuf
,
orig_bufsz
,
DRM_MEM_DRIVER
);
DRM_DEBUG
(
"DONE
\n
"
);
DRM_DEBUG
(
"DONE
\n
"
);
COMMIT_RING
();
COMMIT_RING
();
return
0
;
return
0
;
err:
if
(
orig_bufsz
!=
0
)
drm_free
(
kbuf
,
orig_bufsz
,
DRM_MEM_DRIVER
);
return
DRM_ERR
(
EINVAL
);
}
}
...
...
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