Browse Source

未知BUG

master
Chiri 1 month ago
parent
commit
583d2eae89
11 changed files with 820 additions and 810 deletions
  1. +5
    -2
      Core/Src/main.c
  2. +5
    -2
      Core/Src/stm32f4xx_it.c
  3. +788
    -788
      EWARM/PLSR.dep
  4. +6
    -6
      EWARM/settings/PLSR.dbgdt
  5. +7
    -7
      EWARM/settings/PLSR.dnx
  6. +4
    -4
      EWARM/settings/Project.wsdt
  7. +2
    -0
      Hardware/PLSR.c
  8. +1
    -0
      Hardware/PLSR.h
  9. +2
    -1
      Hardware/modbus.c
  10. BIN
      Words/设计方案书 .doc
  11. BIN
      Words/需求规格书.doc

+ 5
- 2
Core/Src/main.c View File

@@ -134,9 +134,11 @@ int main(void)
SystemClock_Config(); SystemClock_Config();


/* USER CODE BEGIN SysInit */ /* USER CODE BEGIN SysInit */
HAL_PWR_EnableBkUpAccess();/* 使能备份域访问 */ HAL_PWR_EnableBkUpAccess();/* 使能备份域访问 */
__HAL_RCC_BKPSRAM_CLK_ENABLE();/* 使能备份SRAM时钟 */ __HAL_RCC_BKPSRAM_CLK_ENABLE();/* 使能备份SRAM时钟 */
HAL_PWREx_EnableBkUpReg();/* 使能备份SRAM */ HAL_PWREx_EnableBkUpReg();/* 使能备份SRAM */
/* USER CODE END SysInit */ /* USER CODE END SysInit */


/* Initialize all configured peripherals */ /* Initialize all configured peripherals */
@@ -331,6 +333,7 @@ void PulseStartTsk(void *p_arg)
{ {
EN = 0; EN = 0;
PulseStartFlag = 1; PulseStartFlag = 1;
//NowFrequeny = PulseOutput[NowPulse].Frequency; /* 保存当前脉冲的频率 */
PulseStart(); PulseStart();
HAL_TIM_Base_Start_IT(&htim3); /* 启动定时器3和中断 */ HAL_TIM_Base_Start_IT(&htim3); /* 启动定时器3和中断 */
} }
@@ -507,7 +510,7 @@ void EXTSet(void *p_arg)
*/ */
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim) void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{ {
OSIntEnter(); /* 进入中断 */
//OSIntEnter(); /* 进入中断 */
if (htim == (&htim3)) if (htim == (&htim3))
{ {
@@ -577,7 +580,7 @@ void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
} }
} }
OSIntExit(); /* 退出中断 */
//OSIntExit(); /* 退出中断 */
} }
/* USER CODE END 4 */ /* USER CODE END 4 */




+ 5
- 2
Core/Src/stm32f4xx_it.c View File

@@ -213,7 +213,7 @@ void SysTick_Handler(void)
void TIM2_IRQHandler(void) void TIM2_IRQHandler(void)
{ {
/* USER CODE BEGIN TIM2_IRQn 0 */ /* USER CODE BEGIN TIM2_IRQn 0 */
// OSIntEnter(); /* 进入中断 */
/* USER CODE END TIM2_IRQn 0 */ /* USER CODE END TIM2_IRQn 0 */
HAL_TIM_IRQHandler(&htim2); HAL_TIM_IRQHandler(&htim2);
/* USER CODE BEGIN TIM2_IRQn 1 */ /* USER CODE BEGIN TIM2_IRQn 1 */
@@ -250,6 +250,7 @@ void TIM2_IRQHandler(void)
} }
ArrFlag = 1; ArrFlag = 1;
SetNextPulse();/* 设置下一次进入中断的脉冲数 */ SetNextPulse();/* 设置下一次进入中断的脉冲数 */
//NowFrequeny = PulseOutput[NowPulse].Frequency; /* 保存当前脉冲的频率 */
HAL_TIM_Base_Start_IT(&htim3); /* 启动定时器3和中断 */ HAL_TIM_Base_Start_IT(&htim3); /* 启动定时器3和中断 */
} }
@@ -298,6 +299,7 @@ void TIM2_IRQHandler(void)
} }
ArrFlag = 1; ArrFlag = 1;
SetNextPulse();/* 设置下一次进入中断的脉冲数 */ SetNextPulse();/* 设置下一次进入中断的脉冲数 */
//NowFrequeny = PulseOutput[NowPulse].Frequency; /* 保存当前脉冲的频率 */
HAL_TIM_Base_Start_IT(&htim3); /* 启动定时器3和中断 */ HAL_TIM_Base_Start_IT(&htim3); /* 启动定时器3和中断 */
} }


