Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 143509
b: refs/heads/master
c: 9fa3ab3
h: refs/heads/master
i:
  143507: eccd842
v: v3
  • Loading branch information
venkatesh.pallipadi@intel.com authored and Ingo Molnar committed Apr 10, 2009
1 parent 5425a1a commit eb8ecfb
Show file tree
Hide file tree
Showing 2 changed files with 66 additions and 49 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: a5593e0b329a14dea41ea173380dbf1533de2bd2
refs/heads/master: 9fa3ab390abfc8b49fc0dd7c845b0ad224ec429f
113 changes: 65 additions & 48 deletions trunk/arch/x86/mm/pageattr.c
Original file line number Diff line number Diff line change
Expand Up @@ -945,52 +945,56 @@ int _set_memory_uc(unsigned long addr, int numpages)

int set_memory_uc(unsigned long addr, int numpages)
{
int ret;

/*
* for now UC MINUS. see comments in ioremap_nocache()
*/
if (reserve_memtype(__pa(addr), __pa(addr) + numpages * PAGE_SIZE,
_PAGE_CACHE_UC_MINUS, NULL))
return -EINVAL;
ret = reserve_memtype(__pa(addr), __pa(addr) + numpages * PAGE_SIZE,
_PAGE_CACHE_UC_MINUS, NULL);
if (ret)
goto out_err;

ret = _set_memory_uc(addr, numpages);
if (ret)
goto out_free;

return 0;

return _set_memory_uc(addr, numpages);
out_free:
free_memtype(__pa(addr), __pa(addr) + numpages * PAGE_SIZE);
out_err:
return ret;
}
EXPORT_SYMBOL(set_memory_uc);

int set_memory_array_uc(unsigned long *addr, int addrinarray)
{
unsigned long start;
unsigned long end;
int i;
int i, j;
int ret;

/*
* for now UC MINUS. see comments in ioremap_nocache()
*/
for (i = 0; i < addrinarray; i++) {
start = __pa(addr[i]);
for (end = start + PAGE_SIZE; i < addrinarray - 1; end += PAGE_SIZE) {
if (end != __pa(addr[i + 1]))
break;
i++;
}
if (reserve_memtype(start, end, _PAGE_CACHE_UC_MINUS, NULL))
goto out;
ret = reserve_memtype(__pa(addr[i]), __pa(addr[i]) + PAGE_SIZE,
_PAGE_CACHE_UC_MINUS, NULL);
if (ret)
goto out_free;
}

return change_page_attr_set(addr, addrinarray,
ret = change_page_attr_set(addr, addrinarray,
__pgprot(_PAGE_CACHE_UC_MINUS), 1);
out:
for (i = 0; i < addrinarray; i++) {
unsigned long tmp = __pa(addr[i]);

if (tmp == start)
break;
for (end = tmp + PAGE_SIZE; i < addrinarray - 1; end += PAGE_SIZE) {
if (end != __pa(addr[i + 1]))
break;
i++;
}
free_memtype(tmp, end);
}
return -EINVAL;
if (ret)
goto out_free;

return 0;

out_free:
for (j = 0; j < i; j++)
free_memtype(__pa(addr[j]), __pa(addr[j]) + PAGE_SIZE);

return ret;
}
EXPORT_SYMBOL(set_memory_array_uc);

Expand All @@ -1002,14 +1006,26 @@ int _set_memory_wc(unsigned long addr, int numpages)

int set_memory_wc(unsigned long addr, int numpages)
{
int ret;

if (!pat_enabled)
return set_memory_uc(addr, numpages);

if (reserve_memtype(__pa(addr), __pa(addr) + numpages * PAGE_SIZE,
_PAGE_CACHE_WC, NULL))
return -EINVAL;
ret = reserve_memtype(__pa(addr), __pa(addr) + numpages * PAGE_SIZE,
_PAGE_CACHE_WC, NULL);
if (ret)
goto out_err;

return _set_memory_wc(addr, numpages);
ret = _set_memory_wc(addr, numpages);
if (ret)
goto out_free;

return 0;

out_free:
free_memtype(__pa(addr), __pa(addr) + numpages * PAGE_SIZE);
out_err:
return ret;
}
EXPORT_SYMBOL(set_memory_wc);

Expand All @@ -1021,9 +1037,14 @@ int _set_memory_wb(unsigned long addr, int numpages)

int set_memory_wb(unsigned long addr, int numpages)
{
int ret = _set_memory_wb(addr, numpages);
int ret;

ret = _set_memory_wb(addr, numpages);
if (ret)
return ret;

free_memtype(__pa(addr), __pa(addr) + numpages * PAGE_SIZE);
return ret;
return 0;
}
EXPORT_SYMBOL(set_memory_wb);

Expand All @@ -1034,19 +1055,13 @@ int set_memory_array_wb(unsigned long *addr, int addrinarray)

ret = change_page_attr_clear(addr, addrinarray,
__pgprot(_PAGE_CACHE_MASK), 1);
if (ret)
return ret;

for (i = 0; i < addrinarray; i++) {
unsigned long start = __pa(addr[i]);
unsigned long end;
for (i = 0; i < addrinarray; i++)
free_memtype(__pa(addr[i]), __pa(addr[i]) + PAGE_SIZE);

for (end = start + PAGE_SIZE; i < addrinarray - 1; end += PAGE_SIZE) {
if (end != __pa(addr[i + 1]))
break;
i++;
}
free_memtype(start, end);
}
return ret;
return 0;
}
EXPORT_SYMBOL(set_memory_array_wb);

Expand Down Expand Up @@ -1139,14 +1154,16 @@ int set_pages_array_wb(struct page **pages, int addrinarray)

retval = cpa_clear_pages_array(pages, addrinarray,
__pgprot(_PAGE_CACHE_MASK));
if (retval)
return retval;

for (i = 0; i < addrinarray; i++) {
start = (unsigned long)page_address(pages[i]);
end = start + PAGE_SIZE;
free_memtype(start, end);
}

return retval;
return 0;
}
EXPORT_SYMBOL(set_pages_array_wb);

Expand Down

0 comments on commit eb8ecfb

Please sign in to comment.