123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- #include <linux/gfp.h>
- #include <linux/mm_types.h>
- #include <linux/mm.h>
- #include <linux/slab.h>
- #include "slab.h"
- #include <linux/kmemcheck.h>
- void kmemcheck_alloc_shadow(struct page *page, int order, gfp_t flags, int node)
- {
- struct page *shadow;
- int pages;
- int i;
- pages = 1 << order;
-
- shadow = alloc_pages_node(node, flags | __GFP_NOTRACK, order);
- if (!shadow) {
- if (printk_ratelimit())
- pr_err("kmemcheck: failed to allocate shadow bitmap\n");
- return;
- }
- for(i = 0; i < pages; ++i)
- page[i].shadow = page_address(&shadow[i]);
-
- kmemcheck_hide_pages(page, pages);
- }
- void kmemcheck_free_shadow(struct page *page, int order)
- {
- struct page *shadow;
- int pages;
- int i;
- if (!kmemcheck_page_is_tracked(page))
- return;
- pages = 1 << order;
- kmemcheck_show_pages(page, pages);
- shadow = virt_to_page(page[0].shadow);
- for(i = 0; i < pages; ++i)
- page[i].shadow = NULL;
- __free_pages(shadow, order);
- }
- void kmemcheck_slab_alloc(struct kmem_cache *s, gfp_t gfpflags, void *object,
- size_t size)
- {
- if (unlikely(!object))
- return;
-
- if (gfpflags & __GFP_ZERO)
- return;
-
- if (s->flags & SLAB_NOTRACK)
- return;
- if (!kmemcheck_enabled || gfpflags & __GFP_NOTRACK) {
-
- kmemcheck_mark_initialized(object, size);
- } else if (!s->ctor) {
-
- kmemcheck_mark_uninitialized(object, size);
- }
- }
- void kmemcheck_slab_free(struct kmem_cache *s, void *object, size_t size)
- {
-
- if (!s->ctor && !(s->flags & SLAB_DESTROY_BY_RCU))
- kmemcheck_mark_freed(object, size);
- }
- void kmemcheck_pagealloc_alloc(struct page *page, unsigned int order,
- gfp_t gfpflags)
- {
- int pages;
- if (gfpflags & (__GFP_HIGHMEM | __GFP_NOTRACK))
- return;
- pages = 1 << order;
-
-
- kmemcheck_alloc_shadow(page, order, gfpflags, -1);
- if (gfpflags & __GFP_ZERO)
- kmemcheck_mark_initialized_pages(page, pages);
- else
- kmemcheck_mark_uninitialized_pages(page, pages);
- }
|