OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4892|回复: 4

ucos任务运行硬件资源共享问题

[复制链接]

45

主题

108

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
334
金钱
334
注册时间
2013-5-22
在线时间
13 小时
发表于 2013-5-22 09:11:00 | 显示全部楼层 |阅读模式
两个完全对称的任务只是传入一个参数选择两组数据两个任务运行时要调用一个AD采样函数现在出现的问题是一个任务开始采样后另一个一开始第一个任务采样就停了


void Task_Power1()
{
   Task_Power(0);
}
void Task_Power2()
{
   Task_Power(1);
}
void Task_Power(u8 chx)

两个任务运行后是阻塞的
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165309
金钱
165309
注册时间
2010-12-1
在线时间
2108 小时
发表于 2013-5-22 10:11:49 | 显示全部楼层
AD采用能2个任务同时进行么?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

45

主题

108

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
334
金钱
334
注册时间
2013-5-22
在线时间
13 小时
 楼主| 发表于 2013-5-22 12:40:58 | 显示全部楼层
正因为不行才出现问题了能不能用信号量邮箱来互斥呢就是当一个任务占用AD时不允许其他任务使用只有这个任务释放AD才能使用
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165309
金钱
165309
注册时间
2010-12-1
在线时间
2108 小时
发表于 2013-5-22 15:07:25 | 显示全部楼层
可以
回复 支持 反对

使用道具 举报

45

主题

108

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
334
金钱
334
注册时间
2013-5-22
在线时间
13 小时
 楼主| 发表于 2013-5-22 15:41:10 | 显示全部楼层
请原子大哥指点

u16  ADCColl(u8 channel,u8 i){
// FeedDog();

if(i<16)chselect(i);
ADC_ClearFlag(ADC1, ADC_FLAG_EOC);
ADC_RegularChannelConfig(ADC1, channel, 1, ADC_SampleTime_239Cycles5);
ADC_SoftwareStartConvCmd(ADC1, ENABLE);
while(!(ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC)));
ADC_ClearFlag(ADC1, ADC_FLAG_EOC);
return ADC_GetConversionValue(ADC1);
}这是那个被两个任务调用的函数
void RefreshData(char channelx){
u16 i,ADch,tmp1;
s16 temp;
u32 ADsum[ADNUM2];


OSTimeDlyHMSM(0, 0, 0, 300);
for(ADch = CH1ADB1; ADch < ADNUM2; ADch++){ ADsum[ADch] = 0;}

for(i = 0; i < ADSAMP_NUM; i++)
{

if(channelx==0)
{
for(ADch = CH1ADB1; ADch < CH2ADB1; ADch++)
{
ADsum[ADch] += ADCColl(channel[ADch],ADch);//(enum ADCHANNELX)
}
}
if(channelx==1)
{
for(ADch = CH2ADB1; ADch < DCVIN; ADch++)
{
ADsum[ADch] += ADCColl(channel[ADch],ADch);//(enum ADCHANNELX)
}
}
for(ADch = DCVIN; ADch < ADNUM2; ADch++)
{
ADsum[ADch] += ADCColl(channel[ADch],ADch);//(enum ADCHANNELX)
}
}

for(ADch = CH1ADB1; ADch < ADNUM2; ADch++){
ADsum[ADch] /= ADSAMP_NUM;
}
switch(channelx)
{

case 0:
for(i = CH1ADB1; i < CH1DCC; i++){
run[channelx].VB[i+1] = COVER_B16(ADsum);//*CALIVOL/calivalue;
if(run[channelx].VB[i+1] < 500) run[channelx].VB[i+1] = 0;

temp = COVER_CC(ADsum[ADCUR1]);
// if((temp > 10)&&(temp < 1000)) temp -= (run.SCC*(10-temp/100)/10);
run[channelx].CC = temp/* * CALICC/calivalue[ADCUR1] */- run[channelx].SCC;////屏蔽校准
if(run[channelx].CC < 10) run[channelx].CC = 0;
run[channelx].DC = COVER_DC(ADsum[CH1DCC]) - run[channelx].SDC;//)*CALIDC/calivalue[ADDC];
if(run[channelx].DC < 10) run[channelx].DC = 0;
run[channelx].VIN = COVER_BPNI(ADsum[DCVIN]);
if(run[channelx].VIN < 50) run[channelx].VIN = 0;
run[channelx].VOUT= (COVER_BPNI(ADsum[CH1BV])/**CALIVOL*4/calivalue[CH1BV]*/) -  (run[channelx].CC/ 100);////屏蔽校准
if(run[channelx].VOUT < 50) run[channelx].VOUT = 0;
tmp1 = COVER_NTCV(ADsum[ADNTC1]); //求电压
tmp1 = COVER_NTCR(tmp1); //求电阻
run[channelx].NTC = COVER_NTC((float)tmp1/1000); //求温度
if((run[channelx].NTC < -10)||(run[channelx].NTC > 100))
///run[channelx].NTC = -100;
run[channelx].NTC = 30;
tmp1 = COVER_NTCV(ADsum[ADBT1]); //求电压
tmp1 = COVER_NTCR(tmp1); //求电阻
run[channelx].BNTC = COVER_NTC((float)tmp1/1000); //求温度
if((run[channelx].BNTC < -10)||(run[channelx].BNTC > 100))
///run[channelx].BNTC = -100;
run[channelx].BNTC = 30;
break;
case 1: for(i = CH2ADB1; i < CH2DCC; i++){
run[channelx].VB[i-7] = COVER_B16(ADsum);//*CALIVOL/calivalue;
if(run[channelx].VB[i-7] < 500) run[channelx].VB[i-7] = 0;

temp = COVER_CC(ADsum[ADCUR2]);
// if((temp > 10)&&(temp < 1000)) temp -= (run.SCC*(10-temp/100)/10);
run[channelx].CC = temp /** CALICC/calivalue[ADCUR2]*/ - run[channelx].SCC;
if(run[channelx].CC < 10) run[channelx].CC = 0;
run[channelx].DC = COVER_DC(ADsum[CH2DCC]) - run[channelx].SDC;//)*CALIDC/calivalue[ADDC];
if(run[channelx].DC < 10) run[channelx].DC = 0;
run[channelx].VIN = COVER_BPNI(ADsum[DCVIN]);
if(run[channelx].VIN < 50) run[channelx].VIN = 0;
run[channelx].VOUT= (COVER_BPNI(ADsum[CH2BV])/**CALIVOL*4/calivalue[CH2BV]*/) -  (run[channelx].CC/ 100);
if(run[channelx].VOUT < 50) run[channelx].VOUT = 0;
tmp1 = COVER_NTCV(ADsum[ADNTC2]); //求电压
tmp1 = COVER_NTCR(tmp1); //求电阻
run[channelx].NTC = COVER_NTC((float)tmp1/1000); //求温度
if((run[channelx].NTC < -10)||(run[channelx].NTC > 100))
///run[channelx].NTC = -100;
run[channelx].NTC = 30;
tmp1 = COVER_NTCV(ADsum[ADBT2]); //求电压
tmp1 = COVER_NTCR(tmp1); //求电阻
run[channelx].BNTC = COVER_NTC((float)tmp1/1000); //求温度
if((run[channelx].BNTC < -10)||(run[channelx].BNTC > 100))
////run[channelx].BNTC = -100;
run[channelx].BNTC = 30;
break;
default: break;
}


FANProc();

}
这是调用AD转换的函数
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-22 23:14

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表