@@ -307,9 +309,10 @@ void TIM2_IRQHandler(void)
{ {
PulseCount = 0; PulseCount = 0;
ArrFlag = 0; ArrFlag = 0;
HAL_TIM_PWM_Stop_IT(&htim10,TIM_CHANNEL_1); /* 停止PWM输出 */
HAL_TIM_PWM_Stop_IT(&htim10,TIM_CHANNEL_1); /* 停止PWM输出 */
} }
} }
// OSIntExit(); /* 退出中断 */
/* USER CODE END TIM2_IRQn 1 */ /* USER CODE END TIM2_IRQn 1 */
} }




+ 788
- 788
EWARM/PLSR.dep
File diff suppressed because it is too large
View File


+ 6
- 6
EWARM/settings/PLSR.dbgdt
File diff suppressed because it is too large
View File


+ 7
- 7
EWARM/settings/PLSR.dnx View File

@@ -12,15 +12,15 @@
<ByteLimit>50</ByteLimit> <ByteLimit>50</ByteLimit>
</Stack> </Stack>
<StLinkDriver> <StLinkDriver>
<stlinkserialNo>44142557</stlinkserialNo>
<stlinkfoundProbes />
<stlinkResetStyle>0</stlinkResetStyle> <stlinkResetStyle>0</stlinkResetStyle>
<stlinkResetStrategy>2</stlinkResetStrategy> <stlinkResetStrategy>2</stlinkResetStrategy>
<CStepIntDis>_ 0</CStepIntDis> <CStepIntDis>_ 0</CStepIntDis>
<LeaveTargetRunning>_ 0</LeaveTargetRunning> <LeaveTargetRunning>_ 0</LeaveTargetRunning>
<stlinkserialNo>44142557</stlinkserialNo>
<stlinkfoundProbes />
</StLinkDriver> </StLinkDriver>
<DebugChecksum> <DebugChecksum>
<Checksum>223229180</Checksum>
<Checksum>1343253174</Checksum>
</DebugChecksum> </DebugChecksum>
<Exceptions> <Exceptions>
<StopOnUncaught>_ 0</StopOnUncaught> <StopOnUncaught>_ 0</StopOnUncaught>
@@ -126,10 +126,6 @@
<ShowTimeSum>1</ShowTimeSum> <ShowTimeSum>1</ShowTimeSum>
<SumSortOrder>0</SumSortOrder> <SumSortOrder>0</SumSortOrder>
</EventLog> </EventLog>
<TermIOLog>
<LoggingEnabled>_ 0</LoggingEnabled>
<LogFile>_ ""</LogFile>
</TermIOLog>
<LogFile> <LogFile>
<LoggingEnabled>_ 0</LoggingEnabled> <LoggingEnabled>_ 0</LoggingEnabled>
<LogFile>_ ""</LogFile> <LogFile>_ ""</LogFile>
@@ -159,4 +155,8 @@
<Count>1</Count> <Count>1</Count>
<SuppressDialog>0</SuppressDialog> <SuppressDialog>0</SuppressDialog>
</Aliases> </Aliases>
<TermIOLog>
<LoggingEnabled>_ 0</LoggingEnabled>
<LogFile>_ ""</LogFile>
</TermIOLog>
</settings> </settings>

+ 4
- 4
EWARM/settings/Project.wsdt
File diff suppressed because it is too large
View File


+ 2
- 0
Hardware/PLSR.c View File

@@ -20,6 +20,8 @@ int32_t AccUpCount; /*
int32_t AccDownCount; /* 减速脉冲数 */ int32_t AccDownCount; /* 减速脉冲数 */
int32_t NowMAXPulse; /* 当前要达到的总脉冲 */ int32_t NowMAXPulse; /* 当前要达到的总脉冲 */


uint32_t NowFrequeny;

int32_t PulseCount = 0; int32_t PulseCount = 0;


/** /**


+ 1
- 0
Hardware/PLSR.h View File

@@ -41,6 +41,7 @@ extern int32_t AccUpCount; ///<<
extern int32_t AccDownCount;///<<减速脉冲数 extern int32_t AccDownCount;///<<减速脉冲数
extern int32_t NowMAXPulse; ///<<当前要达到的总脉冲 extern int32_t NowMAXPulse; ///<<当前要达到的总脉冲
extern int32_t PulseCount; extern int32_t PulseCount;
extern uint32_t NowFrequeny;
extern int32_t NextPulseEND; extern int32_t NextPulseEND;






+ 2
- 1
Hardware/modbus.c View File

@@ -94,7 +94,8 @@ void ProcessModbusFrame(uint8_t buffer[], uint16_t longth)
;break; ;break;
case WRITE_ONLY_REGISTER: WriteOnlyRegister(buffer, longth) case WRITE_ONLY_REGISTER: WriteOnlyRegister(buffer, longth)
;break; ;break;
case PLSR_COUNT_CLEAR: PLSRCountClear();
// case PLSR_COUNT_CLEAR: PLSRCountClear()
// ;break;
default :ErrorBack(buffer, longth); /* ÎÞЧָÁîÂë */ default :ErrorBack(buffer, longth); /* ÎÞЧָÁîÂë */
;break; ;break;


BIN
Words/设计方案书 .doc View File


BIN
Words/需求规格书.doc View File


Loading…
Cancel
Save