1. VPP源码分析(内存管理之mheap)

简介: 1.1. mheap 1.1.1. mheap_t first_free_elt_uoffset_by_bin: User offsets for head of doubly-linked list of free objects of this size.

1.1. mheap

1.1.1. mheap_t

1

  • first_free_elt_uoffset_by_bin: User offsets for head of doubly-linked list of free objects of this size.
  • non_empty_free_elt_heads: Bitmap of non-empty free list bins.
  • n_elts: Number of allocated objects.
  • max_size: Maximum size (in bytes) this heap is allowed to grow to.
    2

1.1.2. mheap_elt_t

3

  • prev_n_user_data: Number of mheap_size_t words of user data in previous object. Used to find mheap_elt_t for previous object.
  • prev_is_free: Set if previous object is free.
  • n_user_data: Number of mheap_size_t words of user data that follow this object.
  • is_free: Set if this object is on free list (and therefore following free_elt is valid).
  • user_data: For allocated objects: user data follows.
    User data is allocated in units of typeof (user_data[0]).
  • free_elt: For free objects, offsets of next and previous free objects of this size;
    ~0 means end of doubly-linked list.

This is stored in user data (guaranteed to be at least 8 bytes) but only for free objects.
4

1.1.3. mheap_alloc函数过程

5
从虚拟内存空间映射一块size大的内存(am = 0x7ffff3a0ff54)

mmap_addr = mmap(0, size, PROT_READ | PROT_WRITE, flags, -1, 0);
  1. 将mmap_addr指针和页大小对其(av = 0x7ffff3a10000)
    return (addr + mheap_page_size - 1) & ~(mheap_page_size - 1);
  2. 从对齐页的位置往前减去mheap_t的空间(ah = 0x7ffff3a0f860)
    ah = vec_aligned_header(v, sizeof (mheap_t), 16);
  3. 再往后n个page,(ah + page = 0x7ffff3a10860)得到真正的mheap开始的位置【这边类似于补运算,在申请的空间内跳过page_size - mheap_size 的空间】
  4. (ah < am)
    ah += mheap_page_size; // 这样可以保证mheap的其实位置在申请的空间内,且一定对其与page
  5. 最后计算出vector的偏移
    v = mheap_vector (h); // h + sizeof(mheap_t + vec_header_t)
  6. vector区域可以存放的数据大小为
    size = am + memory_size - v;

1.1.4. 从mheap中申请内存

void *
mheap_get_aligned(void *v, uword n_user_data_bytes, uword align, uword align_offset, uword * offset_return)
/* Search free lists for object with given size and alignment. */
static uword
mheap_get_search_free_list(void *v, uword *n_user_bytes_arg, uword align, uword align_offset)
/* Find bin for objects with size at least n_user_data_bytes. */
always_inline uword
user_data_size_to_bin_index(uword n_user_data_bytes)

6

根据用户请求object的size and alignment找到合适的bin(small_bin or large_bin),再从bin中找到合适的free elt
这里所有的操作都是基于数组的形式,elt间的双向链表也是以数组的形式实现的

目录
相关文章
|
关系型数据库 数据库 PostgreSQL
PG源码分析系列:内存上下文
title: Pgsql源码分析——内存上下文 date: 2018-05-01 22:00:00 categories: - Postgresql - PgSource Postgresql内存上下文源码分析 1 数据库内存上下文   postgresql在7.1版本引入了内存上下文机制来解决日益严重的内存泄漏的问题,在引入了这种“
1762 1
|
Java C++
Java Review - 线程池中使用ThreadLocal不当导致的内存泄漏案例&源码分析
Java Review - 线程池中使用ThreadLocal不当导致的内存泄漏案例&源码分析
142 0
|
缓存 算法 Java
全网最硬核 Java 新内存模型解析与实验 - 5. JVM 底层内存屏障源码分析
全网最硬核 Java 新内存模型解析与实验 - 5. JVM 底层内存屏障源码分析
全网最硬核 Java 新内存模型解析与实验 - 5. JVM 底层内存屏障源码分析
|
存储 Linux C++
STL源码分析--内存分配器
STL源码分析--内存分配器
222 0
STL源码分析--内存分配器
|
Java 调度
JVM源码分析之警惕存在内存泄漏风险的FinalReference(增强版)
JVM源码分析之警惕存在内存泄漏风险的FinalReference(增强版)
JVM源码分析之警惕存在内存泄漏风险的FinalReference(增强版)
|
存储 算法 安全
ThreadLocal全攻略:使用实战,源码分析,内存泄露分析
ThreadLocal全攻略:使用实战,源码分析,内存泄露分析
344 0
ThreadLocal全攻略:使用实战,源码分析,内存泄露分析
JVM源码分析之不可控的堆外内存
JVM源码分析之不可控的堆外内存
|
存储 算法 JavaScript
从V8源码分析一个JS 数组的内存占用问题
前段时间,在排查一个问题的时候,遇到了一个有点令人困惑的情况,有下面这两段代码:
从V8源码分析一个JS 数组的内存占用问题
|
算法 Java 开发者
JVM源码分析之堆外内存完全解读
本文作者来源李嘉鹏。 堆外内存有广义的堆外内存和狭义的堆外内存之分。
1249 0
JVM源码分析之堆外内存完全解读
|
分布式计算 搜索推荐 Spark
Spark 源码分析之ShuffleMapTask内存数据Spill和合并
- Spark ShuffleMapTask 内存中的数据Spill到临时文件 - 临时文件中的数据是如何定入的,如何按partition升序排序,再按Key升序排序写入(key,value)数据 - 每个临时文件,都存入对应的每个分区有多少个(key,value)对,有多少次流提交数组,数组中...
1887 0