| /* mmu.c: mmu memory info files |
| * |
| * Copyright (C) 2004 Red Hat, Inc. All Rights Reserved. |
| * Written by David Howells (dhowells@redhat.com) |
| * |
| * This program is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU General Public License |
| * as published by the Free Software Foundation; either version |
| * 2 of the License, or (at your option) any later version. |
| */ |
| |
| #include <linux/types.h> |
| #include <linux/errno.h> |
| #include <linux/time.h> |
| #include <linux/kernel.h> |
| #include <linux/string.h> |
| #include <linux/mman.h> |
| #include <linux/proc_fs.h> |
| #include <linux/mm.h> |
| #include <linux/mmzone.h> |
| #include <linux/pagemap.h> |
| #include <linux/swap.h> |
| #include <linux/slab.h> |
| #include <linux/smp.h> |
| #include <linux/seq_file.h> |
| #include <linux/hugetlb.h> |
| #include <linux/vmalloc.h> |
| #include <asm/uaccess.h> |
| #include <asm/pgtable.h> |
| #include <asm/tlb.h> |
| #include <asm/div64.h> |
| #include "internal.h" |
| |
| void get_vmalloc_info(struct vmalloc_info *vmi) |
| { |
| struct vm_struct *vma; |
| unsigned long free_area_size; |
| unsigned long prev_end; |
| |
| vmi->used = 0; |
| |
| if (!vmlist) { |
| vmi->largest_chunk = VMALLOC_TOTAL; |
| } |
| else { |
| vmi->largest_chunk = 0; |
| |
| prev_end = VMALLOC_START; |
| |
| read_lock(&vmlist_lock); |
| |
| for (vma = vmlist; vma; vma = vma->next) { |
| unsigned long addr = (unsigned long) vma->addr; |
| |
| /* |
| * Some archs keep another range for modules in vmlist |
| */ |
| if (addr < VMALLOC_START) |
| continue; |
| if (addr >= VMALLOC_END) |
| break; |
| |
| vmi->used += vma->size; |
| |
| free_area_size = addr - prev_end; |
| if (vmi->largest_chunk < free_area_size) |
| vmi->largest_chunk = free_area_size; |
| |
| prev_end = vma->size + addr; |
| } |
| |
| if (VMALLOC_END - prev_end > vmi->largest_chunk) |
| vmi->largest_chunk = VMALLOC_END - prev_end; |
| |
| read_unlock(&vmlist_lock); |
| } |
| } |