DSP多核开发——OpenMP

若以C6678为例,一共8个核心,以核心0作为主核心,负责接收数据,如通过网络或VME等其他设备接收数据,然后开始计算,希望同时调用8个核心加快算法计算的速度。计算完成后结果的数据再通过主核心的网络或VME等发送出去。对于这种场景就非常适合OpenMP。无需关心底层的数据交互,只关心算法提升的速度。

OpenMP只适用于同构多核处理器,同一个处理器不同核心之间。

首先需要有一个主线程,在平时串行的执行命令,在需要做算法计算的时候做并行计算,可以通过预编译指令指定需要并行执行的代码段,然后就会fork分配这些需要并行执行的代码到不同核心的多个线程中执行,执行完成后再join回到主线程。

 OpenMP内存使用

其中L2如果被配为缓存则高128k是缓存低位地址是内存,另一部分可以配置为堆和栈大小都可以配置。

MSMCSRAM必须有128k被配置为非缓存区域。 

#pragma omp parallel for
for(i = 0; i<240000 ;i++)
{
    Gray[i] = (Image[3*i+2]*776 + Image[3*i + 1]*150 + Image[3*i]*30)>>8;
}

这个例子是rgb888的图片数组转换为灰度图,使用的经验公式,如果使用单核用一个for循环就够了,若把它运行在多线程多核的情况下只需要添加#pragma omp parallel for就可以了,这就是预编译指令指导openmp的行为。

使用OpenMP需要在CCS中将Enable support for OpenMP 打开才可以,需要引用omp.h头文件

进入main函数前需要启动所有核心写在TI_omp_reset函数里面,在main函数之前执行。

冃录 11录 ...............................................................3 C6678运行Dem o详解.......................................... 7 1 ・ intc_b「oadcast_ 1 ...................................................................................................... 7 I」功能描述........................................................7 1.2变最定义及使用空间分配.........................................7 1.3实现流程........................................................7 1.4注意事项........................................................9 2. D D R 3......................................................................................................................10 2 .1 功能描述....................................................... 10 2.2变量定义及使用空间分配........................................ 10 2.3实现流程....................................................... 10 2.4注意事项....................................................... 11 3. ipc一 navigator.......................................................................................................... 12 3」功能描述....................................................... 12 3.2变最定义及使用空间分配........................................ 12 V 3 .3 实现流程....................................................... 12 3.4注意事项....................................................... 14 4. emif_nandflash....................................................................................................... 14 4 J 功能描述....................................................... 14 4.2变量定义及使用空间分配........................................ 14 4 .3 实现流程....................................................... 14 4.4注意事项....................................................... 15 5. emif_norflash......................................................................................................... 16 5」功能描述....................................................... 16 5.2变最定义及使用空间分配........................................ 16 5.3实现流程....................................................... 16 5.4注意事项....................................................... 17 6. hyperlink................................................................................................................ 17 6」功能描述....................................................17 6.2变量定义及使用空间分配......................................17 6 .3 实现流程....................................................17 6.4注意事项.................................................... 18 7. i2c_eeprom............................................................................................................. 19 7」功能描述.....................................................19 7.2变最定义及使用空间分配......................................19 7.3实现流程.................................................... 19 7.4注意事项....................................................20 8. i2c_srioswitch........................................................................................................20 & 1功能描述....................................................20 8.2变量定义及使用空间分配......................................20 8.3实现流税.........:............................. =21 8.4注意事项....................................................21 9. sem 2....................................................................................................................... 21 9」功能描述.................................................... 21 9.2变虽定义及使用空间分配......................................22 9.3实现流程....................................................22 9.4注意事项....................................................23 1(). srio...........................................................................................................................24 10」功能描述...................................................24 10.2变暈定义及使用空间分配.....................................24 10.3实现流程...................................................24 10.4注意事项...................................................27 11. tim er....................................................................................................................... 28 11」功能描述...................................................28 11.2变最定义及使用空间分配.....................................28 11.3实现流程...................................................2911.4注意爭项......................................................30 12. SPI_FPGA.............................................................................................................. 30 12」功能描述......................................................30 12.2变量定义及使用空间分配.......................................30 12.3实现流程......................................................30 12.4注意爭项......................................................31 13. SPI_nortlash...........................................................................................................31 13」功能描述......................................................31 13.2变量定义及使用空间分配.......................................31 13.3实现流程......................................................31 13.4注意爭项......................................
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值