Stm32 ইভেন্ট এবং বাধা দেয়


17

আমি stm32 বিশেষত stm32f4 আবিষ্কার বোর্ডে বিঘ্ন অধ্যয়ন শুরু করেছি। আমি এই উদাহরণটি পেয়েছি যাতে আপনাকে বাধাটি শুরু করতে বোতাম টিপতে হবে এবং এটি থামাতে আবার চাপ দিতে হবে।

এই লাইনে: এক্সটিআই_আইনটিস্ট্রাকশন.এক্সটিআই_মোড = এক্সটিআই_মোড_আন্তর বিপর্যয় আমাদের বাধা মোড বা ইভেন্ট মোড উভয়ই বেছে নিতে হবে। আমি এটিকে ইভেন্ট মোডে পরিবর্তন করেছি তবে এটি কাজ করছে বলে মনে হচ্ছে না o তাই আমি এই সিদ্ধান্তে উঠে এসেছি যে হ্যান্ডলারটি কেবলমাত্র বাধা দেয় exec

আমরা স্টেম 32 এ ইভেন্টগুলি কেন ব্যবহার করি যদি আপনি কিছু কোডগুলি ঘটে থাকে তবে তা সম্পাদন করতে পারেন না?

কোডটি এখানে:

        #include "stm32f4xx.h"
        #include "stm32f4xx_syscfg.h"
        #include "stm32f4xx_rcc.h"
        #include "stm32f4xx_gpio.h"
        #include "stm32f4xx_exti.h"
        #include "misc.h"



        EXTI_InitTypeDef   EXTI_InitStructure;

        void EXTILine0_Config(void);
        void LEDInit(void);


        void ExtInt(void)
        {

          LEDInit();

          /* Configure EXTI Line0 (connected to PA0 pin) in interrupt mode */
          EXTILine0_Config();

          /* Generate software interrupt: simulate a rising edge applied on EXTI0 line */
          EXTI_GenerateSWInterrupt(EXTI_Line0);

          while (1)
          {
          }
        }

        /**
          * @brief  Configures LED GPIO.
          * @param  None
          * @retval None
          */
        void LEDInit()
        {
          GPIO_InitTypeDef  GPIO_InitStructure;

          /* Enable the GPIO_LED Clock */
          RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);

          /* Configure the GPIO_LED pin */
          GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;
          GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
          GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
          GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
          GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
          GPIO_Init(GPIOD, &GPIO_InitStructure);
        }

        /**
          * @brief  Configures EXTI Line0 (connected to PA0 pin) in interrupt mode
          * @param  None
          * @retval None
          */
        void EXTILine0_Config(void)
        {

          GPIO_InitTypeDef   GPIO_InitStructure;
          NVIC_InitTypeDef   NVIC_InitStructure;

          /* Enable GPIOA clock */
          RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);
          /* Enable SYSCFG clock */
          RCC_APB2PeriphClockCmd(RCC_APB2Periph_SYSCFG, ENABLE);

          /* Configure PA0 pin as input floating */
          GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
          GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
          GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
          GPIO_Init(GPIOA, &GPIO_InitStructure);

          /* Connect EXTI Line0 to PA0 pin */
          SYSCFG_EXTILineConfig(EXTI_PortSourceGPIOA, EXTI_PinSource0);

          /* Configure EXTI Line0 */
          EXTI_InitStructure.EXTI_Line = EXTI_Line0;
          EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
          EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Rising;
          EXTI_InitStructure.EXTI_LineCmd = ENABLE;
          EXTI_Init(&EXTI_InitStructure);

          /* Enable and set EXTI Line0 Interrupt to the lowest priority */
          NVIC_InitStructure.NVIC_IRQChannel = EXTI0_IRQn;
          NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x01;
          NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x01;
          NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
          NVIC_Init(&NVIC_InitStructure);
        }

        /**
          * @brief  This function handles External line 0 interrupt request.
          * @param  None
          * @retval None
          */
        void EXTI0_IRQHandler(void)
        {
          if(EXTI_GetITStatus(EXTI_Line0) != RESET)
          {
            /* Toggle LED1 */
            GPIO_ToggleBits(GPIOD, GPIO_Pin_12);

            /* Clear the EXTI line 0 pending bit */
            EXTI_ClearITPendingBit(EXTI_Line0);
          }
        }

        /**
          * @}
          */

        /**
          * @}
          */

        /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/

        int main(void)
        {

            while(1)
            {
            }
        }

