在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

GD32開發實戰指南(基礎篇) 第9章 呼吸燈

嵌入式大雜燴 ? 2023-05-12 22:22 ? 次閱讀

開發環境:

MDK:Keil 5.30

開發板:GD32F207I-EVAL

MCU:GD32F207IK

1 呼吸燈的工作原理

呼吸燈,就是指燈光設備的亮度隨著時間由暗到亮逐漸增強,再由亮到暗逐漸衰減,很有節奏感地一起一伏,就像是在呼吸一樣,因而被廣泛應用于手機電腦電子設備的指示燈中。

要使用數字器件控制燈光的強弱,我們很自然就想到 PWM(脈沖寬度調制)技術。假如以LED 作為燈光設備,且由控制器輸出的 PWM 信號可以直接驅動 LED,PWM 信號中的低電平可點亮 LED 燈。當 LED 以較高的頻率進行開關(亮滅)切換時,由于視覺暫留效應,人眼是看不到 LED 燈的閃爍現象的,反映到人眼中能感覺到的是亮度的差別。即以一定的時間長度為周期,LED 燈亮的平均時間越長,亮度就越高,反之越暗。因此,我們可以使用高頻率的 PWM 信號,通過調制信號的占空比,控制 LED 燈的亮度。

那么具體我們應該控制 LED 燈以怎樣的亮度曲線變化能夠達到最好的效果呢?亮度隨著時間逐漸變強再衰減,可以用兩種常見的數學函數表示,分別是半個周期的正弦函數與指數上升曲線及其對稱得到的下降曲線。

1683894862773yoqqladc47

相對來說,使用下凹函數曲線燈光處于暗的狀態更長,所以指數函數的曲線更符合我們呼吸燈的亮度變化要求。

2 呼吸燈實現

2.1 簡單方式

筆者先用最簡單的方式來實現,也就是定時改變比較寄存器的值。

1.初始化 GPIO

下面分析具體的定時器配置代碼。本實驗使用 PB0 作為定時器 PWM 輸出通道,先對它進行初始化。作 PWM 輸出通道的引腳需要被配置為復用推挽輸出模式。

/*
    brief      configure PWM GPIO
    param[in]  none
    param[out] none
    retval     none
*/
static void timer_gpio_init(void)
{
    rcu_periph_clock_enable(RCU_GPIOB);
    rcu_periph_clock_enable(RCU_AF);

    /* Configure PB0 (TIMER2 CH2) as alternate function */
    gpio_init(GPIOB, GPIO_MODE_AF_PP, GPIO_OSPEED_50MHZ, GPIO_PIN_0);
}

2.配置定時器模式

在timer2_init()函數中,完成了呼吸燈所需要的定時器 PWM 輸出模式配置。

/*
    brief      configure the Breath LED peripheral
    param[in]  none
    param[out] none
    retval     none
  */
void breath_led_init(void)
{
    /* TIMER2 configuration: generate PWM signals with different duty cycles:
       TIMER2CLK = SystemCoreClock / 120 = 1MHz */
    timer_oc_parameter_struct timer_ocintpara;
    timer_parameter_struct timer_initpara;

    /* configure the GPIO ports */
    timer_gpio_init();

    rcu_periph_clock_enable(RCU_TIMER2);

    timer_deinit(TIMER2);

    /* TIMER1 configuration */
    timer_initpara.prescaler         = 119;
    timer_initpara.alignedmode       = TIMER_COUNTER_EDGE;
    timer_initpara.counterdirection  = TIMER_COUNTER_UP;
    timer_initpara.period            = 250;
    timer_initpara.clockdivision     = TIMER_CKDIV_DIV1;
    timer_initpara.repetitioncounter = 0;
    timer_init(TIMER2, &timer_initpara);

    /* CH0 configuration in PWM mode 0 */
    timer_ocintpara.outputstate  = TIMER_CCX_ENABLE;
    timer_ocintpara.outputnstate = TIMER_CCXN_DISABLE;
    timer_ocintpara.ocpolarity   = TIMER_OC_POLARITY_HIGH;
    timer_ocintpara.ocnpolarity  = TIMER_OCN_POLARITY_HIGH;
    timer_ocintpara.ocidlestate  = TIMER_OC_IDLE_STATE_LOW;
    timer_ocintpara.ocnidlestate = TIMER_OCN_IDLE_STATE_LOW;

    timer_channel_output_config(TIMER2, TIMER_CH_2, &timer_ocintpara);

    /* CH0 configuration in PWM mode 0,duty cycle 25% */
    timer_channel_output_pulse_value_config(TIMER2, TIMER_CH_2, 0);
    timer_channel_output_mode_config(TIMER2, TIMER_CH_2, TIMER_OC_MODE_PWM0);
    timer_channel_output_shadow_config(TIMER2, TIMER_CH_2, TIMER_OC_SHADOW_DISABLE);

    /* auto-reload preload enable */
    timer_auto_reload_shadow_enable(TIMER2);
    /* TIMER2 enable */
    timer_enable(TIMER2);
}

