上下电逻辑

1.发送IG_OFF要持续500毫秒,或者发完IG_OFF后不要再发送跟上下电有关的命令。

2.当没有什么请求时候要发送0x04就可以。

3.当接管的时候要发发送0x04或者别的上下电命令,但是不能不发,0x04代表没有任何上下电请求。如果在接管的时候不发任何上下电命令,车辆就会直接下电。

4.当时在调试上下电的时候,先手动上电,然后接管车辆,远程下电正常,如果在1min之内重新上电也正常,但是超过两分钟后上电就不管用,后来发现是底盘VCU休眠后vehicle就会把CAN的开关给关闭掉,导致can数据发送不出去,后来把接收到can休眠的函数里把can的开关给屏蔽掉,这样就不会在接收到vcu休眠的状态把CAN给关闭掉。

以下是上下电处理相关处理代码:

void * powerReqThread(void *arg)
{
	print_log("%s id=%lu\r\n",__FUNCTION__,pthread_self());//获取当前线程ID
	print_log("Into (%s)\r\n", __FUNCTION__);
	struct timeval tv;
	long long microsecond;
	int pwReqCount = 0;
	unsigned char *pw_req_cmd = (unsigned char*)malloc(sizeof(unsigned char) * CAN_MSG_MAX_LEN);
	int num1=0,num2=0,num3=0,num4=0;
	while(!gIsPwReqThreadExit)
	{
		pwReqCount=1;
		if(mPowerCmd==IG_OFF)
		{
			for(num1=0;num1<6;num1++)
			{
				gettimeofday(&tv,NULL);
				pw_req_cmd[0] = PW_REQ_ID & 0xFF;
				pw_req_cmd[1] = (PW_REQ_ID >> 8) & 0xFF;
				microsecond = ((long long)tv.tv_sec) * 1000000 + tv.tv_usec;
				pw_req_cmd[2] = microsecond & 0xFF;
				pw_req_cmd[3] = (microsecond >> 8) & 0xFF;
				pw_req_cmd[4] = (microsecond >> 16) & 0xFF;
				pw_req_cmd[5] = (microsecond >> 24) & 0xFF;
				pw_req_cmd[6] = 0x00;
				pw_req_cmd[7] = RESERVE;
				pw_req_cmd[8] = RESERVE;
				pw_req_cmd[9] = RESERVE;
				pw_req_cmd[10] = RESERVE;
				pw_req_cmd[11] = RESERVE;
				pw_req_cmd[12] = FRAME_COUNTER(pwReqCount);
				pw_req_cmd[13] = crc8VerifyFF(&pw_req_cmd[CAN_DATA_OFFSET], CRC_VERIFY_DATA_LEN);
				CanOperateSwitch = CAN_SEND_ENABLE;
				rdbWrite(ptr_rdb, pw_req_cmd, CAN_MSG_MAX_LEN);  //给Vac主机发送上电命令  每隔50ms统计下上电命令是否改变然后发给VCA命令一次	
				print_log("CONTROLMODULES mPowerCmd=%d,sendPowerFrame=%d vcuPowerRelayState=%d\n",mPowerCmd,sendPowerFrame,vcuPowerRelayState);
				usleep(500000);  //min 500ms
			}
			mPowerCmd=CLEAR_POWER;
		}
		else if(mPowerCmd==IG_ON)
		{
			if(vcuPowerRelayState < IG_ON)
			{
				for(num2=0;num2<6;num2++)
				{
					gettimeofday(&tv,NULL);
					pw_req_cmd[0] = PW_REQ_ID & 0xFF;
					pw_req_cmd[1] = (PW_REQ_ID >> 8) & 0xFF;
					microsecond = ((long long)tv.tv_sec) * 1000000 + tv.tv_usec;
					pw_req_cmd[2] = microsecond & 0xFF;
					pw_req_cmd[3] = (microsecond >> 8) & 0xFF;
					pw_req_cmd[4] = (microsecond >> 16) & 0xFF;
					pw_req_cmd[5] = (microsecond >> 24) & 0xFF;
					pw_req_cmd[6] = 0x01;
					pw_req_cmd[7] = RESERVE;
					pw_req_cmd[8] = RESERVE;
					pw_req_cmd[9] = RESERVE;
					pw_req_cmd[10] = RESERVE;
					pw_req_cmd[11] = RESERVE;
					pw_req_cmd[12] = FRAME_COUNTER(pwReqCount);
					pw_req_cmd[13] = crc8VerifyFF(&pw_req_cmd[CAN_DATA_OFFSET], CRC_VERIFY_DATA_LEN);
					CanOperateSwitch = CAN_SEND_ENABLE;
					rdbWrite(ptr_rdb, pw_req_cmd, CAN_MSG_MAX_LEN);  //给Vac主机发送上电命令  每隔50ms统计下上电命令是否改变然后发给VCA命令一次	
					print_log("CONTROLMODULES mPowerCmd1=%d,sendPowerFrame=%d vcuPowerRelayState=%d \n",mPowerCmd,sendPowerFrame,vcuPowerRelayState);
					usleep(20000);
				}
			}
			else
			{
				print_log("CONTROLMODULES mPowerCmd==IG_ON vcuPowerRelayState=%d\n",vcuPowerRelayState);
			}
			mPowerCmd=CLEAR_POWER;
		}
		else if(mPowerCmd==POWER_ON)
		{
			if(vcuPowerRelayState < POWER_ON)
			{
				for(num3=0;num3<6;num3++)
				{
					gettimeofday(&tv,NULL);
					pw_req_cmd[0] = PW_REQ_ID & 0xFF;
					pw_req_cmd[1] = (PW_REQ_ID >> 8) & 0xFF;
					microsecond = ((long long)tv.tv_sec) * 1000000 + tv.tv_usec;
					pw_req_cmd[2] = microsecond & 0xFF;
					pw_req_cmd[3] = (microsecond >> 8) & 0xFF;
					pw_req_cmd[4] = (microsecond >> 16) & 0xFF;
					pw_req_cmd[5] = (microsecond >> 24) & 0xFF;
					pw_req_cmd[6] = 0x02;
					pw_req_cmd[7] = RESERVE;
					pw_req_cmd[8] = RESERVE;
					pw_req_cmd[9] = RESERVE;
					pw_req_cmd[10] = RESERVE;
					pw_req_cmd[11] = RESERVE;
					pw_req_cmd[12] = FRAME_COUNTER(pwReqCount);
					pw_req_cmd[13] = crc8VerifyFF(&pw_req_cmd[CAN_DATA_OFFSET], CRC_VERIFY_DATA_LEN);
					CanOperateSwitch = CAN_SEND_ENABLE;
					rdbWrite(ptr_rdb, pw_req_cmd, CAN_MSG_MAX_LEN);  //给Vac主机发送上电命令  每隔50ms统计下上电命令是否改变然后发给VCA命令一次	
					print_log("CONTROLMODULES mPowerCmd=%d,sendPowerFrame=%d vcuPowerRelayState=%d\n",mPowerCmd,sendPowerFrame,vcuPowerRelayState);
					usleep(20000);
				}
			}			
			else
			{
				print_log("CONTROLMODULES mPowerCmd==POWER_ON vcuPowerRelayState=%d\n",vcuPowerRelayState);
			}

			mPowerCmd=CLEAR_POWER;
		}
		else if(mPowerCmd==AUTO_ON)
		{
			if(vcuPowerRelayState < AUTO_ON)
			{
				for(num4=0;num4<6;num4++)
				{
					gettimeofday(&tv,NULL);
					pw_req_cmd[0] = PW_REQ_ID & 0xFF;
					pw_req_cmd[1] = (PW_REQ_ID >> 8) & 0xFF;
					microsecond = ((long long)tv.tv_sec) * 1000000 + tv.tv_usec;
					pw_req_cmd[2] = microsecond & 0xFF;
					pw_req_cmd[3] = (microsecond >> 8) & 0xFF;
					pw_req_cmd[4] = (microsecond >> 16) & 0xFF;
					pw_req_cmd[5] = (microsecond >> 24) & 0xFF;
					pw_req_cmd[6] = 0x03;
					pw_req_cmd[7] = RESERVE;
					pw_req_cmd[8] = RESERVE;
					pw_req_cmd[9] = RESERVE;
					pw_req_cmd[10] = RESERVE;
					pw_req_cmd[11] = RESERVE;
					pw_req_cmd[12] = FRAME_COUNTER(pwReqCount);
					pw_req_cmd[13] = crc8VerifyFF(&pw_req_cmd[CAN_DATA_OFFSET], CRC_VERIFY_DATA_LEN);
					CanOperateSwitch = CAN_SEND_ENABLE;
					rdbWrite(ptr_rdb, pw_req_cmd, CAN_MSG_MAX_LEN);  //给Vac主机发送上电命令  每隔50ms统计下上电命令是否改变然后发给VCA命令一次	
					print_log("CONTROLMODULES mPowerCmd=%d,sendPowerFrame=%d vcuPowerRelayState=%d\n",mPowerCmd,sendPowerFrame,vcuPowerRelayState);
					usleep(20000);
				}
			}
			else
			{
				print_log("CONTROLMODULES mPowerCmd==AUTO_ON vcuPowerRelayState=%d\n",vcuPowerRelayState);
			}
			mPowerCmd=CLEAR_POWER;
		}
		else 
		{
			gettimeofday(&tv,NULL);
			pw_req_cmd[0] = PW_REQ_ID & 0xFF;
			pw_req_cmd[1] = (PW_REQ_ID >> 8) & 0xFF;
			microsecond = ((long long)tv.tv_sec) * 1000000 + tv.tv_usec;
			pw_req_cmd[2] = microsecond & 0xFF;
			pw_req_cmd[3] = (microsecond >> 8) & 0xFF;
			pw_req_cmd[4] = (microsecond >> 16) & 0xFF;
			pw_req_cmd[5] = (microsecond >> 24) & 0xFF;
			pw_req_cmd[6] = 0x04;
			pw_req_cmd[7] = RESERVE;
			pw_req_cmd[8] = RESERVE;
			pw_req_cmd[9] = RESERVE;
			pw_req_cmd[10] = RESERVE;
			pw_req_cmd[11] = RESERVE;
			pw_req_cmd[12] = FRAME_COUNTER(pwReqCount);
			pw_req_cmd[13] = crc8VerifyFF(&pw_req_cmd[CAN_DATA_OFFSET], CRC_VERIFY_DATA_LEN);
			CanOperateSwitch = CAN_SEND_ENABLE;
			rdbWrite(ptr_rdb, pw_req_cmd, CAN_MSG_MAX_LEN);  //给Vac主机发送上电命令  每隔50ms统计下上电命令是否改变然后发给VCA命令一次	
			print_log("CONTROLMODULES mPowerCmdv else=%d,sendPowerFrame=%d vcuPowerRelayState=%d\n",mPowerCmd,sendPowerFrame,vcuPowerRelayState);
		}
		#if 0
		pwReqCount += 1;
		if(pwReqCount > 15)
			pwReqCount = 0;
		#endif
		usleep(CAN_SEND_INTERVAL_50MS);
	}
	free(pw_req_cmd);
	return 0;
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,以下是一个关于Python编写高压上下电测试用例的示例: ```python # 导入所需的库 import time # 定义一个函数,用于执行高压上测试用例 def high_voltage_power_on(): # 执行上操作 print("执行高压上操作...") time.sleep(1) # 模拟上过程 # 检查上是否成功 if check_power_on_status(): print("高压上成功!") else: print("高压上失败!") # 定义一个函数,用于执行高压下电测试用例 def high_voltage_power_off(): # 执行下电操作 print("执行高压下电操作...") time.sleep(1) # 模拟下电过程 # 检查下电是否成功 if check_power_off_status(): print("高压下电成功!") else: print("高压下电失败!") # 定义一个函数,用于检查上状态 def check_power_on_status(): # 检查上状态的逻辑 # 返回True表示上成功,返回False表示上失败 pass # 定义一个函数,用于检查下电状态 def check_power_off_status(): # 检查下电状态的逻辑 # 返回True表示下电成功,返回False表示下电失败 pass # 调用高压上测试用例 high_voltage_power_on() # 调用高压下电测试用例 high_voltage_power_off() ``` 这个示例中,我们定义了两个函数`high_voltage_power_on()`和`high_voltage_power_off()`,分别用于执行高压上下电操作。在这两个函数中,我们可以根据实际需求编写相应的逻辑来执行上下电操作,并通过调用`check_power_on_status()`和`check_power_off_status()`函数来检查上下电的状态是否成功。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值