Changeset 4a5b2b0e in mainline for generic/src/mm/slab.c


Ignore:
Timestamp:
2006-02-02T22:38:13Z (19 years ago)
Author:
Ondrej Palkovsky <ondrap@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
086a600
Parents:
14e5d88
Message:

Partially working SLAB CPU cache.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • generic/src/mm/slab.c

    r14e5d88 r4a5b2b0e  
    9797        slab->available = cache->objects;
    9898        slab->nextavail = 0;
     99        slab->cache = cache;
    99100
    100101        for (i=0; i<cache->objects;i++)
     
    151152        if (!slab)
    152153                slab = obj2slab(obj);
     154
     155        ASSERT(slab->cache == cache);
    153156
    154157        *((int *)obj) = slab->nextavail;
     
    231234        count_t frames = 0;
    232235
    233         for (i=0;i < mag->busy; i++)
     236        for (i=0;i < mag->busy; i++) {
    234237                frames += slab_obj_destroy(cache, mag->objs[i], NULL);
     238                atomic_dec(&cache->cached_objs);
     239        }
    235240       
    236241        slab_free(&mag_cache, mag);
     
    247252{
    248253        slab_magazine_t *mag;
     254        void *obj;
    249255
    250256        spinlock_lock(&cache->mag_cache[CPU->id].lock);
     
    280286        }
    281287gotit:
     288        obj = mag->objs[--mag->busy];
    282289        spinlock_unlock(&cache->mag_cache[CPU->id].lock);
    283         return mag->objs[--mag->busy];
     290        atomic_dec(&cache->cached_objs);
     291       
     292        return obj;
    284293out:   
    285294        spinlock_unlock(&cache->mag_cache[CPU->id].lock);
     
    338347
    339348        spinlock_unlock(&cache->mag_cache[CPU->id].lock);
     349        atomic_inc(&cache->cached_objs);
    340350        return 0;
    341351errout:
     
    468478        if (flags & SLAB_RECLAIM_ALL) {
    469479                /* Aggressive memfree */
    470 
    471480                /* Destroy CPU magazines */
    472481                for (i=0; i<config.cpu_count; i++) {
     
    484493        /* Destroy full magazines */
    485494        cur=cache->magazines.prev;
     495
    486496        while (cur!=&cache->magazines) {
    487497                mag = list_get_instance(cur, slab_magazine_t, link);
     
    489499                cur = cur->prev;
    490500                list_remove(cur->next);
     501//              list_remove(&mag->link);
    491502                frames += magazine_destroy(cache,mag);
    492503                /* If we do not do full reclaim, break
     
    597608
    598609        spinlock_lock(&slab_cache_lock);
    599         printf("SLAB name\tOsize\tPages\tOcnt\tSlabs\tAllocobjs\tCtl\n");
     610        printf("SLAB name\tOsize\tPages\tObj/pg\tSlabs\tCached\tAllocobjs\tCtl\n");
    600611        for (cur = slab_cache_list.next;cur!=&slab_cache_list; cur=cur->next) {
    601612                cache = list_get_instance(cur, slab_cache_t, link);
    602                 printf("%s\t%d\t%d\t%d\t%d\t%d\t\t%s\n", cache->name, cache->size,
     613                printf("%s\t%d\t%d\t%d\t%d\t%d\t%d\t\t%s\n", cache->name, cache->size,
    603614                       (1 << cache->order), cache->objects,
    604                        atomic_get(&cache->allocated_slabs),
     615                       atomic_get(&cache->allocated_slabs),
     616                       atomic_get(&cache->cached_objs),
    605617                       atomic_get(&cache->allocated_objs),
    606618                       cache->flags & SLAB_CACHE_SLINSIDE ? "In" : "Out");
Note: See TracChangeset for help on using the changeset viewer.