這個定時器的模式配置主要分為三個部分,分別為時基初始化,輸出模式初始化。

  • 時基初始化

代碼中前面的部分是定時器的時基初始化,這部分主要負責配置定時器的定時周期、時鐘頻率、計數方式等。它使用到庫函數timer_init()函數,利用結構體timer_parameter_struct進行配置,該結構體有以下成員:

  1. period

定時周期,實質是存儲到重載寄存器CAR的數值,脈沖計數器從 0 累加到這個值上溢或從這個值自減至 0 下溢。這個數值加 1 然后乘以時鐘源周期就是實際定時周期。

本實驗中向該成員賦值為 255,即定時周期為(255+1)* T ,T 為定時器的時鐘周期。

  1. prescaler

對定時器時鐘CLK 的預分頻值,分頻后作為脈沖計數器TIMERx_CNT的驅動時鐘,得到脈沖計數器的時鐘頻率為:CNT=CLK/(N+1),其中 N 為即為賦給本成員的時鐘分頻值。

本實驗給 prescaler 成員賦值為 119,即對時鐘 120 分頻,所以定時器的時鐘周期 T 為 120/120000000。

  1. clockdivision

時鐘分頻因子。怎么又出現一個配置時鐘分頻的呢?要注意這個clockdivision和上面的 prescaler 是不一樣的。prescaler 預分頻配置是對CLK進行分頻,分頻后的時鐘被輸出到脈沖計數器CNT。

本實驗中是使用內部時鐘CLK 作為定時器時鐘源的,沒有進行濾波所以配置clockdivision為任何數值都沒有影響。

  1. alignedmode

本成員配置的為脈沖計數器 CNT 的計數模式,分別為向上計數,向下計數,及中央對齊模式。向上計數即 CNT 從 0 向上累加到 period 中的值,(重載寄存器 CAR 的值),產生上溢事件;向下計數則 CNT 從period 的值累減至0,產生下溢事件。而中央對齊模式則為向上、向下計數的合體,CNT 從 0 累加到period 的值減 1 時,產生一個上溢事件,然后向下計數到 1 時,產生一個計數器下溢事件,再從 0 開始重新計數。

  • 輸出模式配置

在本函數代碼的后面是關于定時器的輸出模式配置的。通用定時器的輸出模式由 timer_oc_parameter_struct類型結構體的主要有以下幾個成員:

  1. outputstate

配置輸出模式的狀態使能或關閉輸出。

  1. outputnstate

本成員的參數值即為比較寄存器 CH2CV的數值,當脈沖計數器CNT與CH2CV的比較結果發生變化時,輸出脈沖將發生跳變。

  1. ocpolarity

有效電平的極性,把 PWM 模式中的有效電平設置為高電平或低電平。

本實驗中向該成員賦值為 TIMER_OC_POLARITY_LOW (有效電平為低電平),因為在上面把輸出模式配置為 PWM0 模式,向上計數,所以在 CNT< CH0CV 時,通道 n 輸出為低電平,否則為高電平。

  1. ocnpolarity

用于比較有效電平的極性。

本實驗中就是通過不斷改變比較寄存器CH2CV的值,達到控制 PWM 信號的占空比呈指數曲線變化的目的。在本函數代碼中,我們對該成員賦予初始為 0,而改變比較寄存器 CH0CV 值的操作是在中斷服務函數中修改的。填充完輸出模式初始化結構體后,調用輸出模式初始化函數 timer_channel_output_config()對通道進行初始化。

以上是最基本的PWM輸出調制實現呼吸燈。

