异构计算编程

本文介绍了异构计算系统,由通用处理器和特定于域的处理器(如MLU)组成,重点讲解了MLU异构编程的编译链接过程、执行模型,以及在MLU270上并行执行的限制。
摘要由CSDN通过智能技术生成

异构计算编程
异构计算系统通常由通用处理器和许多特定于域的处理器组成:通用处理器作为控制设备(称为主机),用于复杂的控制和调度;特定于域的处理器作为子设备(称为MLU),用于大规模并行计算和特定于域的计算任务。主机和MLU合作完成计算任务。对于异构计算系统,原始的同构并行编程模型不再适用。因此,异构并行编程模型在学术界和工业界受到越来越多的关注。本文简要介绍了MLU异构编程。
编译链接过程
异构编程包括Host和MLU。对于主机,主要包括设备获取,数据/参数准备,执行流创建,任务描述,内核启动,输出获取等。Entry函数是MLU上的程序项,可以调用MLU函数。MLU程序使用异构编程模型的C / C ++语言扩展。二进制文件由MLU的指定编译器编译。
在这里插入图片描述

MLU异构程序的编译和链接过程
MLU异构程序如图2所示。MLU异构程序。采用单独的编程方法,即主机程序和MLU程序位于不同的文件(即主机文件和内核文件)中。Host程序和MLU程序的异构并行程序需要由编译器进行编译。
主机程序是常见的C / C ++程序,用户可以使用任何C / C ++编译器,例如GCC,CLANG等。MLU程序是基于C / C ++语言的扩展,可以通过以下方式进行编译: Cambricon提供的指定编译器CNCC。主机链接器通过链接主机和MLU中的两个目标文件,Runtime库和其他文件来形成可执行程序。
平行模型
执行模型
启动执行任务时&#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值