taglinefilesource code
order168include/linux/mm.hextern void free_pages(unsigned long addr, unsigned long order);
order73mm/kmalloc.cint order;
order121mm/kmalloc.c#define NBLOCKS(order)          (sizes[order].nblocks)
order122mm/kmalloc.c#define BLOCKSIZE(order)        (sizes[order].size)
order123mm/kmalloc.c#define AREASIZE(order)    (PAGE_SIZE<<(sizes[order].gfporder))
order128mm/kmalloc.cint order;
order134mm/kmalloc.cfor (order = 0;BLOCKSIZE(order);order++)
order136mm/kmalloc.cif ((NBLOCKS (order)*BLOCKSIZE(order) + sizeof (struct page_descriptor)) >
order137mm/kmalloc.cAREASIZE(order)) 
order140mm/kmalloc.c(int) (NBLOCKS (order) * BLOCKSIZE(order) + 
order142mm/kmalloc.c(int) AREASIZE(order),
order143mm/kmalloc.cBLOCKSIZE (order));
order154mm/kmalloc.cint order;
order158mm/kmalloc.cfor (order = 0;BLOCKSIZE(order);order++)
order159mm/kmalloc.cif (size <= BLOCKSIZE (order))
order160mm/kmalloc.creturn order; 
order167mm/kmalloc.cint order,tries,i,sz;
order185mm/kmalloc.corder = get_order (size);
order186mm/kmalloc.cif (order < 0)
order201mm/kmalloc.cif ((page = (dma_flag ? sizes[order].dmafree : sizes[order].firstfree)) &&
order211mm/kmalloc.csizes[order].dmafree = page->next;
order213mm/kmalloc.csizes[order].firstfree = page->next;
order218mm/kmalloc.csizes [order].nmallocs++;
order219mm/kmalloc.csizes [order].nbytesmalloced += size;
order232mm/kmalloc.csz = BLOCKSIZE(order); /* sz is the size of the blocks we're dealing with */
order236mm/kmalloc.cpage = (struct page_descriptor *) __get_dma_pages (priority & GFP_LEVEL_MASK, sizes[order].gfporder);
order238mm/kmalloc.cpage = (struct page_descriptor *) __get_free_pages (priority & GFP_LEVEL_MASK, sizes[order].gfporder);
order251mm/kmalloc.csizes[order].npages++;
order254mm/kmalloc.cfor (i=NBLOCKS(order),p=BH (page+1);i > 1;i--,p=p->bh_next) 
order263mm/kmalloc.cpage->order = order;
order264mm/kmalloc.cpage->nfree = NBLOCKS(order); 
order277mm/kmalloc.cpage->next = sizes[order].dmafree;
order278mm/kmalloc.csizes[order].dmafree = page;
order280mm/kmalloc.cpage->next = sizes[order].firstfree;
order281mm/kmalloc.csizes[order].firstfree = page;
order303mm/kmalloc.cint order;
order308mm/kmalloc.corder = page->order;
order309mm/kmalloc.cif ((order < 0) || 
order310mm/kmalloc.c(order > sizeof (sizes)/sizeof (sizes[0])) ||
order315mm/kmalloc.cp, page->next, page->order);
order342mm/kmalloc.cpage->next = sizes[order].firstfree;
order343mm/kmalloc.csizes[order].firstfree = page;
order348mm/kmalloc.cif (page->nfree == NBLOCKS (page->order))
order353mm/kmalloc.cif (sizes[order].firstfree == page)
order355mm/kmalloc.csizes[order].firstfree = page->next;
order357mm/kmalloc.celse if (sizes[order].dmafree == page)
order359mm/kmalloc.csizes[order].dmafree = page->next;
order363mm/kmalloc.cfor (pg2=sizes[order].firstfree;
order368mm/kmalloc.cfor (pg2=sizes[order].dmafree;
order378mm/kmalloc.cfree_pages ((long)page, sizes[order].gfporder);
order386mm/kmalloc.csizes[order].nfrees++;      /* Noncritical (monitoring) admin stuff */
order387mm/kmalloc.csizes[order].nbytesmalloced -= size;
order640mm/swap.cstatic inline void free_pages_ok(unsigned long addr, unsigned long order)
order642mm/swap.cunsigned long index = MAP_NR(addr) >> (1 + order);
order643mm/swap.cunsigned long mask = PAGE_MASK << order;
order646mm/swap.cnr_free_pages += 1 << order;
order647mm/swap.cwhile (order < NR_MEM_LISTS-1) {
order648mm/swap.cif (!change_bit(index, free_area_map[order]))
order650mm/swap.cremove_mem_queue(free_area_list+order, (struct mem_list *) (addr ^ (1+~mask)));
order651mm/swap.corder++;
order656mm/swap.cadd_mem_queue(free_area_list+order, (struct mem_list *) addr);
order674mm/swap.cvoid free_pages(unsigned long addr, unsigned long order)
order684mm/swap.cfree_pages_ok(addr, order);
order702mm/swap.c#define RMQUEUE(order) \
order703mm/swap.cdo { struct mem_list * queue = free_area_list+order; \
order704mm/swap.cunsigned long new_order = order; \
order709mm/swap.cnr_free_pages -= 1 << order; \
order711mm/swap.cEXPAND(next, order, new_order); \
order717mm/swap.cstatic inline int mark_used(unsigned long addr, unsigned long order)
order719mm/swap.creturn change_bit(MAP_NR(addr) >> (1+order), free_area_map[order]);
order733mm/swap.cunsigned long __get_free_pages(int priority, unsigned long order)
order753mm/swap.cRMQUEUE(order);
order766mm/swap.cunsigned long __get_dma_pages(int priority, unsigned long order)
order776mm/swap.cresult = __get_free_pages(priority, order);
order785mm/swap.cfree_pages(tmp, order);
order797mm/swap.cunsigned long order, flags;
order803mm/swap.cfor (order=0 ; order < NR_MEM_LISTS; order++) {
order806mm/swap.cfor (tmp = free_area_list[order].next ; tmp != free_area_list + order ; tmp = tmp->next) {
order809mm/swap.ctotal += nr * ((PAGE_SIZE>>10) << order);
order810mm/swap.cprintk("%lu*%lukB ", nr, (PAGE_SIZE>>10) << order);