筆者接下來還要講解一下重映射的輸出配置。在這里講解的是通過重映射 TIMER2_CH2到 PB0 上,由 TIMER2_CH2 輸出 PWM 來控制LED的亮度。下面我們介紹通過庫函數來配置該功能的步驟。

1)開啟 TIMER2時鐘以及復用功能時鐘,配置 PB0為復用輸出。

要使用 TIMER2,我們必須先開啟 TIMER2的時鐘,這點相信大家看了這么多代碼,應該明白了。這里我們還要配置 PB0為復用輸出,此時,PB0屬于復用功能輸出。在此只列出庫函數設置 AFIO 時鐘的方法。

rcu_periph_clock_enable(RCU_AF);

其余的和前面的配置一樣,就不再列出了。

2)初始化 TIMER2,設置 TIMER2的 CAR 和 PSC。

3)設置 TIMER2_CH2 的 PWM 模式,使能 TIMER2的 CH2 輸出。

4)使能 TIMER2。

在完成以上設置了之后,我們需要使能 TIMER2。 使能 TIMER2的方法前面已經講解過:

timer_enable(TIMER2);

5)修改 TIMER2_ CH2CV來控制占空比。

最后,在經過以上設置之后, PWM 其實已經開始輸出了,只是其占空比和頻率都是固定的,而我們通過修改 TIMER2_CH2CV則可以控制 CH2 的輸出占空比。繼而控制LED的亮度。在庫函數中,修改 TIMER2_CH2CV占空比的函數是:

void timer_channel_output_pulse_value_config(uint32_t timer_periph, uint16_t channel, uint32_t pulse)

通過以上5個步驟,我們就可以控制 TIMER2的 CH2 輸出 PWM 波了。

接下來看看主函數的代碼:

/*
    brief      main function
    param[in]  none
    param[out] none
    retval     none
*/
int main(void)
{
    uint16_t i = 0;
    FlagStatus breathe_flag = SET;

    //systick init
    sysTick_init();

    /* configure the Breath LED peripheral */
    breath_led_init();

    while(1)
    {
        /* delay a time in milliseconds */
        delay_ms(5);
        if(SET == breathe_flag) 
        {
            i++;
        }
        else
        {
            i--;
        }
        if(250 < i)
        {
            breathe_flag = RESET;
        }
        if(0 >= i)
        {
            breathe_flag = SET;
        }
        /* configure TIMER channel output pulse value */
        //timer_channel_output_pulse_value_config(TIMER2, TIMER_CH_2, i);
        TIMER_CH2CV(TIMER2) = (uint32_t)i;
    }
}

代碼很簡單,就是不斷改變CH2CV的值從而控制 CH2 的輸出占空比。

2.2 中斷方式

1.生成指數曲線 PWM 數據

要實現 LED 亮度隨著指數曲線變化,我們需要使用占空比呈指數曲線變化的 PWM 信號,而這樣的信號由定時器經過查表產生。這個表的數據存儲在程序中的數組 indexWave中。

uint8_t indexWave[] = {1,1,2,2,3,4,6,8,10,14,19,25,33,44,59,80,
107,143,191,255,255,191,143,107,80,59,44,33,25,19,14,10,8,6,4,3,2,2,1,1};

這個表有 40 個數字,從圖中可以看到這些數字呈指數上升再衰減,正好是呼吸燈的一個控制周期。數字的大小范圍是 0255,即把 LED 的亮度分為了 0255 個等級。

假如我們把定時器的脈沖計數器 CNT 上限設置為 255,把這個表的數據一個一個地賦值到定時器的比較寄存器CH2CV中,那么在每個 PWM 周期中,當 CNT的計數值小于比較寄存器 CH2CV的值時, 就會在通道中輸出低電平,點亮 LED,而隨著 CCR 的值由 LED 亮度表得來,所以 LED 點亮的時間就會呈圖中的曲線變化,實現呼吸燈的功能。

這個表的數據是使用 matlab 軟件生成的。該代碼運行后會生成一個“index_wave.c”的文件,用戶把該文件中的數據復制到工程中的數組中即可。

%本代碼用于產生呼吸燈使用的指數函數數據
clear;

x = [0 : 8/19 : 8];       %設置序列 ,指數上升
up = 2.^x ;               %求上升指數序列  
up = uint8(up);           %化為8位數據

y = [8: -8/19 :0];       %設置序列 ,指數下降
down = 2.^y ;            %求下降指數序列
down = uint8(down);      %化為8位數據

