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
cf41f8ac
Commit
cf41f8ac
authored
Feb 02, 2006
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'drm-linus' of
git://git.kernel.org/pub/scm/linux/kernel/git/airlied/drm-2.6
parents
0271fc2d
30e2fb18
Changes
28
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
28 changed files
with
248 additions
and
175 deletions
+248
-175
drivers/char/drm/ati_pcigart.c
drivers/char/drm/ati_pcigart.c
+7
-10
drivers/char/drm/drmP.h
drivers/char/drm/drmP.h
+3
-2
drivers/char/drm/drm_auth.c
drivers/char/drm/drm_auth.c
+10
-10
drivers/char/drm/drm_bufs.c
drivers/char/drm/drm_bufs.c
+40
-40
drivers/char/drm/drm_context.c
drivers/char/drm/drm_context.c
+26
-26
drivers/char/drm/drm_drv.c
drivers/char/drm/drm_drv.c
+2
-2
drivers/char/drm/drm_fops.c
drivers/char/drm/drm_fops.c
+6
-6
drivers/char/drm/drm_ioctl.c
drivers/char/drm/drm_ioctl.c
+9
-9
drivers/char/drm/drm_irq.c
drivers/char/drm/drm_irq.c
+8
-8
drivers/char/drm/drm_pciids.h
drivers/char/drm/drm_pciids.h
+2
-0
drivers/char/drm/drm_proc.c
drivers/char/drm/drm_proc.c
+14
-14
drivers/char/drm/drm_stub.c
drivers/char/drm/drm_stub.c
+2
-2
drivers/char/drm/drm_vm.c
drivers/char/drm/drm_vm.c
+6
-6
drivers/char/drm/i810_dma.c
drivers/char/drm/i810_dma.c
+1
-1
drivers/char/drm/i810_drv.h
drivers/char/drm/i810_drv.h
+0
-2
drivers/char/drm/i830_dma.c
drivers/char/drm/i830_dma.c
+1
-1
drivers/char/drm/i830_drv.h
drivers/char/drm/i830_drv.h
+0
-3
drivers/char/drm/i915_dma.c
drivers/char/drm/i915_dma.c
+30
-12
drivers/char/drm/i915_drm.h
drivers/char/drm/i915_drm.h
+33
-0
drivers/char/drm/i915_drv.h
drivers/char/drm/i915_drv.h
+4
-2
drivers/char/drm/i915_mem.c
drivers/char/drm/i915_mem.c
+31
-0
drivers/char/drm/radeon_cp.c
drivers/char/drm/radeon_cp.c
+1
-1
drivers/char/drm/savage_bci.c
drivers/char/drm/savage_bci.c
+3
-1
drivers/char/drm/savage_drv.h
drivers/char/drm/savage_drv.h
+0
-1
drivers/char/drm/via_dma.c
drivers/char/drm/via_dma.c
+5
-5
drivers/char/drm/via_dmablit.c
drivers/char/drm/via_dmablit.c
+3
-3
drivers/char/drm/via_drv.h
drivers/char/drm/via_drv.h
+0
-7
drivers/char/drm/via_irq.c
drivers/char/drm/via_irq.c
+1
-1
No files found.
drivers/char/drm/ati_pcigart.c
View file @
cf41f8ac
...
...
@@ -59,17 +59,16 @@ static void *drm_ati_alloc_pcigart_table(void)
int
i
;
DRM_DEBUG
(
"%s
\n
"
,
__FUNCTION__
);
address
=
__get_free_pages
(
GFP_KERNEL
,
ATI_PCIGART_TABLE_ORDER
);
address
=
__get_free_pages
(
GFP_KERNEL
|
__GFP_COMP
,
ATI_PCIGART_TABLE_ORDER
);
if
(
address
==
0UL
)
{
return
0
;
return
NULL
;
}
page
=
virt_to_page
(
address
);
for
(
i
=
0
;
i
<
ATI_PCIGART_TABLE_PAGES
;
i
++
,
page
++
)
{
get_page
(
page
);
for
(
i
=
0
;
i
<
ATI_PCIGART_TABLE_PAGES
;
i
++
,
page
++
)
SetPageReserved
(
page
);
}
DRM_DEBUG
(
"%s: returning 0x%08lx
\n
"
,
__FUNCTION__
,
address
);
return
(
void
*
)
address
;
...
...
@@ -83,10 +82,8 @@ static void drm_ati_free_pcigart_table(void *address)
page
=
virt_to_page
((
unsigned
long
)
address
);
for
(
i
=
0
;
i
<
ATI_PCIGART_TABLE_PAGES
;
i
++
,
page
++
)
{
__put_page
(
page
);
for
(
i
=
0
;
i
<
ATI_PCIGART_TABLE_PAGES
;
i
++
,
page
++
)
ClearPageReserved
(
page
);
}
free_pages
((
unsigned
long
)
address
,
ATI_PCIGART_TABLE_ORDER
);
}
...
...
@@ -127,7 +124,7 @@ int drm_ati_pcigart_cleanup(drm_device_t *dev, drm_ati_pcigart_info *gart_info)
if
(
gart_info
->
gart_table_location
==
DRM_ATI_GART_MAIN
&&
gart_info
->
addr
)
{
drm_ati_free_pcigart_table
(
gart_info
->
addr
);
gart_info
->
addr
=
0
;
gart_info
->
addr
=
NULL
;
}
return
1
;
...
...
@@ -168,7 +165,7 @@ int drm_ati_pcigart_init(drm_device_t *dev, drm_ati_pcigart_info *gart_info)
if
(
bus_address
==
0
)
{
DRM_ERROR
(
"unable to map PCIGART pages!
\n
"
);
drm_ati_free_pcigart_table
(
address
);
address
=
0
;
address
=
NULL
;
goto
done
;
}
}
else
{
...
...
drivers/char/drm/drmP.h
View file @
cf41f8ac
...
...
@@ -57,6 +57,7 @@
#include <linux/smp_lock.h>
/* For (un)lock_kernel */
#include <linux/mm.h>
#include <linux/cdev.h>
#include <linux/mutex.h>
#if defined(__alpha__) || defined(__powerpc__)
#include <asm/pgtable.h>
/* For pte_wrprotect */
#endif
...
...
@@ -623,7 +624,7 @@ typedef struct drm_device {
/** \name Locks */
/*@{ */
spinlock_t
count_lock
;
/**< For inuse, drm_device::open_count, drm_device::buf_use */
struct
semaphore
struct_sem
;
/**< For others */
struct
mutex
struct_mutex
;
/**< For others */
/*@} */
/** \name Usage Counters */
...
...
@@ -658,7 +659,7 @@ typedef struct drm_device {
/*@{ */
drm_ctx_list_t
*
ctxlist
;
/**< Linked list of context handles */
int
ctx_count
;
/**< Number of context handles */
struct
semaphore
ctxlist_sem
;
/**< For ctxlist */
struct
mutex
ctxlist_mutex
;
/**< For ctxlist */
drm_map_t
**
context_sareas
;
/**< per-context SAREA's */
int
max_context
;
...
...
drivers/char/drm/drm_auth.c
View file @
cf41f8ac
...
...
@@ -56,7 +56,7 @@ static int drm_hash_magic(drm_magic_t magic)
* \param magic magic number.
*
* Searches in drm_device::magiclist within all files with the same hash key
* the one with matching magic number, while holding the drm_device::struct_
sem
* the one with matching magic number, while holding the drm_device::struct_
mutex
* lock.
*/
static
drm_file_t
*
drm_find_file
(
drm_device_t
*
dev
,
drm_magic_t
magic
)
...
...
@@ -65,14 +65,14 @@ static drm_file_t *drm_find_file(drm_device_t * dev, drm_magic_t magic)
drm_magic_entry_t
*
pt
;
int
hash
=
drm_hash_magic
(
magic
);
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
for
(
pt
=
dev
->
magiclist
[
hash
].
head
;
pt
;
pt
=
pt
->
next
)
{
if
(
pt
->
magic
==
magic
)
{
retval
=
pt
->
priv
;
break
;
}
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
retval
;
}
...
...
@@ -85,7 +85,7 @@ static drm_file_t *drm_find_file(drm_device_t * dev, drm_magic_t magic)
*
* Creates a drm_magic_entry structure and appends to the linked list
* associated the magic number hash key in drm_device::magiclist, while holding
* the drm_device::struct_
sem
lock.
* the drm_device::struct_
mutex
lock.
*/
static
int
drm_add_magic
(
drm_device_t
*
dev
,
drm_file_t
*
priv
,
drm_magic_t
magic
)
...
...
@@ -104,7 +104,7 @@ static int drm_add_magic(drm_device_t * dev, drm_file_t * priv,
entry
->
priv
=
priv
;
entry
->
next
=
NULL
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
if
(
dev
->
magiclist
[
hash
].
tail
)
{
dev
->
magiclist
[
hash
].
tail
->
next
=
entry
;
dev
->
magiclist
[
hash
].
tail
=
entry
;
...
...
@@ -112,7 +112,7 @@ static int drm_add_magic(drm_device_t * dev, drm_file_t * priv,
dev
->
magiclist
[
hash
].
head
=
entry
;
dev
->
magiclist
[
hash
].
tail
=
entry
;
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
0
;
}
...
...
@@ -124,7 +124,7 @@ static int drm_add_magic(drm_device_t * dev, drm_file_t * priv,
* \param magic magic number.
*
* Searches and unlinks the entry in drm_device::magiclist with the magic
* number hash key, while holding the drm_device::struct_
sem
lock.
* number hash key, while holding the drm_device::struct_
mutex
lock.
*/
static
int
drm_remove_magic
(
drm_device_t
*
dev
,
drm_magic_t
magic
)
{
...
...
@@ -135,7 +135,7 @@ static int drm_remove_magic(drm_device_t * dev, drm_magic_t magic)
DRM_DEBUG
(
"%d
\n
"
,
magic
);
hash
=
drm_hash_magic
(
magic
);
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
for
(
pt
=
dev
->
magiclist
[
hash
].
head
;
pt
;
prev
=
pt
,
pt
=
pt
->
next
)
{
if
(
pt
->
magic
==
magic
)
{
if
(
dev
->
magiclist
[
hash
].
head
==
pt
)
{
...
...
@@ -147,11 +147,11 @@ static int drm_remove_magic(drm_device_t * dev, drm_magic_t magic)
if
(
prev
)
{
prev
->
next
=
pt
->
next
;
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
0
;
}
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
drm_free
(
pt
,
sizeof
(
*
pt
),
DRM_MEM_MAGIC
);
...
...
drivers/char/drm/drm_bufs.c
View file @
cf41f8ac
This diff is collapsed.
Click to expand it.
drivers/char/drm/drm_context.c
View file @
cf41f8ac
...
...
@@ -53,7 +53,7 @@
* \param ctx_handle context handle.
*
* Clears the bit specified by \p ctx_handle in drm_device::ctx_bitmap and the entry
* in drm_device::context_sareas, while holding the drm_device::struct_
sem
* in drm_device::context_sareas, while holding the drm_device::struct_
mutex
* lock.
*/
void
drm_ctxbitmap_free
(
drm_device_t
*
dev
,
int
ctx_handle
)
...
...
@@ -64,10 +64,10 @@ void drm_ctxbitmap_free(drm_device_t * dev, int ctx_handle)
goto
failed
;
if
(
ctx_handle
<
DRM_MAX_CTXBITMAP
)
{
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
clear_bit
(
ctx_handle
,
dev
->
ctx_bitmap
);
dev
->
context_sareas
[
ctx_handle
]
=
NULL
;
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
;
}
failed:
...
...
@@ -83,7 +83,7 @@ void drm_ctxbitmap_free(drm_device_t * dev, int ctx_handle)
*
* Find the first zero bit in drm_device::ctx_bitmap and (re)allocates
* drm_device::context_sareas to accommodate the new entry while holding the
* drm_device::struct_
sem
lock.
* drm_device::struct_
mutex
lock.
*/
static
int
drm_ctxbitmap_next
(
drm_device_t
*
dev
)
{
...
...
@@ -92,7 +92,7 @@ static int drm_ctxbitmap_next(drm_device_t * dev)
if
(
!
dev
->
ctx_bitmap
)
return
-
1
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
bit
=
find_first_zero_bit
(
dev
->
ctx_bitmap
,
DRM_MAX_CTXBITMAP
);
if
(
bit
<
DRM_MAX_CTXBITMAP
)
{
set_bit
(
bit
,
dev
->
ctx_bitmap
);
...
...
@@ -113,7 +113,7 @@ static int drm_ctxbitmap_next(drm_device_t * dev)
DRM_MEM_MAPS
);
if
(
!
ctx_sareas
)
{
clear_bit
(
bit
,
dev
->
ctx_bitmap
);
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
1
;
}
dev
->
context_sareas
=
ctx_sareas
;
...
...
@@ -126,16 +126,16 @@ static int drm_ctxbitmap_next(drm_device_t * dev)
DRM_MEM_MAPS
);
if
(
!
dev
->
context_sareas
)
{
clear_bit
(
bit
,
dev
->
ctx_bitmap
);
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
1
;
}
dev
->
context_sareas
[
bit
]
=
NULL
;
}
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
bit
;
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
1
;
}
...
...
@@ -145,24 +145,24 @@ static int drm_ctxbitmap_next(drm_device_t * dev)
* \param dev DRM device.
*
* Allocates and initialize drm_device::ctx_bitmap and drm_device::context_sareas, while holding
* the drm_device::struct_
sem
lock.
* the drm_device::struct_
mutex
lock.
*/
int
drm_ctxbitmap_init
(
drm_device_t
*
dev
)
{
int
i
;
int
temp
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
dev
->
ctx_bitmap
=
(
unsigned
long
*
)
drm_alloc
(
PAGE_SIZE
,
DRM_MEM_CTXBITMAP
);
if
(
dev
->
ctx_bitmap
==
NULL
)
{
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
ENOMEM
;
}
memset
((
void
*
)
dev
->
ctx_bitmap
,
0
,
PAGE_SIZE
);
dev
->
context_sareas
=
NULL
;
dev
->
max_context
=
-
1
;
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
for
(
i
=
0
;
i
<
DRM_RESERVED_CONTEXTS
;
i
++
)
{
temp
=
drm_ctxbitmap_next
(
dev
);
...
...
@@ -178,17 +178,17 @@ int drm_ctxbitmap_init(drm_device_t * dev)
* \param dev DRM device.
*
* Frees drm_device::ctx_bitmap and drm_device::context_sareas, while holding
* the drm_device::struct_
sem
lock.
* the drm_device::struct_
mutex
lock.
*/
void
drm_ctxbitmap_cleanup
(
drm_device_t
*
dev
)
{
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
if
(
dev
->
context_sareas
)
drm_free
(
dev
->
context_sareas
,
sizeof
(
*
dev
->
context_sareas
)
*
dev
->
max_context
,
DRM_MEM_MAPS
);
drm_free
((
void
*
)
dev
->
ctx_bitmap
,
PAGE_SIZE
,
DRM_MEM_CTXBITMAP
);
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
}
/*@}*/
...
...
@@ -222,15 +222,15 @@ int drm_getsareactx(struct inode *inode, struct file *filp,
if
(
copy_from_user
(
&
request
,
argp
,
sizeof
(
request
)))
return
-
EFAULT
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
if
(
dev
->
max_context
<
0
||
request
.
ctx_id
>=
(
unsigned
)
dev
->
max_context
)
{
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
EINVAL
;
}
map
=
dev
->
context_sareas
[
request
.
ctx_id
];
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
request
.
handle
=
NULL
;
list_for_each_entry
(
_entry
,
&
dev
->
maplist
->
head
,
head
)
{
...
...
@@ -274,7 +274,7 @@ int drm_setsareactx(struct inode *inode, struct file *filp,
(
drm_ctx_priv_map_t
__user
*
)
arg
,
sizeof
(
request
)))
return
-
EFAULT
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
list_for_each
(
list
,
&
dev
->
maplist
->
head
)
{
r_list
=
list_entry
(
list
,
drm_map_list_t
,
head
);
if
(
r_list
->
map
...
...
@@ -282,7 +282,7 @@ int drm_setsareactx(struct inode *inode, struct file *filp,
goto
found
;
}
bad:
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
EINVAL
;
found:
...
...
@@ -294,7 +294,7 @@ int drm_setsareactx(struct inode *inode, struct file *filp,
if
(
request
.
ctx_id
>=
(
unsigned
)
dev
->
max_context
)
goto
bad
;
dev
->
context_sareas
[
request
.
ctx_id
]
=
map
;
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
0
;
}
...
...
@@ -448,10 +448,10 @@ int drm_addctx(struct inode *inode, struct file *filp,
ctx_entry
->
handle
=
ctx
.
handle
;
ctx_entry
->
tag
=
priv
;
down
(
&
dev
->
ctxlist_sem
);
mutex_lock
(
&
dev
->
ctxlist_mutex
);
list_add
(
&
ctx_entry
->
head
,
&
dev
->
ctxlist
->
head
);
++
dev
->
ctx_count
;
up
(
&
dev
->
ctxlist_sem
);
mutex_unlock
(
&
dev
->
ctxlist_mutex
);
if
(
copy_to_user
(
argp
,
&
ctx
,
sizeof
(
ctx
)))
return
-
EFAULT
;
...
...
@@ -574,7 +574,7 @@ int drm_rmctx(struct inode *inode, struct file *filp,
drm_ctxbitmap_free
(
dev
,
ctx
.
handle
);
}
down
(
&
dev
->
ctxlist_sem
);
mutex_lock
(
&
dev
->
ctxlist_mutex
);
if
(
!
list_empty
(
&
dev
->
ctxlist
->
head
))
{
drm_ctx_list_t
*
pos
,
*
n
;
...
...
@@ -586,7 +586,7 @@ int drm_rmctx(struct inode *inode, struct file *filp,
}
}
}
up
(
&
dev
->
ctxlist_sem
);
mutex_unlock
(
&
dev
->
ctxlist_mutex
);
return
0
;
}
...
...
drivers/char/drm/drm_drv.c
View file @
cf41f8ac
...
...
@@ -151,7 +151,7 @@ int drm_lastclose(drm_device_t * dev)
if
(
dev
->
irq_enabled
)
drm_irq_uninstall
(
dev
);
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
del_timer
(
&
dev
->
timer
);
/* Clear pid list */
...
...
@@ -231,7 +231,7 @@ int drm_lastclose(drm_device_t * dev)
dev
->
lock
.
filp
=
NULL
;
wake_up_interruptible
(
&
dev
->
lock
.
lock_queue
);
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
DRM_DEBUG
(
"lastclose completed
\n
"
);
return
0
;
...
...
drivers/char/drm/drm_fops.c
View file @
cf41f8ac
...
...
@@ -262,7 +262,7 @@ static int drm_open_helper(struct inode *inode, struct file *filp,
goto
out_free
;
}
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
if
(
!
dev
->
file_last
)
{
priv
->
next
=
NULL
;
priv
->
prev
=
NULL
;
...
...
@@ -276,7 +276,7 @@ static int drm_open_helper(struct inode *inode, struct file *filp,
dev
->
file_last
->
next
=
priv
;
dev
->
file_last
=
priv
;
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
#ifdef __alpha__
/*
...
...
@@ -413,7 +413,7 @@ int drm_release(struct inode *inode, struct file *filp)
drm_fasync
(
-
1
,
filp
,
0
);
down
(
&
dev
->
ctxlist_sem
);
mutex_lock
(
&
dev
->
ctxlist_mutex
);
if
(
dev
->
ctxlist
&&
(
!
list_empty
(
&
dev
->
ctxlist
->
head
)))
{
drm_ctx_list_t
*
pos
,
*
n
;
...
...
@@ -432,9 +432,9 @@ int drm_release(struct inode *inode, struct file *filp)
}
}
}
up
(
&
dev
->
ctxlist_sem
);
mutex_unlock
(
&
dev
->
ctxlist_mutex
);
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
if
(
priv
->
remove_auth_on_close
==
1
)
{
drm_file_t
*
temp
=
dev
->
file_first
;
while
(
temp
)
{
...
...
@@ -452,7 +452,7 @@ int drm_release(struct inode *inode, struct file *filp)
}
else
{
dev
->
file_last
=
priv
->
prev
;
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
if
(
dev
->
driver
->
postclose
)
dev
->
driver
->
postclose
(
dev
,
priv
);
...
...
drivers/char/drm/drm_ioctl.c
View file @
cf41f8ac
...
...
@@ -194,9 +194,9 @@ int drm_getmap(struct inode *inode, struct file *filp,
return
-
EFAULT
;
idx
=
map
.
offset
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
if
(
idx
<
0
)
{
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
EINVAL
;
}
...
...
@@ -209,7 +209,7 @@ int drm_getmap(struct inode *inode, struct file *filp,
i
++
;
}
if
(
!
r_list
||
!
r_list
->
map
)
{
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
EINVAL
;
}
...
...
@@ -219,7 +219,7 @@ int drm_getmap(struct inode *inode, struct file *filp,
map
.
flags
=
r_list
->
map
->
flags
;
map
.
handle
=
(
void
*
)(
unsigned
long
)
r_list
->
user_token
;
map
.
mtrr
=
r_list
->
map
->
mtrr
;
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
if
(
copy_to_user
(
argp
,
&
map
,
sizeof
(
map
)))
return
-
EFAULT
;
...
...
@@ -253,11 +253,11 @@ int drm_getclient(struct inode *inode, struct file *filp,
if
(
copy_from_user
(
&
client
,
argp
,
sizeof
(
client
)))
return
-
EFAULT
;
idx
=
client
.
idx
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
for
(
i
=
0
,
pt
=
dev
->
file_first
;
i
<
idx
&&
pt
;
i
++
,
pt
=
pt
->
next
)
;
if
(
!
pt
)
{
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
EINVAL
;
}
client
.
auth
=
pt
->
authenticated
;
...
...
@@ -265,7 +265,7 @@ int drm_getclient(struct inode *inode, struct file *filp,
client
.
uid
=
pt
->
uid
;
client
.
magic
=
pt
->
magic
;
client
.
iocs
=
pt
->
ioctl_count
;
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
if
(
copy_to_user
(
argp
,
&
client
,
sizeof
(
client
)))
return
-
EFAULT
;
...
...
@@ -292,7 +292,7 @@ int drm_getstats(struct inode *inode, struct file *filp,
memset
(
&
stats
,
0
,
sizeof
(
stats
));
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
for
(
i
=
0
;
i
<
dev
->
counters
;
i
++
)
{
if
(
dev
->
types
[
i
]
==
_DRM_STAT_LOCK
)
...
...
@@ -305,7 +305,7 @@ int drm_getstats(struct inode *inode, struct file *filp,
stats
.
count
=
dev
->
counters
;
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
if
(
copy_to_user
((
drm_stats_t
__user
*
)
arg
,
&
stats
,
sizeof
(
stats
)))
return
-
EFAULT
;
...
...
drivers/char/drm/drm_irq.c
View file @
cf41f8ac
...
...
@@ -98,20 +98,20 @@ static int drm_irq_install(drm_device_t * dev)
if
(
dev
->
irq
==
0
)
return
-
EINVAL
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
/* Driver must have been initialized */
if
(
!
dev
->
dev_private
)
{
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
EINVAL
;
}
if
(
dev
->
irq_enabled
)
{
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
-
EBUSY
;
}
dev
->
irq_enabled
=
1
;
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
DRM_DEBUG
(
"%s: irq=%d
\n
"
,
__FUNCTION__
,
dev
->
irq
);
...
...
@@ -135,9 +135,9 @@ static int drm_irq_install(drm_device_t * dev)
ret
=
request_irq
(
dev
->
irq
,
dev
->
driver
->
irq_handler
,
sh_flags
,
dev
->
devname
,
dev
);
if
(
ret
<
0
)
{
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
dev
->
irq_enabled
=
0
;
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
ret
;
}
...
...
@@ -161,10 +161,10 @@ int drm_irq_uninstall(drm_device_t * dev)
if
(
!
drm_core_check_feature
(
dev
,
DRIVER_HAVE_IRQ
))
return
-
EINVAL
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
irq_enabled
=
dev
->
irq_enabled
;
dev
->
irq_enabled
=
0
;
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
if
(
!
irq_enabled
)
return
-
EINVAL
;
...
...
drivers/char/drm/drm_pciids.h
View file @
cf41f8ac
...
...
@@ -3,6 +3,7 @@
Please contact dri-devel@lists.sf.net to add new cards to this list
*/
#define radeon_PCI_IDS \
{0x1002, 0x3150, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RV350},\
{0x1002, 0x4136, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS100|CHIP_IS_IGP}, \
{0x1002, 0x4137, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_RS200|CHIP_IS_IGP}, \
{0x1002, 0x4144, PCI_ANY_ID, PCI_ANY_ID, 0, 0, CHIP_R300}, \
...
...
@@ -242,5 +243,6 @@
{0x8086, 0x2582, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0}, \
{0x8086, 0x2592, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0}, \
{0x8086, 0x2772, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0}, \
{0x8086, 0x27a2, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0}, \
{0, 0, 0}
drivers/char/drm/drm_proc.c
View file @
cf41f8ac
...
...
@@ -258,7 +258,7 @@ static int drm__vm_info(char *buf, char **start, off_t offset, int request,
}
/**
* Simply calls _vm_info() while holding the drm_device::struct_
sem
lock.
* Simply calls _vm_info() while holding the drm_device::struct_
mutex
lock.
*/
static
int
drm_vm_info
(
char
*
buf
,
char
**
start
,
off_t
offset
,
int
request
,
int
*
eof
,
void
*
data
)
...
...
@@ -266,9 +266,9 @@ static int drm_vm_info(char *buf, char **start, off_t offset, int request,
drm_device_t
*
dev
=
(
drm_device_t
*
)
data
;
int
ret
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
ret
=
drm__vm_info
(
buf
,
start
,
offset
,
request
,
eof
,
data
);
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
ret
;
}
...
...
@@ -331,7 +331,7 @@ static int drm__queues_info(char *buf, char **start, off_t offset,
}
/**
* Simply calls _queues_info() while holding the drm_device::struct_
sem
lock.
* Simply calls _queues_info() while holding the drm_device::struct_
mutex
lock.
*/
static
int
drm_queues_info
(
char
*
buf
,
char
**
start
,
off_t
offset
,
int
request
,
int
*
eof
,
void
*
data
)
...
...
@@ -339,9 +339,9 @@ static int drm_queues_info(char *buf, char **start, off_t offset, int request,
drm_device_t
*
dev
=
(
drm_device_t
*
)
data
;
int
ret
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
ret
=
drm__queues_info
(
buf
,
start
,
offset
,
request
,
eof
,
data
);
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
ret
;
}
...
...
@@ -403,7 +403,7 @@ static int drm__bufs_info(char *buf, char **start, off_t offset, int request,
}
/**
* Simply calls _bufs_info() while holding the drm_device::struct_
sem
lock.
* Simply calls _bufs_info() while holding the drm_device::struct_
mutex
lock.
*/
static
int
drm_bufs_info
(
char
*
buf
,
char
**
start
,
off_t
offset
,
int
request
,
int
*
eof
,
void
*
data
)
...
...
@@ -411,9 +411,9 @@ static int drm_bufs_info(char *buf, char **start, off_t offset, int request,
drm_device_t
*
dev
=
(
drm_device_t
*
)
data
;
int
ret
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
ret
=
drm__bufs_info
(
buf
,
start
,
offset
,
request
,
eof
,
data
);
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
ret
;
}
...
...
@@ -459,7 +459,7 @@ static int drm__clients_info(char *buf, char **start, off_t offset,
}
/**
* Simply calls _clients_info() while holding the drm_device::struct_
sem
lock.
* Simply calls _clients_info() while holding the drm_device::struct_
mutex
lock.
*/
static
int
drm_clients_info
(
char
*
buf
,
char
**
start
,
off_t
offset
,
int
request
,
int
*
eof
,
void
*
data
)
...
...
@@ -467,9 +467,9 @@ static int drm_clients_info(char *buf, char **start, off_t offset,
drm_device_t
*
dev
=
(
drm_device_t
*
)
data
;
int
ret
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
ret
=
drm__clients_info
(
buf
,
start
,
offset
,
request
,
eof
,
data
);
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
ret
;
}
...
...
@@ -540,9 +540,9 @@ static int drm_vma_info(char *buf, char **start, off_t offset, int request,
drm_device_t
*
dev
=
(
drm_device_t
*
)
data
;
int
ret
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
ret
=
drm__vma_info
(
buf
,
start
,
offset
,
request
,
eof
,
data
);
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
return
ret
;
}
#endif
drivers/char/drm/drm_stub.c
View file @
cf41f8ac
...
...
@@ -61,8 +61,8 @@ static int drm_fill_in_dev(drm_device_t * dev, struct pci_dev *pdev,
spin_lock_init
(
&
dev
->
count_lock
);
init_timer
(
&
dev
->
timer
);
sema_init
(
&
dev
->
struct_sem
,
1
);
sema_init
(
&
dev
->
ctxlist_sem
,
1
);
mutex_init
(
&
dev
->
struct_mutex
);
mutex_init
(
&
dev
->
ctxlist_mutex
);
dev
->
pdev
=
pdev
;
...
...
drivers/char/drm/drm_vm.c
View file @
cf41f8ac
...
...
@@ -188,7 +188,7 @@ static void drm_vm_shm_close(struct vm_area_struct *vma)
map
=
vma
->
vm_private_data
;
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
for
(
pt
=
dev
->
vmalist
,
prev
=
NULL
;
pt
;
pt
=
next
)
{
next
=
pt
->
next
;
if
(
pt
->
vma
->
vm_private_data
==
map
)
...
...
@@ -248,7 +248,7 @@ static void drm_vm_shm_close(struct vm_area_struct *vma)
drm_free
(
map
,
sizeof
(
*
map
),
DRM_MEM_MAPS
);
}
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
}
/**
...
...
@@ -404,12 +404,12 @@ static void drm_vm_open(struct vm_area_struct *vma)
vma_entry
=
drm_alloc
(
sizeof
(
*
vma_entry
),
DRM_MEM_VMAS
);
if
(
vma_entry
)
{
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
vma_entry
->
vma
=
vma
;
vma_entry
->
next
=
dev
->
vmalist
;
vma_entry
->
pid
=
current
->
pid
;
dev
->
vmalist
=
vma_entry
;
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
}
}
...
...
@@ -431,7 +431,7 @@ static void drm_vm_close(struct vm_area_struct *vma)
vma
->
vm_start
,
vma
->
vm_end
-
vma
->
vm_start
);
atomic_dec
(
&
dev
->
vma_count
);
down
(
&
dev
->
struct_sem
);
mutex_lock
(
&
dev
->
struct_mutex
);
for
(
pt
=
dev
->
vmalist
,
prev
=
NULL
;
pt
;
prev
=
pt
,
pt
=
pt
->
next
)
{
if
(
pt
->
vma
==
vma
)
{
if
(
prev
)
{
...
...
@@ -443,7 +443,7 @@ static void drm_vm_close(struct vm_area_struct *vma)
break
;
}
}
up
(
&
dev
->
struct_sem
);
mutex_unlock
(
&
dev
->
struct_mutex
);
}
/**
...
...
drivers/char/drm/i810_dma.c
View file @
cf41f8ac
...
...
@@ -958,7 +958,7 @@ static int i810_flush_queue(drm_device_t * dev)
}
/* Must be called with the lock held */
void
i810_reclaim_buffers
(
drm_device_t
*
dev
,
struct
file
*
filp
)
static
void
i810_reclaim_buffers
(
drm_device_t
*
dev
,
struct
file
*
filp
)
{
drm_device_dma_t
*
dma
=
dev
->
dma
;
int
i
;
...
...
drivers/char/drm/i810_drv.h
View file @
cf41f8ac
...
...
@@ -113,8 +113,6 @@ typedef struct drm_i810_private {
}
drm_i810_private_t
;
/* i810_dma.c */
extern
void
i810_reclaim_buffers
(
drm_device_t
*
dev
,
struct
file
*
filp
);
extern
int
i810_driver_dma_quiescent
(
drm_device_t
*
dev
);
extern
void
i810_driver_reclaim_buffers_locked
(
drm_device_t
*
dev
,
struct
file
*
filp
);
...
...
drivers/char/drm/i830_dma.c
View file @
cf41f8ac
...
...
@@ -1239,7 +1239,7 @@ static int i830_flush_queue(drm_device_t * dev)
}
/* Must be called with the lock held */
void
i830_reclaim_buffers
(
drm_device_t
*
dev
,
struct
file
*
filp
)
static
void
i830_reclaim_buffers
(
drm_device_t
*
dev
,
struct
file
*
filp
)
{
drm_device_dma_t
*
dma
=
dev
->
dma
;
int
i
;
...
...
drivers/char/drm/i830_drv.h
View file @
cf41f8ac
...
...
@@ -123,9 +123,6 @@ typedef struct drm_i830_private {
extern
drm_ioctl_desc_t
i830_ioctls
[];
extern
int
i830_max_ioctl
;
/* i830_dma.c */
extern
void
i830_reclaim_buffers
(
drm_device_t
*
dev
,
struct
file
*
filp
);
/* i830_irq.c */
extern
int
i830_irq_emit
(
struct
inode
*
inode
,
struct
file
*
filp
,
unsigned
int
cmd
,
unsigned
long
arg
);
...
...
drivers/char/drm/i915_dma.c
View file @
cf41f8ac
...
...
@@ -344,18 +344,20 @@ static int i915_emit_cmds(drm_device_t * dev, int __user * buffer, int dwords)
int
i
;
RING_LOCALS
;
if
((
dwords
+
1
)
*
sizeof
(
int
)
>=
dev_priv
->
ring
.
Size
-
8
)
return
DRM_ERR
(
EINVAL
);
BEGIN_LP_RING
(((
dwords
+
1
)
&~
1
));
for
(
i
=
0
;
i
<
dwords
;)
{
int
cmd
,
sz
;
if
(
DRM_COPY_FROM_USER_UNCHECKED
(
&
cmd
,
&
buffer
[
i
],
sizeof
(
cmd
)))
return
DRM_ERR
(
EINVAL
);
/* printk("%d/%d ", i, dwords); */
if
((
sz
=
validate_cmd
(
cmd
))
==
0
||
i
+
sz
>
dwords
)
return
DRM_ERR
(
EINVAL
);
BEGIN_LP_RING
(
sz
);
OUT_RING
(
cmd
);
while
(
++
i
,
--
sz
)
{
...
...
@@ -365,9 +367,13 @@ static int i915_emit_cmds(drm_device_t * dev, int __user * buffer, int dwords)
}
OUT_RING
(
cmd
);
}
ADVANCE_LP_RING
();
}
if
(
dwords
&
1
)
OUT_RING
(
0
);
ADVANCE_LP_RING
();
return
0
;
}
...
...
@@ -401,6 +407,21 @@ static int i915_emit_box(drm_device_t * dev,
return
0
;
}
static
void
i915_emit_breadcrumb
(
drm_device_t
*
dev
)
{
drm_i915_private_t
*
dev_priv
=
dev
->
dev_private
;
RING_LOCALS
;
dev_priv
->
sarea_priv
->
last_enqueue
=
dev_priv
->
counter
++
;
BEGIN_LP_RING
(
4
);
OUT_RING
(
CMD_STORE_DWORD_IDX
);
OUT_RING
(
20
);
OUT_RING
(
dev_priv
->
counter
);
OUT_RING
(
0
);
ADVANCE_LP_RING
();
}
static
int
i915_dispatch_cmdbuffer
(
drm_device_t
*
dev
,
drm_i915_cmdbuffer_t
*
cmd
)
{
...
...
@@ -429,6 +450,7 @@ static int i915_dispatch_cmdbuffer(drm_device_t * dev,
return
ret
;
}
i915_emit_breadcrumb
(
dev
);
return
0
;
}
...
...
@@ -475,12 +497,7 @@ static int i915_dispatch_batchbuffer(drm_device_t * dev,
dev_priv
->
sarea_priv
->
last_enqueue
=
dev_priv
->
counter
++
;
BEGIN_LP_RING
(
4
);
OUT_RING
(
CMD_STORE_DWORD_IDX
);
OUT_RING
(
20
);
OUT_RING
(
dev_priv
->
counter
);
OUT_RING
(
0
);
ADVANCE_LP_RING
();
i915_emit_breadcrumb
(
dev
);
return
0
;
}
...
...
@@ -657,7 +674,7 @@ static int i915_getparam(DRM_IOCTL_ARGS)
value
=
READ_BREADCRUMB
(
dev_priv
);
break
;
default:
DRM_ERROR
(
"Unkown parameter %d
\n
"
,
param
.
param
);
DRM_ERROR
(
"Unk
n
own parameter %d
\n
"
,
param
.
param
);
return
DRM_ERR
(
EINVAL
);
}
...
...
@@ -742,7 +759,8 @@ drm_ioctl_desc_t i915_ioctls[] = {
[
DRM_IOCTL_NR
(
DRM_I915_ALLOC
)]
=
{
i915_mem_alloc
,
DRM_AUTH
},
[
DRM_IOCTL_NR
(
DRM_I915_FREE
)]
=
{
i915_mem_free
,
DRM_AUTH
},
[
DRM_IOCTL_NR
(
DRM_I915_INIT_HEAP
)]
=
{
i915_mem_init_heap
,
DRM_AUTH
|
DRM_MASTER
|
DRM_ROOT_ONLY
},
[
DRM_IOCTL_NR
(
DRM_I915_CMDBUFFER
)]
=
{
i915_cmdbuffer
,
DRM_AUTH
}
[
DRM_IOCTL_NR
(
DRM_I915_CMDBUFFER
)]
=
{
i915_cmdbuffer
,
DRM_AUTH
},
[
DRM_IOCTL_NR
(
DRM_I915_DESTROY_HEAP
)]
=
{
i915_mem_destroy_heap
,
DRM_AUTH
|
DRM_MASTER
|
DRM_ROOT_ONLY
}
};
int
i915_max_ioctl
=
DRM_ARRAY_SIZE
(
i915_ioctls
);
...
...
drivers/char/drm/i915_drm.h
View file @
cf41f8ac
...
...
@@ -74,6 +74,30 @@ typedef struct _drm_i915_sarea {
int
pf_active
;
int
pf_current_page
;
/* which buffer is being displayed? */
int
perf_boxes
;
/* performance boxes to be displayed */
int
width
,
height
;
/* screen size in pixels */
drm_handle_t
front_handle
;
int
front_offset
;
int
front_size
;
drm_handle_t
back_handle
;
int
back_offset
;
int
back_size
;
drm_handle_t
depth_handle
;
int
depth_offset
;
int
depth_size
;
drm_handle_t
tex_handle
;
int
tex_offset
;
int
tex_size
;
int
log_tex_granularity
;
int
pitch
;
int
rotation
;
/* 0, 90, 180 or 270 */
int
rotated_offset
;
int
rotated_size
;
int
rotated_pitch
;
int
virtualX
,
virtualY
;
}
drm_i915_sarea_t
;
/* Flags for perf_boxes
...
...
@@ -99,6 +123,7 @@ typedef struct _drm_i915_sarea {
#define DRM_I915_FREE 0x09
#define DRM_I915_INIT_HEAP 0x0a
#define DRM_I915_CMDBUFFER 0x0b
#define DRM_I915_DESTROY_HEAP 0x0c
#define DRM_IOCTL_I915_INIT DRM_IOW( DRM_COMMAND_BASE + DRM_I915_INIT, drm_i915_init_t)
#define DRM_IOCTL_I915_FLUSH DRM_IO ( DRM_COMMAND_BASE + DRM_I915_FLUSH)
...
...
@@ -112,6 +137,7 @@ typedef struct _drm_i915_sarea {
#define DRM_IOCTL_I915_FREE DRM_IOW( DRM_COMMAND_BASE + DRM_I915_FREE, drm_i915_mem_free_t)
#define DRM_IOCTL_I915_INIT_HEAP DRM_IOW( DRM_COMMAND_BASE + DRM_I915_INIT_HEAP, drm_i915_mem_init_heap_t)
#define DRM_IOCTL_I915_CMDBUFFER DRM_IOW( DRM_COMMAND_BASE + DRM_I915_CMDBUFFER, drm_i915_cmdbuffer_t)
#define DRM_IOCTL_I915_DESTROY_HEAP DRM_IOW( DRM_COMMAND_BASE + DRM_I915_DESTROY_HEAP, drm_i915_mem_destroy_heap_t)
/* Allow drivers to submit batchbuffers directly to hardware, relying
* on the security mechanisms provided by hardware.
...
...
@@ -191,4 +217,11 @@ typedef struct drm_i915_mem_init_heap {
int
start
;
}
drm_i915_mem_init_heap_t
;
/* Allow memory manager to be torn down and re-initialized (eg on
* rotate):
*/
typedef
struct
drm_i915_mem_destroy_heap
{
int
region
;
}
drm_i915_mem_destroy_heap_t
;
#endif
/* _I915_DRM_H_ */
drivers/char/drm/i915_drv.h
View file @
cf41f8ac
...
...
@@ -37,16 +37,17 @@
#define DRIVER_NAME "i915"
#define DRIVER_DESC "Intel Graphics"
#define DRIVER_DATE "200
5120
9"
#define DRIVER_DATE "200
6011
9"
/* Interface history:
*
* 1.1: Original.
* 1.2: Add Power Management
* 1.3: Add vblank support
* 1.4: Fix cmdbuffer path, add heap destroy
*/
#define DRIVER_MAJOR 1
#define DRIVER_MINOR
3
#define DRIVER_MINOR
4
#define DRIVER_PATCHLEVEL 0
typedef
struct
_drm_i915_ring_buffer
{
...
...
@@ -123,6 +124,7 @@ extern void i915_driver_irq_uninstall(drm_device_t * dev);
extern
int
i915_mem_alloc
(
DRM_IOCTL_ARGS
);
extern
int
i915_mem_free
(
DRM_IOCTL_ARGS
);
extern
int
i915_mem_init_heap
(
DRM_IOCTL_ARGS
);
extern
int
i915_mem_destroy_heap
(
DRM_IOCTL_ARGS
);
extern
void
i915_mem_takedown
(
struct
mem_block
**
heap
);
extern
void
i915_mem_release
(
drm_device_t
*
dev
,
DRMFILE
filp
,
struct
mem_block
*
heap
);
...
...
drivers/char/drm/i915_mem.c
View file @
cf41f8ac
...
...
@@ -365,3 +365,34 @@ int i915_mem_init_heap(DRM_IOCTL_ARGS)
return
init_heap
(
heap
,
initheap
.
start
,
initheap
.
size
);
}
int
i915_mem_destroy_heap
(
DRM_IOCTL_ARGS
)
{
DRM_DEVICE
;
drm_i915_private_t
*
dev_priv
=
dev
->
dev_private
;
drm_i915_mem_destroy_heap_t
destroyheap
;
struct
mem_block
**
heap
;
if
(
!
dev_priv
)
{
DRM_ERROR
(
"%s called with no initialization
\n
"
,
__FUNCTION__
);
return
DRM_ERR
(
EINVAL
);
}
DRM_COPY_FROM_USER_IOCTL
(
destroyheap
,
(
drm_i915_mem_destroy_heap_t
*
)
data
,
sizeof
(
destroyheap
)
);
heap
=
get_heap
(
dev_priv
,
destroyheap
.
region
);
if
(
!
heap
)
{
DRM_ERROR
(
"get_heap failed"
);
return
DRM_ERR
(
EFAULT
);
}
if
(
!*
heap
)
{
DRM_ERROR
(
"heap not initialized?"
);
return
DRM_ERR
(
EFAULT
);
}
i915_mem_takedown
(
heap
);
return
0
;
}
drivers/char/drm/radeon_cp.c
View file @
cf41f8ac
...
...
@@ -1640,7 +1640,7 @@ static int radeon_do_cleanup_cp(drm_device_t * dev)
if
(
dev_priv
->
gart_info
.
gart_table_location
==
DRM_ATI_GART_FB
)
{
drm_core_ioremapfree
(
&
dev_priv
->
gart_info
.
mapping
,
dev
);
dev_priv
->
gart_info
.
addr
=
0
;
dev_priv
->
gart_info
.
addr
=
NULL
;
}
}
/* only clear to the start of flags */
...
...
drivers/char/drm/savage_bci.c
View file @
cf41f8ac
...
...
@@ -32,6 +32,8 @@
#define SAVAGE_EVENT_USEC_TIMEOUT 5000000
/* 5s */
#define SAVAGE_FREELIST_DEBUG 0
static
int
savage_do_cleanup_bci
(
drm_device_t
*
dev
);
static
int
savage_bci_wait_fifo_shadow
(
drm_savage_private_t
*
dev_priv
,
unsigned
int
n
)
{
...
...
@@ -895,7 +897,7 @@ static int savage_do_init_bci(drm_device_t * dev, drm_savage_init_t * init)
return
0
;
}
int
savage_do_cleanup_bci
(
drm_device_t
*
dev
)
static
int
savage_do_cleanup_bci
(
drm_device_t
*
dev
)
{
drm_savage_private_t
*
dev_priv
=
dev
->
dev_private
;
...
...
drivers/char/drm/savage_drv.h
View file @
cf41f8ac
...
...
@@ -212,7 +212,6 @@ extern int savage_driver_load(drm_device_t *dev, unsigned long chipset);
extern
int
savage_driver_firstopen
(
drm_device_t
*
dev
);
extern
void
savage_driver_lastclose
(
drm_device_t
*
dev
);
extern
int
savage_driver_unload
(
drm_device_t
*
dev
);
extern
int
savage_do_cleanup_bci
(
drm_device_t
*
dev
);
extern
void
savage_reclaim_buffers
(
drm_device_t
*
dev
,
DRMFILE
filp
);
/* state functions */
...
...
drivers/char/drm/via_dma.c
View file @
cf41f8ac
...
...
@@ -222,7 +222,7 @@ static int via_initialize(drm_device_t * dev,
return
0
;
}
int
via_dma_init
(
DRM_IOCTL_ARGS
)
static
int
via_dma_init
(
DRM_IOCTL_ARGS
)
{
DRM_DEVICE
;
drm_via_private_t
*
dev_priv
=
(
drm_via_private_t
*
)
dev
->
dev_private
;
...
...
@@ -321,7 +321,7 @@ int via_driver_dma_quiescent(drm_device_t * dev)
return
0
;
}
int
via_flush_ioctl
(
DRM_IOCTL_ARGS
)
static
int
via_flush_ioctl
(
DRM_IOCTL_ARGS
)
{
DRM_DEVICE
;
...
...
@@ -330,7 +330,7 @@ int via_flush_ioctl(DRM_IOCTL_ARGS)
return
via_driver_dma_quiescent
(
dev
);
}
int
via_cmdbuffer
(
DRM_IOCTL_ARGS
)
static
int
via_cmdbuffer
(
DRM_IOCTL_ARGS
)
{
DRM_DEVICE
;
drm_via_cmdbuffer_t
cmdbuf
;
...
...
@@ -375,7 +375,7 @@ static int via_dispatch_pci_cmdbuffer(drm_device_t * dev,
return
ret
;
}
int
via_pci_cmdbuffer
(
DRM_IOCTL_ARGS
)
static
int
via_pci_cmdbuffer
(
DRM_IOCTL_ARGS
)
{
DRM_DEVICE
;
drm_via_cmdbuffer_t
cmdbuf
;
...
...
@@ -665,7 +665,7 @@ static void via_cmdbuf_reset(drm_via_private_t * dev_priv)
* User interface to the space and lag functions.
*/
int
via_cmdbuf_size
(
DRM_IOCTL_ARGS
)
static
int
via_cmdbuf_size
(
DRM_IOCTL_ARGS
)
{
DRM_DEVICE
;
drm_via_cmdbuf_size_t
d_siz
;
...
...
drivers/char/drm/via_dmablit.c
View file @
cf41f8ac
...
...
@@ -108,7 +108,7 @@ via_map_blit_for_device(struct pci_dev *pdev,
int
num_desc
=
0
;
int
cur_line
;
dma_addr_t
next
=
0
|
VIA_DMA_DPR_EC
;
drm_via_descriptor_t
*
desc_ptr
=
0
;
drm_via_descriptor_t
*
desc_ptr
=
NULL
;
if
(
mode
==
1
)
desc_ptr
=
vsg
->
desc_pages
[
cur_descriptor_page
];
...
...
@@ -167,7 +167,7 @@ via_map_blit_for_device(struct pci_dev *pdev,
*/
void
static
void
via_free_sg_info
(
struct
pci_dev
*
pdev
,
drm_via_sg_info_t
*
vsg
)
{
struct
page
*
page
;
...
...
@@ -581,7 +581,7 @@ via_build_sg_info(drm_device_t *dev, drm_via_sg_info_t *vsg, drm_via_dmablit_t *
int
ret
=
0
;
vsg
->
direction
=
(
draw
)
?
DMA_TO_DEVICE
:
DMA_FROM_DEVICE
;
vsg
->
bounce_buffer
=
0
;
vsg
->
bounce_buffer
=
NULL
;
vsg
->
state
=
dr_via_sg_init
;
...
...
drivers/char/drm/via_drv.h
View file @
cf41f8ac
...
...
@@ -110,11 +110,6 @@ extern int via_mem_free(DRM_IOCTL_ARGS);
extern
int
via_agp_init
(
DRM_IOCTL_ARGS
);
extern
int
via_map_init
(
DRM_IOCTL_ARGS
);
extern
int
via_decoder_futex
(
DRM_IOCTL_ARGS
);
extern
int
via_dma_init
(
DRM_IOCTL_ARGS
);
extern
int
via_cmdbuffer
(
DRM_IOCTL_ARGS
);
extern
int
via_flush_ioctl
(
DRM_IOCTL_ARGS
);
extern
int
via_pci_cmdbuffer
(
DRM_IOCTL_ARGS
);
extern
int
via_cmdbuf_size
(
DRM_IOCTL_ARGS
);
extern
int
via_wait_irq
(
DRM_IOCTL_ARGS
);
extern
int
via_dma_blit_sync
(
DRM_IOCTL_ARGS
);
extern
int
via_dma_blit
(
DRM_IOCTL_ARGS
);
...
...
@@ -139,8 +134,6 @@ extern int via_driver_dma_quiescent(drm_device_t * dev);
extern
void
via_init_futex
(
drm_via_private_t
*
dev_priv
);
extern
void
via_cleanup_futex
(
drm_via_private_t
*
dev_priv
);
extern
void
via_release_futex
(
drm_via_private_t
*
dev_priv
,
int
context
);
extern
int
via_driver_irq_wait
(
drm_device_t
*
dev
,
unsigned
int
irq
,
int
force_sequence
,
unsigned
int
*
sequence
);
extern
void
via_dmablit_handler
(
drm_device_t
*
dev
,
int
engine
,
int
from_irq
);
extern
void
via_init_dmablit
(
drm_device_t
*
dev
);
...
...
drivers/char/drm/via_irq.c
View file @
cf41f8ac
...
...
@@ -190,7 +190,7 @@ int via_driver_vblank_wait(drm_device_t * dev, unsigned int *sequence)
return
ret
;
}
int
static
int
via_driver_irq_wait
(
drm_device_t
*
dev
,
unsigned
int
irq
,
int
force_sequence
,
unsigned
int
*
sequence
)
{
...
...
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