0

RTX RTOS を搭載した STM32F1x ボードでプロジェクトに取り組んでおり、ユーザー入力を処理するために外部割り込みが必要です。このため、ピン A.0 の入力で動作するように外部割り込みを有効にしました。

/* Handle PA0 interrupt: user input */
__irq void EXTI0_IRQHandler(void) {
     /* Make sure that interrupt flag is set */
     if (EXTI_GetITStatus(EXTI_Line0) != RESET) {
         isr_evt_set(0x0003, task1);
         EXTI_ClearITPendingBit(EXTI_Line0);
     }
}

__task void task1(void) {
     OS_RESULT result;
     unsigned int i;
     while(1) {
         result = os_evt_wait_or(0x0003, 0xFFFF);
         if (result == OS_R_TMO)
         {
            // event not received
            counter--;  // variable used for debugging purposes
         }
         else
         {
         // event received
            counter++;
     }
}

ただし、GPIOA.0 ピンに入力を与えるたびに、ロジック アナライザーで確認できる奇妙な動作が発生します (他のすべての定期的なタスクの実行が停止し、フラットラインになります)。編集: 詳細情報を提供するには: このコードは、ハンドラー内に配置された LED トグル コードで動作します。

これが私のGPIO / EXTI構成です

void Configure_PA0(void) {
     /* PA0 */
     GPIO_InitTypeDef GPIO_InitStruct;
     EXTI_InitTypeDef EXTI_InitStruct;
     NVIC_InitTypeDef NVIC_InitStruct;

     /* Enable clock for GPIOA */
     /* Enable clock for GPIO */
     RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);

     /* Set pin 0 as input */
     GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN_FLOATING;
     GPIO_InitStruct.GPIO_Pin = GPIO_Pin_0;
     GPIO_Init(GPIOA, &GPIO_InitStruct);

     /* Tell system that you will use PDn for EXTI_Line n */
     GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource);

     /* PA0 is connected to EXTI_Line0 */
     EXTI_InitStruct.EXTI_Line = EXTI_Line0;
     /* Enable interrupt */
     EXTI_InitStruct.EXTI_LineCmd = ENABLE;
     /* Interrupt mode */
     EXTI_InitStruct.EXTI_Mode = EXTI_Mode_Interrupt;
     /* Triggers on rising and falling edge */
     EXTI_InitStruct.EXTI_Trigger = EXTI_Trigger_Rising_Falling;
     /* Add to EXTI */
     EXTI_Init(&EXTI_InitStruct);

     /* Add IRQ vector to NVIC */

     /* PA0 is connected to EXTI_Line0, which has EXTI0_IRQn vector */
     NVIC_InitStruct.NVIC_IRQChannel = EXTI0_IRQn;
     /* Set priority */
     NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 0x00;
     /* Set sub priority */
     NVIC_InitStruct.NVIC_IRQChannelSubPriority = 0x00;
     /* Enable interrupt */
     NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE;
     /* Add to NVIC */
     NVIC_Init(&NVIC_InitStruct);
}

私が間違っていることは何ですか?これを手伝ってくれる人に感謝します。

4

1 に答える 1

1

コードを少し調べたところ、何が問題なのかがわかりました。同じ問題に直面する可能性のある人たちと共有したいと思います。init タスク内にいくつかのタスクが作成され、このタスクの前にリストされていたとします。

init_task() {
  id_tsk0 = os_tsk_create(task1, 50);
  id_tsk1 = os_tsk_create(task2, 40);
  id_tsk2 = os_tsk_create(task3, 30);
  //...and the task I want to call from interrupt..
  id_tskn = os_tsk_create(taskn, 254);
}

taskN を最後の場所から最初の場所に移動したところ、動作するようになりました!

于 2020-01-29T13:33:24.600 に答える