Changeset 0c2d9bb in mainline for kernel/generic/include/mm/frame.h


Ignore:
Timestamp:
2013-12-25T22:54:29Z (10 years ago)
Author:
Martin Decky <martin@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
b51cf2c
Parents:
f7a33de (diff), ac36aed (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

merge mainline changes

File:
1 edited

Legend:

Unmodified
Added
Removed
  • kernel/generic/include/mm/frame.h

    rf7a33de r0c2d9bb  
    3939#include <typedefs.h>
    4040#include <trace.h>
     41#include <adt/bitmap.h>
    4142#include <adt/list.h>
    42 #include <mm/buddy.h>
    4343#include <synch/spinlock.h>
    4444#include <arch/mm/page.h>
     
    5050typedef uint8_t frame_flags_t;
    5151
    52 #define FRAME_NONE        0x0
    53 /** Convert the frame address to kernel VA. */
    54 #define FRAME_KA          0x1
     52#define FRAME_NONE        0x00
    5553/** Do not panic and do not sleep on failure. */
    56 #define FRAME_ATOMIC      0x2
     54#define FRAME_ATOMIC      0x01
    5755/** Do not start reclaiming when no free memory. */
    58 #define FRAME_NO_RECLAIM  0x4
     56#define FRAME_NO_RECLAIM  0x02
    5957/** Do not reserve / unreserve memory. */
    60 #define FRAME_NO_RESERVE  0x8
     58#define FRAME_NO_RESERVE  0x04
    6159/** Allocate a frame which can be identity-mapped. */
    62 #define FRAME_LOWMEM      0x10
     60#define FRAME_LOWMEM      0x08
    6361/** Allocate a frame which cannot be identity-mapped. */
    64 #define FRAME_HIGHMEM     0x20
    65 /** Allocate a frame which needs to be from DMA zone. */
    66 #define FRAME_DMA         0x40
     62#define FRAME_HIGHMEM     0x10
    6763
    6864typedef uint8_t zone_flags_t;
    6965
    70 #define ZONE_NONE       0x0
     66#define ZONE_NONE       0x00
    7167/** Available zone (free for allocation) */
    72 #define ZONE_AVAILABLE  0x1
     68#define ZONE_AVAILABLE  0x01
    7369/** Zone is reserved (not available for allocation) */
    74 #define ZONE_RESERVED   0x2
     70#define ZONE_RESERVED   0x02
    7571/** Zone is used by firmware (not available for allocation) */
    76 #define ZONE_FIRMWARE   0x4
     72#define ZONE_FIRMWARE   0x04
    7773/** Zone contains memory that can be identity-mapped */
    78 #define ZONE_LOWMEM     0x8
     74#define ZONE_LOWMEM     0x08
    7975/** Zone contains memory that cannot be identity-mapped */
    80 #define ZONE_HIGHMEM    0x10
    81 /** Zone contains memory suitable for old ISA DMA */
    82 #define ZONE_DMA        0x20
     76#define ZONE_HIGHMEM    0x10
    8377
    8478/** Mask of zone bits that must be matched exactly. */
    85 #define ZONE_EF_MASK    0x7
     79#define ZONE_EF_MASK  0x07
    8680
    87 #define FRAME_TO_ZONE_FLAGS(ff) \
    88         ((((ff) & FRAME_DMA) ? ZONE_DMA : \
    89             (((ff) & FRAME_LOWMEM) ? ZONE_LOWMEM : \
     81#define FRAME_TO_ZONE_FLAGS(ff) \
     82        ((((ff) & FRAME_LOWMEM) ? ZONE_LOWMEM : \
    9083            (((ff) & FRAME_HIGHMEM) ? ZONE_HIGHMEM : \
    91             ZONE_LOWMEM /* | ZONE_HIGHMEM */))) | \
     84            ZONE_LOWMEM /* | ZONE_HIGHMEM */)) | \
    9285            ZONE_AVAILABLE)
    9386
     
    9790
    9891typedef struct {
    99         size_t refcount;      /**< Tracking of shared frames */
    100         link_t buddy_link;    /**< Link to the next free block inside
    101                                    one order */
    102         void *parent;         /**< If allocated by slab, this points there */
    103         uint8_t buddy_order;  /**< Buddy system block order */
     92        size_t refcount;  /**< Tracking of shared frames */
     93        void *parent;     /**< If allocated by slab, this points there */
    10494} frame_t;
    10595
    10696typedef struct {
    107         pfn_t base;                    /**< Frame_no of the first frame
    108                                             in the frames array */
    109         size_t count;                  /**< Size of zone */
    110         size_t free_count;             /**< Number of free frame_t
    111                                             structures */
    112         size_t busy_count;             /**< Number of busy frame_t
    113                                             structures */
    114         zone_flags_t flags;            /**< Type of the zone */
     97        /** Frame_no of the first frame in the frames array */
     98        pfn_t base;
    11599       
    116         frame_t *frames;               /**< Array of frame_t structures
    117                                             in this zone */
    118         buddy_system_t *buddy_system;  /**< Buddy system for the zone */
     100        /** Size of zone */
     101        size_t count;
     102       
     103        /** Number of free frame_t structures */
     104        size_t free_count;
     105       
     106        /** Number of busy frame_t structures */
     107        size_t busy_count;
     108       
     109        /** Type of the zone */
     110        zone_flags_t flags;
     111       
     112        /** Frame bitmap */
     113        bitmap_t bitmap;
     114       
     115        /** Array of frame_t structures in this zone */
     116        frame_t *frames;
    119117} zone_t;
    120118
     
    131129extern zones_t zones;
    132130
    133 NO_TRACE static inline uintptr_t PFN2ADDR(pfn_t frame)
    134 {
    135         return (uintptr_t) (frame << FRAME_WIDTH);
    136 }
    137 
    138 NO_TRACE static inline pfn_t ADDR2PFN(uintptr_t addr)
    139 {
    140         return (pfn_t) (addr >> FRAME_WIDTH);
    141 }
    142 
    143 NO_TRACE static inline size_t SIZE2FRAMES(size_t size)
    144 {
    145         if (!size)
    146                 return 0;
    147         return (size_t) ((size - 1) >> FRAME_WIDTH) + 1;
    148 }
    149 
    150 NO_TRACE static inline size_t FRAMES2SIZE(size_t frames)
    151 {
    152         return (size_t) (frames << FRAME_WIDTH);
    153 }
    154 
    155 #define IS_BUDDY_ORDER_OK(index, order) \
    156     ((~(((sysarg_t) -1) << (order)) & (index)) == 0)
    157 #define IS_BUDDY_LEFT_BLOCK(zone, frame) \
    158     (((frame_index((zone), (frame)) >> (frame)->buddy_order) & 0x1) == 0)
    159 #define IS_BUDDY_RIGHT_BLOCK(zone, frame) \
    160     (((frame_index((zone), (frame)) >> (frame)->buddy_order) & 0x1) == 1)
    161 #define IS_BUDDY_LEFT_BLOCK_ABS(zone, frame) \
    162     (((frame_index_abs((zone), (frame)) >> (frame)->buddy_order) & 0x1) == 0)
    163 #define IS_BUDDY_RIGHT_BLOCK_ABS(zone, frame) \
    164     (((frame_index_abs((zone), (frame)) >> (frame)->buddy_order) & 0x1) == 1)
    165 
    166131extern void frame_init(void);
    167132extern bool frame_adjust_zone_bounds(bool, uintptr_t *, size_t *);
    168 extern void *frame_alloc_generic(uint8_t, frame_flags_t, size_t *);
    169 extern void *frame_alloc(uint8_t, frame_flags_t);
    170 extern void *frame_alloc_noreserve(uint8_t, frame_flags_t);
    171 extern void frame_free_generic(uintptr_t, frame_flags_t);
    172 extern void frame_free(uintptr_t);
    173 extern void frame_free_noreserve(uintptr_t);
     133extern uintptr_t frame_alloc_generic(size_t, frame_flags_t, uintptr_t,
     134    size_t *);
     135extern uintptr_t frame_alloc(size_t, frame_flags_t, uintptr_t);
     136extern void frame_free_generic(uintptr_t, size_t, frame_flags_t);
     137extern void frame_free(uintptr_t, size_t);
     138extern void frame_free_noreserve(uintptr_t, size_t);
    174139extern void frame_reference_add(pfn_t);
    175140extern size_t frame_total_free_get(void);
Note: See TracChangeset for help on using the changeset viewer.