• 已解决 73482 个问题
  • 已帮助 5993 位优秀工程师

如下程序,无法运行flashdata函数。

l4bg 2017-06-02 浏览量:1519

如下程序,无法运行flashdata函数。



#include "main.h"
#include "stm32f1xx_hal.h"
#include "cmsis_os.h"
#include "tim.h"
#include "gpio.h"




int main(void)
{

  HAL_Init();

  SystemClock_Config();

  MX_GPIO_Init();
  MX_DMA_Init();
  MX_ADC1_Init();
  MX_ADC2_Init();
  MX_I2C1_Init();
  MX_UART4_Init();
  MX_UART5_Init();
  MX_USART1_UART_Init();
  MX_TIM2_Init();

  MX_FREERTOS_Init();
  osKernelStart();
  while (1)
  {


  }


}

void SystemClock_Config(void)
{

  RCC_OscInitTypeDef RCC_OscInitStruct;
  RCC_ClkInitTypeDef RCC_ClkInitStruct;
  RCC_PeriphCLKInitTypeDef PeriphClkInit;

    /**Initializes the CPU, AHB and APB busses clocks
    */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  RCC_OscInitStruct.Prediv1Source = RCC_PREDIV1_SOURCE_HSE;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
  RCC_OscInitStruct.PLL2.PLL2State = RCC_PLL_NONE;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  {
    Error_Handler();
  }

    /**Initializes the CPU, AHB and APB busses clocks
    */
  RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
                              |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
  {
    Error_Handler();
  }

  PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_ADC;
  PeriphClkInit.AdcClockSelection = RCC_ADCPCLK2_DIV6;
  if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
  {
    Error_Handler();
  }

    /**Configure the Systick interrupt time
    */
  HAL_SYSTICK_Config(HAL_RCC_GetHCLKFreq()/1000);

    /**Configure the Systick
    */
  HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK);

    /**Configure the Systick interrupt time
    */
  __HAL_RCC_PLLI2S_ENABLE();

  /* SysTick_IRQn interrupt configuration */
  HAL_NVIC_SetPriority(SysTick_IRQn, 15, 0);
}

unsigned char counter;
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{

  if (htim->Instance == TIM1) {
    HAL_IncTick();
  }
    if (htim->Instance == TIM2) {
        counter++;
        if(counter>=0xffff){
            counter=0;
            flashdata();
        }
        
     }

}

void Error_Handler(void)
{
  while(1)  {  }

}
#ifdef USE_FULL_ASSERT
void assert_failed(uint8_t* file, uint32_t line)
{}

#endif



0 0 收起

我来回答

上传资料:
选择文件 文件大小不超过15M(格式支持:doc、ppt、xls、pdf、zip、rar、txt)
最佳答案
  • 你的counter是个unsigned char 的类型,不会大于0xffff的。

    你要设置为unsigned short int ,或是unsigned int 的。

    • 发布于 2017-06-02
    • 举报
    • 评论 0
    • 0
    • 0

其他答案 数量:5
  • unsigned char在C语言中表示的是无符号的字符型,对应的整数范围为0~255.


    255相当于16进制的0XFF,因此它最多只能是两位,不能是四位


    你这里最好用一个长整形的

    • 发布于2017-06-02
    • 举报
    • 评论 0
    • 0
    • 0

  • unsigned char 范围0至255,即0x00至0xff

    如果函数形参采用unsigned char,而传过来的实参大于255,则高八位会自动被系统舍弃,只留下低八位,比如传过来0xabcd,到了函数里面就变成0xcd。


    • 发布于2017-06-02
    • 举报
    • 评论 0
    • 0
    • 0

  • unsigned char 对应的整数范围为0~255. ​ 是不可能大于0xffff这个数的 这个逻辑根本执行不到的

    • 发布于2017-06-02
    • 举报
    • 评论 0
    • 0
    • 0

  • 不懂你的无法运行是什么意思,程序可以烧录进去,但是没有效果么?
    • 发布于2017-06-02
    • 举报
    • 评论 0
    • 0
    • 0

  • 不懂您的做法?


        if (htim->Instance == TIM2) {
            counter++;
            if(counter>=0xffff){
                counter=0;
                flashdata();
            }
            
         }
    這段其實不需要,您只需要一個SysTick就好(因為您是跑FreeRTOS)

    然後用Systick的計數值來計算條件發生即可,當然型別也是一個問題, unsigned char只到0xff

    所以還需要您本人來說您要什麼功能...

    以上

    • 发布于2017-06-03
    • 举报
    • 评论 0
    • 0
    • 0

相关问题

问题达人换一批

如下程序,无法运行flashdata函数。