line = [[0:8/19:8],[8:8/19:16]]         %拼接序列
val = [up , down]                       %拼接輸出序列

dlmwrite('index_wave.c',val);       %輸出到文件index_wave.c
plot(line,val,'.');                 %顯示波形圖

2.初始化 GPIO

這部分和前面的一樣,沒啥好說的。

3.配置定時器模式

這里也差不多,只是將分頻系數設置的稍微大些,另外開啟了中斷。

/*
    brief      configure the Breath LED peripheral
    param[in]  none
    param[out] none
    retval     none
  */
void breath_led_init(void)
{
    /* TIMER2 configuration: generate PWM signals with different duty cycles*/
    timer_oc_parameter_struct timer_ocintpara;
    timer_parameter_struct timer_initpara;

    /* configure the GPIO ports */
    timer_gpio_init();

    rcu_periph_clock_enable(RCU_TIMER2);

    timer_deinit(TIMER2);

    /* TIMER2 configuration */
    timer_initpara.prescaler         = 3999;
    timer_initpara.alignedmode       = TIMER_COUNTER_EDGE;
    timer_initpara.counterdirection  = TIMER_COUNTER_UP;
    timer_initpara.period            = 255;
    timer_initpara.clockdivision     = TIMER_CKDIV_DIV1;
    timer_initpara.repetitioncounter = 0;
    timer_init(TIMER2, &timer_initpara);

    /* CH2 configuration in PWM mode 0 */
    timer_ocintpara.outputstate  = TIMER_CCX_ENABLE;
    timer_ocintpara.outputnstate = TIMER_CCXN_DISABLE;
    timer_ocintpara.ocpolarity   = TIMER_OC_POLARITY_HIGH;
    timer_ocintpara.ocnpolarity  = TIMER_OCN_POLARITY_HIGH;
    timer_ocintpara.ocidlestate  = TIMER_OC_IDLE_STATE_LOW;
    timer_ocintpara.ocnidlestate = TIMER_OCN_IDLE_STATE_LOW;

    timer_channel_output_config(TIMER2, TIMER_CH_2, &timer_ocintpara);

    /* CH2 configuration in PWM mode 0,duty cycle 25% */
    timer_channel_output_pulse_value_config(TIMER2, TIMER_CH_2, 0);
    timer_channel_output_mode_config(TIMER2, TIMER_CH_2, TIMER_OC_MODE_PWM0);
    timer_channel_output_shadow_config(TIMER2, TIMER_CH_2, TIMER_OC_SHADOW_DISABLE);

    /* auto-reload preload enable */
    timer_auto_reload_shadow_enable(TIMER2);

    /* Timer2 interrupt setting, preemptive priority 0, sub-priority 2 */
    nvic_irq_enable(TIMER2_IRQn, 0, 2); 

    /* Enable Timer2 update interrupt */
    timer_interrupt_enable(TIMER2, TIMER_INT_UP);

    /* TIMER2 enable */
    timer_enable(TIMER2);
}

配置好中斷,下面就要編寫中斷服務函數。

/*!
    \\brief      this function handles TIMER2 exception
    \\param[in]  none
    \\param[out] none
    \\retval     none
*/
void TIMER2_IRQHandler(void)
{
    static uint8_t pwm_index = 0; //用于PWM查表
    static uint8_t period_cnt = 0; //用于計算周期數
	
    if(timer_interrupt_flag_get(TIMER2, TIMER_INT_FLAG_UP))
    {
        /* 清除TIMER2 中斷標志位 */
        timer_interrupt_flag_clear(TIMER2, TIMER_INT_FLAG_UP);

        period_cnt++;
        if(period_cnt >= 10)	//若輸出的周期數大于10,輸出下一種脈沖寬的PWM波
        {
            //根據PWM表修改定時器的比較寄存器值
            TIMER_CH2CV(TIMER2) = indexWave[pwm_index];
            pwm_index++; //標志PWM表的下一個元素
            //若PWM脈沖表已經輸出完成一遍,重置PWM查表標志
            if( pwm_index >=  40)	
            {
                pwm_index=0;
            }
            period_cnt=0; //重置周期計數標志
        }
    }
}

本中斷服務函數在每次定時器更新事件發生時執行一次(即 256 個定時器時鐘周期)。函數中使用了靜態變量 pwm_index 和 period_cnt,它們分別用來查找 PWM 表元素和記錄同樣占空比的脈沖輸出了多少次。

