TI中文支持网
TI专业的中文技术问题搜集分享网站

利用全局变量flag进行核间通信

自己写了一段小程序,想要实现core0和core1之间的数据通信。

其中使用了全局变量flag作为标志位,指示core0是否完成数据的操作。

软件:ccs5.4

6678仿真运行。

运行的步骤:先在core0中跑,然后手动切换到core1中跑相同的程序。

问题:当切换到core1中时,发现flag=0,但是data[100]中是core1执行完程序的数值0,1,2…….99。

            而且在ccs的变量查看窗口看到core0和core1的flag所在地址是相同的。

请问:为什么flag不能同步呢?

程序:

#include <stdio.h>
#include <c6x.h>


int data[100],i,flag;//两个core的flag都位于0X0C007BDC,但是当第一个核执行完成后flag=1,第二个核读取flag=0,而且data是可以同步

int main(void)
{
	if(DNUM == 0)
	{
		flag=0;
		for(i=0; i<100; i++)
		{
			data[i]=i+1;
			if(i==99)
			{
				printf("data has prepared!");
				flag=1;
			}
		}

	}
	if(DNUM==1 && flag==1)
	{
		for(i=0;i<100; i++)
		{
			data[i]=data[i]+DNUM;
		}
	}
	return 0;
}
CMD文件如下:
-heap  0x800
-stack 0x1000

MEMORY
{
	/* Local L2, 0.5~1MB*/
	VECTORS: 	o = 0x00800000  l = 0x00000200
	LL2: 	o = 0x00800200  l = (0x00080000-0x200)
	MSM:o = 0x0c000000  l = 0x0c3fffff
}

SECTIONS
{
	vecs	>VECTORS
	GROUP
	{
		.stack
		.far
		.sysmem
	} > MSM
	
	GROUP
	{
		.text
		.switch
	} > MSM
	
	GROUP
	{
		.bss
		.neardata
		.rodata
	} > MSM
	
	GROUP
	{
		.fardata
		.const
	} > LL2
	
	GROUP
	{
		.cinit
		.cio
	} > MSM

}

 
Annie Ren:

回复 Allen35065:

Allen Yin

谢谢你的回答!

在德仪社区看到了下面的方法:http://www.deyisupport.com/question_answer/dsp_arm/c6000_multicore/f/53/t/6338.aspx

The operations on Core 0 are:

Write Flag at shared memory

If(Cache is enabled for access shared memory)

{

 If(L2 Cache Size>0)

 {

   CACHE_wbL2(flag address, size of flag);

 }

 Else if(L1D Cache Size>0)

 {

   CACHE_wbL1D(flag address, size of flag);

 }

}

The operations on Core 1 are:

If(Cache is enabled for access shared memory)

{

 If(L2 Cache Size>0)

 {

   CACHE_invL2(flag address, size of flag);

 }

 Else if(L1D Cache Size>0)

 {

   CACHE_invL1D(flag address, size of flag);

 }

}

If(Prefetch buffer is enabled for access Core X’s L2 RAM)

{

 Invalidate Prefetch Buffer;

}

Read Flag at shared memory

赞(0)
未经允许不得转载:TI中文支持网 » 利用全局变量flag进行核间通信
分享到: 更多 (0)