当前位置: 首页 > wzjs >正文

企业做网站步骤收录网站

企业做网站步骤,收录网站,手机网站图片切换特效,唐山如何做百度的网站GPU虚拟化实现(五) 章节回顾初步介绍详细介绍核心数据结构核心功能和运作机制初始化显存分配显存释放显存溢出检查显存类型检查查看分配信息代码执行流程假设例子总结章节回顾 在上一章,简单介绍了项目拦截cuda函数的流程,其本质上与拦截nvml函数的流程是一致的,都是首先…

GPU虚拟化实现(五)

  • 章节回顾
  • 初步介绍
  • 详细介绍
    • 核心数据结构
    • 核心功能和运作机制
      • 初始化
      • 显存分配
      • 显存释放
      • 显存溢出检查
      • 显存类型检查
      • 查看分配信息
    • 代码执行流程
    • 假设例子
  • 总结

章节回顾

在上一章,简单介绍了项目拦截cuda函数的流程,其本质上与拦截nvml函数的流程是一致的,都是首先将源函数的地址存储在列表的指针中,当拦截到函数时跳转到自定义实现的函数,需要特殊处理就特殊处理,如不需要转到源函数去处理。在这一章,将会介绍这个项目的allocator模块。

初步介绍

项目中的allocator模块时自定义实现的 CUDA 设备显存分配器,主要负责实际的显存分配、释放、追踪和 OOM 检查。

详细介绍

核心数据结构

分配器的运作依赖于几个关键的数据结构(定义在 allocator.h 中):

  1. allocated_device_memory_struct
struct allocated_device_memory_struct{CUdeviceptr address;                       // 设备显存的指针size_t length;                             // 分配的大小CUcontext ctx;                             // 关联的 CUDA 上下文CUmemGenericAllocationHandle *allocHandle; // 分配句柄
};
typedef struct allocated_device_memory_struct allocated_device_memory;

这个结构体用来存储单块已分配的 CUDA 设备显存的关键信息。
2. allocated_list_structallocated_list_entry_struct

struct allocated_list_entry_struct{allocated_device_memory *entry;;struct allocated_list_entry_struct *next,*prev;
};
typedef struct allocated_list_entry_struct allocated_list_entry;struct allocated_list_struct{allocated_list_entry *head;allocated_list_entry *tail;size_t length;
};
typedef struct allocated_list_struct allocated_list;

allocated_list_entry定义了双向链表中的一个节点。每个节点代表着一块被追踪的设备显存。
allocated_list是一个双向链表,用于存储分配的显存记录。
3. region_struct, region_list_structregion_list_entry_struct(在 allocator.c 这个文件的代码逻辑里,并没有直接使用 region 相关的结构和逻辑)

struct region_struct{size_t start;size_t freemark;size_t freed_map;size_t length;CUcontext ctx;allocated_list *region_allocs;char *bitmap;CUmemGenericAllocationHandle *allocHandle;
};
typedef struct region_struct region;struct region_list_entry_struct{region *entry;struct region_list_entry_struct *next,*prev;
};
typedef struct region_list_entry_struct region_list_entry;struct region_list_struct{region_list_entry   *head;region_list_entry   *tail;size_t length;
};
typedef struct region_list_struct region_list;

大白话解释:
想象 GPU 显存是一整块大蛋糕,为了方便管理,我们先把它分成几块“大蛋糕”(region),每一块大蛋糕都有自己的档案,记录大小、位置、还有哪些部分被切走了。大蛋糕的档案都串在一起(region_list_entry),放在一个总账本里(region_list),让你随时能找到所有大蛋糕的信息。

每块大蛋糕还能再切成很多“小蛋糕”,分给不同的任务用。每块小蛋糕的信息(位置、大小、谁在用)也记录在小纸条上(allocated_device_memory),这些小纸条串成一串(allocated_list_entry),放在一个小账本里(allocated_list)。而每个大蛋糕的档案里,都有一个指向自己小账本的指针(region_allocs),让你知道从这块大蛋糕切出去的小蛋糕有哪些。

核心功能和运作机制

初始化

// allocator.c
void allocator_init(){LOG_DEBUG("Allocator_init\n");device_overallocated = malloc(sizeof(allocated_list));LIST_INIT(device_overallocated);pthread_mutex_init(&mutex,NULL);
}
// allocator.h
#define LIST_INIT(list) {   \list->head=NULL;         \list->tail=NULL;         \list
http://www.dtcms.com/wzjs/38717.html

相关文章:

  • 怎么建设课程的网站seo主要是指优化
  • 国内优秀的网站设计广告公司怎么找客户资源
  • 35网站建设网页开发公司
  • 开个做网站公司网站推广的途径有哪些
  • 网站换空间不换域名对seo有影响吗百度如何发布作品
  • 看b站直播间户外百度平台商家我的订单查询
  • 广州小型网站建设公司长沙市网站制作
  • 企业网站无锡手机百度高级搜索入口在哪里
  • airbnb网站建设分析培训总结怎么写
  • 门户网站设计说明公司网站建设方案
  • 做衣服外贸用什么网站好网络工程师培训机构排名
  • 微信优惠券网站怎么做的网站怎么优化seo
  • 邯郸做网站公司nba最新排名榜
  • 深圳智能响应网站建设优化网站有哪些方法
  • mysql做wp网站专业seo网络推广
  • 商城网站服务器租用南昌seo优化
  • 中国银行网站建设百度热点排行榜
  • 网站建设河南公司百度下载免费安装
  • 量个网站一个域名打开百度一下
  • 如何建电子商务网站quark搜索引擎入口
  • 人工在线客服平台郑州专业seo推荐
  • 12306网站学生做网络推广主要做什么
  • wordpress搬家后文章泉州网站建设优化
  • 什么网站做玩具的外贸推广平台哪儿有怎么做
  • 湖北省建设信息网站网络公司品牌推广
  • 网站后台有些不显示网站排名优化软件
  • 温州网站建设备案软件开发平台
  • 自己做网站前端开发营销公司排名
  • 一家专做灯的网站招聘凡科网怎么建网站
  • 网站后台尺寸一般做多大的自助建站