本代碼的目的是每 10 次定時器中斷更新一次 PWM 表中的數據到比較寄存器中,當遍歷完 PWM 表的 40 個元素時,再重頭開始遍歷 PWM 表,周而復始,重復 LED 的呼吸過程。

整個呼吸過程的時間計算方法如下:

因為定時器的 prescaler 設置為 3999;

所以定時器的時鐘頻率:fTIMER = 120000000/(prescaler+1) = 30000 Hz

即定時器的時鐘周期為:tTIMER = 1/fTIMER = 1/30000 s

因為定時器的 period 設置為 255;

所以定時器的中斷周期為:tint= tTIMER * (period+1) =0.00753s

因為 PWM 表有 pwm_index = 40 個亮度占空比數據,同種占空比信號輸出 period_cnt =10 次

所以一個呼吸周期 T = tint *40 *10 = 3.41s

3 呼吸燈的實驗現象

將程序編譯好下載到板子中,將PF6接到PB0上,可一看到LED1像呼吸一樣漸漸變明或者漸漸變暗,但是方法二明顯比方法一更流暢,效果更好。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • Cortex-M
    +關注

    關注

    2

    文章

    229

    瀏覽量

    29761
  • 呼吸燈
    +關注

    關注

    10

    文章

    110

    瀏覽量

    42728
  • GD32
    +關注

    關注

    7

    文章

    403

    瀏覽量

    24351
