日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

3天內不再提示

在STM32上實現(xiàn)驅動注冊initcall機制

STM32嵌入式開發(fā) ? 來源:STM32嵌入式開發(fā) ? 2023-07-02 10:26 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、前言

每個硬件如LED控制,GPIO口需要初始化,初始化函數(shù)bsp_led_init();這個函數(shù)需要在主函數(shù)中調用初始化,類似這樣:

void bsp_init(void)
{
    bsp_rcc_init();
    bsp_tick_init();
    bsp_led_init();
    bsp_usart_init();
}

這樣存在的問題是:

當有很對驅動,加入100個硬件驅動,我們只用到了了50個,剩下的源文件不參與編譯,此時如果忘記將主函數(shù)中的相應初始化刪除,就會報錯。這樣操作很麻煩,不能很好的實現(xiàn)單個驅動文件的隔離。 那么現(xiàn)在就提供解決此問題的方式。這個方式源自于Linux內核--initcall機制。具體講解網絡上很多,在此不在詳細說明。 可閱讀:

二、代碼

頭文件:

#ifndef _COLA_INIT_H_
#define _COLA_INIT_H_
 
 
#define  __used  __attribute__((__used__))
 
typedef void (*initcall_t)(void);
 
#define __define_initcall(fn, id) 
    static const initcall_t __initcall_##fn##id __used 
    __attribute__((__section__("initcall" #id "init"))) = fn; 
 
#define pure_initcall(fn)       __define_initcall(fn, 0) //可用作系統(tǒng)時鐘初始化  
#define fs_initcall(fn)         __define_initcall(fn, 1) //tick和調試接口初始化
#define device_initcall(fn)     __define_initcall(fn, 2) //驅動初始化
#define late_initcall(fn)       __define_initcall(fn, 3) //其他初始化
    
 
void do_init_call(void);
    
#endif 

源文件:

#include "cola_init.h"
 
 
 
void do_init_call(void)
{
    extern initcall_t initcall0init$$Base[];
    extern initcall_t initcall0init$$Limit[];
    extern initcall_t initcall1init$$Base[];
    extern initcall_t initcall1init$$Limit[];
    extern initcall_t initcall2init$$Base[];
    extern initcall_t initcall2init$$Limit[];
    extern initcall_t initcall3init$$Base[];
    extern initcall_t initcall3init$$Limit[];
    
    initcall_t *fn;
    
    for (fn = initcall0init$$Base;
            fn < initcall0init$$Limit;
            fn++)
    {
        if(fn)
            (*fn)();
    }
    
    for (fn = initcall1init$$Base;
            fn < initcall1init$$Limit;
            fn++)
    {
        if(fn)
            (*fn)();
    }
    
    for (fn = initcall2init$$Base;
            fn < initcall2init$$Limit;
            fn++)
    {
        if(fn)
            (*fn)();
    }
    
    for (fn = initcall3init$$Base;
            fn < initcall3init$$Limit;
            fn++)
    {
        if(fn)
            (*fn)();
    }
       
}

在主進程中調用void do_init_call(void)進行驅動初始化,驅動注冊初始化時調用:

 pure_initcall(fn)        //可用作系統(tǒng)時鐘初始化  
 fs_initcall(fn)          //tick和調試接口初始化
 device_initcall(fn)      //驅動初始化
 late_initcall(fn)

舉個例子:

static void led_register(void)
{
    led_gpio_init();
    led_dev.dops = &ops;
    led_dev.name = "led";
    cola_device_register(&led_dev);
}
 
device_initcall(led_register);

這樣頭文件中就沒有有對外的接口函數(shù)了。

三、代碼

gitee:

https://gitee.com/schuck/cola_os

girhub:

https://github.com/sckuck-bit/cola_os

審核編輯:湯梓紅

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

    關注

    244

    文章

    24733

    瀏覽量

    692701
  • STM32
    +關注

    關注

    2313

    文章

    11196

    瀏覽量

    374772
  • 函數(shù)
    +關注

    關注

    3

    文章

    4423

    瀏覽量

    67884
  • 代碼
    +關注

    關注

    30

    文章

    4977

    瀏覽量

    74427
  • GPIO
    +關注

    關注

    16

    文章

    1334

    瀏覽量

    56490

原文標題:在STM32上實現(xiàn)驅動注冊initcall機制

文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發(fā)】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    請問基于GCC編譯器的initcallSTM32如何實現(xiàn)?

    請問各位基于GCC編譯器的initcallSTM32如何實現(xiàn)?有哪位實現(xiàn)了嗎?
    發(fā)表于 03-13 06:24

    嵌入式linux 串口console注冊

    是__con_initcall_start,該段中的所有函數(shù)driver\tty\tty_io.c\console_init函數(shù)中調用,console_initstart_kernel函數(shù)中被調用. console的
    發(fā)表于 03-05 13:53

    Linux的platform機制開發(fā)驅動流程是怎么樣的?

    從Linux 2.6起引入了一套新的驅動管理和注冊機制:platform_device和platform_driver。Linux中大部分的設備驅動,都可以使用這套機制,設備用plat
    發(fā)表于 09-23 07:31

    Delphi教程之軟件注冊機制的建立

    Delphi教程之軟件注冊機制的建立,很好的Delphi資料,快來下載吧。
    發(fā)表于 04-11 16:09 ?5次下載

    C#教程之注冊注冊機制

    C#教程之注冊注冊機制,很好的C#資料,快來學習吧。
    發(fā)表于 04-21 09:52 ?17次下載

    基于STM32單片機低功耗模式機制詳細解析

    本文主要解讀STM32低功耗模式的機制,并不側重STM32低功耗的程序實現(xiàn),而且借助STM32固件庫實現(xiàn)
    發(fā)表于 10-24 16:16 ?2w次閱讀
    基于<b class='flag-5'>STM32</b>單片機低功耗模式<b class='flag-5'>機制</b>詳細解析

    Linux內核驅動的platform機制是怎樣的

    從Linux 2.6起引入了一套新的驅動管理和注冊機制:platform_device和platform_driver。
    發(fā)表于 11-06 14:12 ?2175次閱讀
    Linux內核<b class='flag-5'>驅動</b>的platform<b class='flag-5'>機制</b>是怎樣的

    STM32H743芯片實現(xiàn)CAN通信的步驟

    本篇筆記主要介紹,STM32H743芯片實現(xiàn)CAN通信,封裝為BSP驅動,為之后實現(xiàn)CAN的
    的頭像 發(fā)表于 09-14 14:33 ?1.9w次閱讀
    <b class='flag-5'>在</b><b class='flag-5'>STM32</b>H743芯片<b class='flag-5'>上</b><b class='flag-5'>實現(xiàn)</b>CAN通信的步驟

    基于 RT-Thread STM32 實現(xiàn) USB 虛擬串口

    之前由于工作需要,基于 RT-Thread STM32 實現(xiàn)了 USB 虛擬串口。為了方便大家,我在這里把正點原子 F429 阿波羅
    發(fā)表于 02-10 10:28 ?9次下載
    基于 RT-Thread <b class='flag-5'>在</b> <b class='flag-5'>STM32</b> <b class='flag-5'>上</b><b class='flag-5'>實現(xiàn)</b> USB 虛擬串口

    stm32_FSMC機制

    stm32_FSMC機制,介紹FSMC機制入門
    發(fā)表于 02-21 15:16 ?19次下載

    嵌入式函數(shù)回調注冊機制實現(xiàn)

    嵌入式函數(shù)回調注冊機制是一種常用的解耦技術,它通過應用程序中注冊回調函數(shù)的方式來實現(xiàn)模塊之間的通信,從而使系統(tǒng)更加靈活、可擴展和易于維護。函數(shù)回調
    的頭像 發(fā)表于 04-13 15:52 ?2457次閱讀

    什么是函數(shù)回調注冊機制?實現(xiàn)的大致步驟介紹

    嵌入式函數(shù)回調注冊機制是一種常用的解耦技術,它通過應用程序中注冊回調函數(shù)的方式來實現(xiàn)模塊之間的通信
    的頭像 發(fā)表于 05-20 16:43 ?6000次閱讀

    initcall實現(xiàn)原理和調試方法介紹

    linux kernel啟動過程中,通過initcall機制調用初始化函數(shù)。initcall作為kernel經典設計機制之一延續(xù)至今。
    的頭像 發(fā)表于 06-05 11:38 ?2486次閱讀
    <b class='flag-5'>initcall</b><b class='flag-5'>實現(xiàn)</b>原理和調試方法介紹

    如何解決引入注冊機制問題

    耦合狀態(tài),失去了一個.c 一個 .h的意義。 如何解決這種問題 ????引入注冊機制。為了方便說明注冊機制,舉一個例子:手機使用相機這個功能時,有一個操作:將拍攝的照片發(fā)送出去。以程序來實現(xiàn)
    的頭像 發(fā)表于 08-16 09:17 ?1478次閱讀

    基于表驅動的健康監(jiān)控機制實現(xiàn)方法

    電子發(fā)燒友網站提供《基于表驅動的健康監(jiān)控機制實現(xiàn)方法.pdf》資料免費下載
    發(fā)表于 11-06 10:09 ?0次下載
    基于表<b class='flag-5'>驅動</b>的健康監(jiān)控<b class='flag-5'>機制</b><b class='flag-5'>實現(xiàn)</b>方法
    邯郸县| 莱州市| 栾城县| 彰武县| 花莲市| 金乡县| 同仁县| 瓦房店市| 寻甸| 辰溪县| 抚宁县| 紫金县| 开鲁县| 渭源县| 金昌市| 花莲县| 镇坪县| 刚察县| 湖南省| 金塔县| 饶平县| 平南县| 富源县| 栾城县| 盐城市| 水富县| 左贡县| 惠州市| 墨脱县| 文昌市| 金山区| 云和县| 石台县| 乡宁县| 郎溪县| 开封市| 东丰县| 城固县| 深水埗区| 沈丘县| 武川县|