উত্তর:


14

কখনও কখনও কোনও এআরএম ডিভাইসের জন্য এই প্রশ্নের উত্তর সন্ধান করা সহজ মাইক্রোকন্ট্রোলারদের চেয়ে আরও কঠিন হতে পারে কারণ তথ্যটি প্রায়শই ডেটাশিটে অন্তর্ভুক্ত না করে পরিবার এবং প্রোগ্রামিং গাইডগুলিতে ছড়িয়ে পড়ে। এই ক্ষেত্রে উত্তরটি RM0090 রেফারেন্স ম্যানুয়ালটির 381 পৃষ্ঠায় প্রদর্শিত হবে :

মূল (ডাব্লুএফএই) জাগ্রত করার জন্য STM32F4xx বাহ্যিক বা অভ্যন্তরীণ ইভেন্টগুলি পরিচালনা করতে সক্ষম। জাগ্রত ইভেন্টটি এর দ্বারা উত্পন্ন করা যেতে পারে:

  • (আমি স্বাভাবিক বাহ্যিক বাধা মোডের বিশদটি সরিয়েছি)

  • বা ইভেন্ট মোডে একটি বাহ্যিক বা অভ্যন্তরীণ এক্সটিআই লাইনটি কনফিগার করা। যখন সিপিইউ ডাব্লুএফই থেকে পুনরায় শুরু হয়, পেরিফেরিয়াল বাধা বিঘ্নিত বিট বা এনভিসি আইআরকিউ চ্যানেলটি বিলের বিটটি বিভক্ত বিট সেট না হওয়ার কারণে পেরিফেরাল বিঘ্নিত বিটটি সাফ করার প্রয়োজন হয় না।

সুতরাং এটি প্রদর্শিত হয় মূল উদ্দেশ্যটি হ'ল জাগ্রতগুলি সক্ষম করা বাধা সৃষ্টি না করা বা স্বাভাবিক ক্রিয়াকলাপের সময় বিঘ্নিত হয়ে সাড়া না দেওয়া।

এটি গাইডে উল্লেখ করা হয়নি এবং আমি নিশ্চিত নই যে এসটিএম 32 আর্কিটেকচারের ক্ষেত্রে কতটা প্রযোজ্য তবে অন্যান্য কিছু ডিভাইসে অনুরূপ স্কিমগুলি বাধা সৃষ্টি না করে দ্রুত ইভেন্টগুলি ধরতে কার্যকর হতে পারে। উদাহরণস্বরূপ আপনার কাছে এমন একটি অ্যাপ্লিকেশন থাকতে পারে যেখানে সাব-মাইক্রোসেকেন্ড ঘটনা ঘটেছে তা ক্যাপচার করা গুরুত্বপূর্ণ, তবে এটির দ্রুত প্রতিক্রিয়া জানানোর দরকার নেই তাই এটি ঠিক আছে কিনা তা দেখার জন্য আপনি কেবল একটি পতাকা চেক করতে পারেন।

সম্পাদনা করুন: (5/2018) আজ অবধি, রেফারেন্সযুক্ত পাঠ্যের পৃষ্ঠা সংখ্যা 381 পৃষ্ঠা (পূর্বে পৃষ্ঠা 377)


1
হ্যাঁ, পিসিকগুলিতে এটি মনে হয় যে আমি একটি বিরতিতে যা করি তার অনেকগুলি পতাকা সেট থাকে। কর্টেক্সে, এই পতাকাগুলির বেশিরভাগই কোনও বাধা ছাড়াই সেট হয়ে যায়, তাই আমি কম বাধা ব্যবহার করি
স্কট সিডম্যান
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.