收藏 人收藏

    評論

    相關推薦

    GD32開發實戰指南(基礎) 1 開發環境搭建

    開發環境: MDK:Keil 5.30 開發板:GD32F207I-EVAL MCU:GD32F207IK 1 GD32F207I-EVAL
    的頭像 發表于 05-07 23:35 ?1.1w次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>1<b class='flag-5'>章</b> <b class='flag-5'>開發</b>環境搭建

    GD32開發實戰指南(基礎) 4 GD32啟動流程詳解(Keil版)

    ,所有的一切都需要由開發者來設置,這里處理器是沒有堆棧,沒有中斷,更沒有外圍設備,這些工作是需要軟件來指定的,而且不同的CPU類型、不同大小的內存和不同種類的外設,其初始化工作都是不同的。本文將以GD32F207IK (基于Cortex-M3)為例進行講解。
    的頭像 發表于 05-10 09:00 ?1.7w次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>4<b class='flag-5'>章</b> <b class='flag-5'>GD32</b>啟動流程詳解(Keil版)

    GD32開發實戰指南(基礎) 7 定時器

    系統滴答定時器一般用來提供“心跳”作用,而GD32定時器最基本功能也是定時,可以設置不同時間長度的定時。定時器除了最基本的定時功能外,定時器與GPIO有掛鉤使得它可以發揮強大的作用,比如可以輸出
    的頭像 發表于 05-11 09:00 ?1.2w次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>7<b class='flag-5'>章</b> 定時器

    GD32開發實戰指南(基礎) 8 定時器

    開發環境: MDK:Keil 5.30 開發板:GD32F207I-EVAL MCU:GD32F207IK 1 PWM輸出的工作原理 脈沖寬度調制(PWM) ,是英文“Pulse Wi
    的頭像 發表于 05-12 22:14 ?7967次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>8<b class='flag-5'>章</b> 定時器

    GD32開發實戰指南(基礎) 11 CPU的高級代理-DMA

    或者存儲器和存儲器之間的高速數據傳輸,因而被廣泛地使用。早在 8086 的應用中就已經有 Intel 的 8237 這種典型的 DMA 控制器,而 GD32的 DMA 則是以類似外設的形式添加到 Cortex 內核之外的。可以說,DMA就是CPU的高級代理,DMA大大減輕了CPU的負擔。
    的頭像 發表于 05-16 08:59 ?3870次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>11<b class='flag-5'>章</b> CPU的高級代理-DMA

    GD32開發實戰指南(基礎) 12 ADC

    GD32F2系列有 3 個逐次逼近型的ADC,精度為 12 位,有18個多路復用通道,可以轉換來自16個外部通道和2個內部通道的模擬信號。其中ADC0 和 ADC1都有 16 個外部通道, ADC2
    的頭像 發表于 05-16 09:03 ?1.1w次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>12<b class='flag-5'>章</b> ADC

    GD32開發實戰指南(基礎) 14 內部溫度傳感器

    GD32 有一個內部的溫度傳感器,可以用來測量 CPU 及周圍的溫度(TA)。該溫度傳感器在內部和 ADCx_IN16 輸入通道相連接,此通道把傳感器輸出的電壓轉換成數字值。溫度傳感器模擬輸入
    的頭像 發表于 05-17 08:58 ?5370次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>14<b class='flag-5'>章</b> 內部溫度傳感器

    GD32開發實戰指南(基礎) 15 低功耗

    GD32的工作電壓(VDD)為2.0~3.6V。通過內置的電壓調節器提供所需的1.8V電源。當主電源VDD掉電后,通過VBAT腳為實時時鐘(RTC)和備份寄存器提供電源。
    的頭像 發表于 05-17 08:59 ?8069次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>15<b class='flag-5'>章</b> 低功耗

    GD32開發實戰指南(基礎) 16 RTC

    開發環境: MDK:Keil 5.30 開發板:GD32F207I-EVAL MCU:GD32F207IK 1 RTC工作原理 1.1 RTC簡介
    的頭像 發表于 05-18 22:14 ?7180次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>16<b class='flag-5'>章</b> RTC

    GD32開發實戰指南(基礎) 17 看門狗

    開發環境: MDK:Keil 5.30 開發板:GD32F207I-EVAL MCU:GD32F207IK GD32 有兩個看門狗, 一個是
    的頭像 發表于 06-03 16:00 ?1.1w次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>17<b class='flag-5'>章</b> 看門狗

    【圖書分享】《STM32庫開發實戰指南

    GPIO入門之流水燈 4 深入分析流水燈例程 5 調試程序第二部分 庫開發中級 
    發表于 03-13 17:01

    Arduino開發實戰指南 AVR

    模塊的應用第三應用8打造自己的遙控履帶車9
    發表于 08-03 16:14

    GD32 MCU原理及固件庫開發指南》 + 初讀感悟

    GD32 MCU原理固件庫開發指南這本書內容豐富,囊括了GD32中的所有外設,書中首先介紹了如何使用MDK或IAR軟件搭建GD32工程環境,讓初學者能快速基于工程上手編程。書中主要對
    發表于 03-31 22:11

    GD32 MCU原理及固件庫開發指南》+讀后感

    。 2介紹GD32 MCU快速入門與開發平臺搭建的方法,包括對軟硬件開發平臺、調試工具、GD32
    發表于 06-06 21:52

    GD32開發實戰指南(基礎) 19 程序加密

    GD32通過讀取芯片唯一ID號來實現程序的保護,防止被抄襲。96位的產品唯一身份標識所提供的參考號碼對任意一個GD32微控制器
    的頭像 發表于 05-20 09:10 ?4154次閱讀
    <b class='flag-5'>GD32</b><b class='flag-5'>開發</b><b class='flag-5'>實戰</b><b class='flag-5'>指南</b>(基礎<b class='flag-5'>篇</b>) <b class='flag-5'>第</b>19<b class='flag-5'>章</b> 程序加密
    主站蜘蛛池模板: 三级a黄| 中文天堂在线最新2022更新| 在线免费视频国产| 欧美三级欧美一级| 午夜影院日韩| 高清欧美性xxxx成熟| 婷婷六月综合| 成人在线91| 日本xxxxxxxxx69| 五月激情婷婷丁香| 丁香花五月婷婷| 亚洲 另类色区 欧美日韩| 亚洲综合色站| 国产乱辈通伦影片在线播放 | 中国日韩欧美中文日韩欧美色| 欧美一区福利| 色之综合天天综合色天天棕色| 深夜动态福利gif进出粗暴| 日本xxxx色视频在线观看免 | 美国bj69| 日本特级黄色大片| 天天视频官网天天视频在线| 日本不卡视频一区二区| 毛片黄| www激情com| 色婷婷免费视频| 天天做天天爱天天射| 久久精品第一页| 国内一级毛片| 女人69xxx| 欧美一级高清片欧美国产欧美| 日本激情网| 一级毛片在线免费视频| 成 年 人 视频在线播放| caoporn成人免费公开| 欧美网站色| 国产午夜视频| 色01视频| 国产一级免费视频| 上海一级毛片| 免费看欧美一级片|