diff options
Diffstat (limited to 'drivers/char/drm/drm_memory.c')
-rw-r--r-- | drivers/char/drm/drm_memory.c | 54 |
1 files changed, 28 insertions, 26 deletions
diff --git a/drivers/char/drm/drm_memory.c b/drivers/char/drm/drm_memory.c index ff483fb418aa..2c74155aa84f 100644 --- a/drivers/char/drm/drm_memory.c +++ b/drivers/char/drm/drm_memory.c | |||
@@ -1,12 +1,12 @@ | |||
1 | /** | 1 | /** |
2 | * \file drm_memory.h | 2 | * \file drm_memory.c |
3 | * Memory management wrappers for DRM | 3 | * Memory management wrappers for DRM |
4 | * | 4 | * |
5 | * \author Rickard E. (Rik) Faith <faith@valinux.com> | 5 | * \author Rickard E. (Rik) Faith <faith@valinux.com> |
6 | * \author Gareth Hughes <gareth@valinux.com> | 6 | * \author Gareth Hughes <gareth@valinux.com> |
7 | */ | 7 | */ |
8 | 8 | ||
9 | /* | 9 | /* |
10 | * Created: Thu Feb 4 14:00:34 1999 by faith@valinux.com | 10 | * Created: Thu Feb 4 14:00:34 1999 by faith@valinux.com |
11 | * | 11 | * |
12 | * Copyright 1999 Precision Insight, Inc., Cedar Park, Texas. | 12 | * Copyright 1999 Precision Insight, Inc., Cedar Park, Texas. |
@@ -48,7 +48,7 @@ void drm_mem_init(void) | |||
48 | 48 | ||
49 | /** | 49 | /** |
50 | * Called when "/proc/dri/%dev%/mem" is read. | 50 | * Called when "/proc/dri/%dev%/mem" is read. |
51 | * | 51 | * |
52 | * \param buf output buffer. | 52 | * \param buf output buffer. |
53 | * \param start start of output data. | 53 | * \param start start of output data. |
54 | * \param offset requested start offset. | 54 | * \param offset requested start offset. |
@@ -57,10 +57,10 @@ void drm_mem_init(void) | |||
57 | * \param data private data. | 57 | * \param data private data. |
58 | * \return number of written bytes. | 58 | * \return number of written bytes. |
59 | * | 59 | * |
60 | * No-op. | 60 | * No-op. |
61 | */ | 61 | */ |
62 | int drm_mem_info(char *buf, char **start, off_t offset, | 62 | int drm_mem_info(char *buf, char **start, off_t offset, |
63 | int len, int *eof, void *data) | 63 | int len, int *eof, void *data) |
64 | { | 64 | { |
65 | return 0; | 65 | return 0; |
66 | } | 66 | } |
@@ -70,7 +70,8 @@ void *drm_realloc(void *oldpt, size_t oldsize, size_t size, int area) | |||
70 | { | 70 | { |
71 | void *pt; | 71 | void *pt; |
72 | 72 | ||
73 | if (!(pt = kmalloc(size, GFP_KERNEL))) return NULL; | 73 | if (!(pt = kmalloc(size, GFP_KERNEL))) |
74 | return NULL; | ||
74 | if (oldpt && oldsize) { | 75 | if (oldpt && oldsize) { |
75 | memcpy(pt, oldpt, oldsize); | 76 | memcpy(pt, oldpt, oldsize); |
76 | kfree(oldpt); | 77 | kfree(oldpt); |
@@ -90,21 +91,20 @@ void *drm_realloc(void *oldpt, size_t oldsize, size_t size, int area) | |||
90 | unsigned long drm_alloc_pages(int order, int area) | 91 | unsigned long drm_alloc_pages(int order, int area) |
91 | { | 92 | { |
92 | unsigned long address; | 93 | unsigned long address; |
93 | unsigned long bytes = PAGE_SIZE << order; | 94 | unsigned long bytes = PAGE_SIZE << order; |
94 | unsigned long addr; | 95 | unsigned long addr; |
95 | unsigned int sz; | 96 | unsigned int sz; |
96 | 97 | ||
97 | address = __get_free_pages(GFP_KERNEL, order); | 98 | address = __get_free_pages(GFP_KERNEL, order); |
98 | if (!address) | 99 | if (!address) |
99 | return 0; | 100 | return 0; |
100 | 101 | ||
101 | /* Zero */ | 102 | /* Zero */ |
102 | memset((void *)address, 0, bytes); | 103 | memset((void *)address, 0, bytes); |
103 | 104 | ||
104 | /* Reserve */ | 105 | /* Reserve */ |
105 | for (addr = address, sz = bytes; | 106 | for (addr = address, sz = bytes; |
106 | sz > 0; | 107 | sz > 0; addr += PAGE_SIZE, sz -= PAGE_SIZE) { |
107 | addr += PAGE_SIZE, sz -= PAGE_SIZE) { | ||
108 | SetPageReserved(virt_to_page(addr)); | 108 | SetPageReserved(virt_to_page(addr)); |
109 | } | 109 | } |
110 | 110 | ||
@@ -113,7 +113,7 @@ unsigned long drm_alloc_pages(int order, int area) | |||
113 | 113 | ||
114 | /** | 114 | /** |
115 | * Free pages. | 115 | * Free pages. |
116 | * | 116 | * |
117 | * \param address address of the pages to free. | 117 | * \param address address of the pages to free. |
118 | * \param order size order. | 118 | * \param order size order. |
119 | * \param area memory area. (Not used.) | 119 | * \param area memory area. (Not used.) |
@@ -124,49 +124,51 @@ void drm_free_pages(unsigned long address, int order, int area) | |||
124 | { | 124 | { |
125 | unsigned long bytes = PAGE_SIZE << order; | 125 | unsigned long bytes = PAGE_SIZE << order; |
126 | unsigned long addr; | 126 | unsigned long addr; |
127 | unsigned int sz; | 127 | unsigned int sz; |
128 | 128 | ||
129 | if (!address) | 129 | if (!address) |
130 | return; | 130 | return; |
131 | 131 | ||
132 | /* Unreserve */ | 132 | /* Unreserve */ |
133 | for (addr = address, sz = bytes; | 133 | for (addr = address, sz = bytes; |
134 | sz > 0; | 134 | sz > 0; addr += PAGE_SIZE, sz -= PAGE_SIZE) { |
135 | addr += PAGE_SIZE, sz -= PAGE_SIZE) { | ||
136 | ClearPageReserved(virt_to_page(addr)); | 135 | ClearPageReserved(virt_to_page(addr)); |
137 | } | 136 | } |
138 | 137 | ||
139 | free_pages(address, order); | 138 | free_pages(address, order); |
140 | } | 139 | } |
141 | 140 | ||
142 | |||
143 | #if __OS_HAS_AGP | 141 | #if __OS_HAS_AGP |
144 | /** Wrapper around agp_allocate_memory() */ | 142 | /** Wrapper around agp_allocate_memory() */ |
145 | DRM_AGP_MEM *drm_alloc_agp(drm_device_t *dev, int pages, u32 type) | 143 | DRM_AGP_MEM *drm_alloc_agp(drm_device_t * dev, int pages, u32 type) |
146 | { | 144 | { |
147 | return drm_agp_allocate_memory(dev->agp->bridge, pages, type); | 145 | return drm_agp_allocate_memory(dev->agp->bridge, pages, type); |
148 | } | 146 | } |
147 | |||
149 | EXPORT_SYMBOL(drm_alloc_agp); | 148 | EXPORT_SYMBOL(drm_alloc_agp); |
150 | 149 | ||
151 | /** Wrapper around agp_free_memory() */ | 150 | /** Wrapper around agp_free_memory() */ |
152 | int drm_free_agp(DRM_AGP_MEM *handle, int pages) | 151 | int drm_free_agp(DRM_AGP_MEM * handle, int pages) |
153 | { | 152 | { |
154 | return drm_agp_free_memory(handle) ? 0 : -EINVAL; | 153 | return drm_agp_free_memory(handle) ? 0 : -EINVAL; |
155 | } | 154 | } |
155 | |||
156 | EXPORT_SYMBOL(drm_free_agp); | 156 | EXPORT_SYMBOL(drm_free_agp); |
157 | 157 | ||
158 | /** Wrapper around agp_bind_memory() */ | 158 | /** Wrapper around agp_bind_memory() */ |
159 | int drm_bind_agp(DRM_AGP_MEM *handle, unsigned int start) | 159 | int drm_bind_agp(DRM_AGP_MEM * handle, unsigned int start) |
160 | { | 160 | { |
161 | return drm_agp_bind_memory(handle, start); | 161 | return drm_agp_bind_memory(handle, start); |
162 | } | 162 | } |
163 | |||
163 | EXPORT_SYMBOL(drm_bind_agp); | 164 | EXPORT_SYMBOL(drm_bind_agp); |
164 | 165 | ||
165 | /** Wrapper around agp_unbind_memory() */ | 166 | /** Wrapper around agp_unbind_memory() */ |
166 | int drm_unbind_agp(DRM_AGP_MEM *handle) | 167 | int drm_unbind_agp(DRM_AGP_MEM * handle) |
167 | { | 168 | { |
168 | return drm_agp_unbind_memory(handle); | 169 | return drm_agp_unbind_memory(handle); |
169 | } | 170 | } |
171 | |||
170 | EXPORT_SYMBOL(drm_unbind_agp); | 172 | EXPORT_SYMBOL(drm_unbind_agp); |
171 | #endif /* agp */ | 173 | #endif /* agp */ |
172 | #endif /* debug_memory */ | 174 | #endif /* debug_memory */ |