diff options
| author | Thomas Hellstrom <thomas-at-tungstengraphics-dot-com> | 2006-09-14 12:17:38 +0200 | 
|---|---|---|
| committer | Thomas Hellstrom <thomas-at-tungstengraphics-dot-com> | 2006-09-14 12:17:38 +0200 | 
| commit | 682c6ed0293771b093452597540118f47fda1adf (patch) | |
| tree | 71400326deeec5b87c4316b8bb904ddccf5f4c56 /linux-core/drm_compat.c | |
| parent | 9adc9584a7e0b61b16a943720bef31a71faeaef4 (diff) | |
Remove the use of reserved pages, and use locked pages instead.
Update compatibility for latest linux versions.
Diffstat (limited to 'linux-core/drm_compat.c')
| -rw-r--r-- | linux-core/drm_compat.c | 30 | 
1 files changed, 24 insertions, 6 deletions
| diff --git a/linux-core/drm_compat.c b/linux-core/drm_compat.c index 162e4656..d387678e 100644 --- a/linux-core/drm_compat.c +++ b/linux-core/drm_compat.c @@ -54,19 +54,37 @@ static inline void change_pte_range(struct mm_struct *mm, pmd_t * pmd,  				    unsigned long addr, unsigned long end)  {  	pte_t *pte; +	struct page *page; +	unsigned long pfn;  	pte = pte_offset_map(pmd, addr);  	do {  		if (pte_present(*pte)) {  			pte_t ptent; -			ptep_get_and_clear(mm, addr, pte); +			pfn = pte_pfn(*pte);  			ptent = *pte; -			lazy_mmu_prot_update(ptent); -		} else {  			ptep_get_and_clear(mm, addr, pte); -		} -		if (!pte_none(*pte)) { -		  DRM_ERROR("Ugh. Pte was presen\n"); +			if (pfn_valid(pfn)) { +				page = pfn_to_page(pfn); +				if (atomic_add_negative(-1, &page->_mapcount)) { +					if (page_test_and_clear_dirty(page)) +						set_page_dirty(page); +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,18) +					dec_zone_page_state(page, NR_FILE_MAPPED); +#else +					dec_page_state(nr_mapped); +#endif			 +				} + +				put_page(page); +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,15) +				dec_mm_counter(mm, file_rss); +#elif LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,12) +				dec_mm_counter(mm, rss); +#else +				--mm->rss; +#endif +			}  		}  	} while (pte++, addr += PAGE_SIZE, addr != end);  	pte_unmap(pte - 1); | 
