mirror of
https://github.com/torvalds/linux.git
synced 2026-03-08 03:24:45 +01:00
mm/zsmalloc: convert obj_malloc() to use zpdesc
Use get_first_zpdesc/get_next_zpdesc to replace get_first_page/get_next_page. no functional change. Link: https://lkml.kernel.org/r/20241216150450.1228021-6-42.hyeyoo@gmail.com Signed-off-by: Hyeonggon Yoo <42.hyeyoo@gmail.com> Signed-off-by: Alex Shi <alexs@kernel.org> Acked-by: Sergey Senozhatsky <senozhatsky@chromium.org> Tested-by: Sergey Senozhatsky <senozhatsky@chromium.org> Cc: Matthew Wilcox (Oracle) <willy@infradead.org> Cc: Minchan Kim <minchan@kernel.org> Cc: Vishal Moola (Oracle) <vishal.moola@gmail.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
parent
b5c1d8b510
commit
8f1868ad0c
1 changed files with 8 additions and 8 deletions
|
|
@ -1295,12 +1295,12 @@ EXPORT_SYMBOL_GPL(zs_huge_class_size);
|
|||
static unsigned long obj_malloc(struct zs_pool *pool,
|
||||
struct zspage *zspage, unsigned long handle)
|
||||
{
|
||||
int i, nr_page, offset;
|
||||
int i, nr_zpdesc, offset;
|
||||
unsigned long obj;
|
||||
struct link_free *link;
|
||||
struct size_class *class;
|
||||
|
||||
struct page *m_page;
|
||||
struct zpdesc *m_zpdesc;
|
||||
unsigned long m_offset;
|
||||
void *vaddr;
|
||||
|
||||
|
|
@ -1308,14 +1308,14 @@ static unsigned long obj_malloc(struct zs_pool *pool,
|
|||
obj = get_freeobj(zspage);
|
||||
|
||||
offset = obj * class->size;
|
||||
nr_page = offset >> PAGE_SHIFT;
|
||||
nr_zpdesc = offset >> PAGE_SHIFT;
|
||||
m_offset = offset_in_page(offset);
|
||||
m_page = get_first_page(zspage);
|
||||
m_zpdesc = get_first_zpdesc(zspage);
|
||||
|
||||
for (i = 0; i < nr_page; i++)
|
||||
m_page = get_next_page(m_page);
|
||||
for (i = 0; i < nr_zpdesc; i++)
|
||||
m_zpdesc = get_next_zpdesc(m_zpdesc);
|
||||
|
||||
vaddr = kmap_local_page(m_page);
|
||||
vaddr = kmap_local_zpdesc(m_zpdesc);
|
||||
link = (struct link_free *)vaddr + m_offset / sizeof(*link);
|
||||
set_freeobj(zspage, link->next >> OBJ_TAG_BITS);
|
||||
if (likely(!ZsHugePage(zspage)))
|
||||
|
|
@ -1327,7 +1327,7 @@ static unsigned long obj_malloc(struct zs_pool *pool,
|
|||
kunmap_local(vaddr);
|
||||
mod_zspage_inuse(zspage, 1);
|
||||
|
||||
obj = location_to_obj(m_page, obj);
|
||||
obj = location_to_obj(zpdesc_page(m_zpdesc), obj);
|
||||
record_obj(handle, obj);
|
||||
|
||||
return obj;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue