基于CMSIS的外设/设备驱动框架

先附上一张CMSIS的结构图
在这里插入图片描述
对于基于CMSIS的设备驱动框架开发涉及的文件有CMSIS目录下的,对外设驱动做了统一的驱动模型封装
在这里插入图片描述

/**
\brief Access structure of the SPI Driver.
*/
typedef struct _ARM_DRIVER_SPI {
  ARM_DRIVER_VERSION   (*GetVersion)      (void);                             ///< Pointer to \ref ARM_SPI_GetVersion : Get driver version.
  ARM_SPI_CAPABILITIES (*GetCapabilities) (void);                             ///< Pointer to \ref ARM_SPI_GetCapabilities : Get driver capabilities.
  int32_t              (*Initialize)      (ARM_SPI_SignalEvent_t cb_event);   ///< Pointer to \ref ARM_SPI_Initialize : Initialize SPI Interface.
  int32_t              (*Uninitialize)    (void);                             ///< Pointer to \ref ARM_SPI_Uninitialize : De-initialize SPI Interface.
  int32_t              (*PowerControl)    (ARM_POWER_STATE state);            ///< Pointer to \ref ARM_SPI_PowerControl : Control SPI Interface Power.
  int32_t              (*Send)            (const void *data, uint32_t num);   ///< Pointer to \ref ARM_SPI_Send : Start sending data to SPI Interface.
  int32_t              (*Receive)         (      void *data, uint32_t num);   ///< Pointer to \ref ARM_SPI_Receive : Start receiving data from SPI Interface.
  int32_t              (*Transfer)        (const void *data_out,
                                                 void *data_in,
                                           uint32_t    num);                  ///< Pointer to \ref ARM_SPI_Transfer : Start sending/receiving data to/from SPI.
  uint32_t             (*GetDataCount)    (void);                             ///< Pointer to \ref ARM_SPI_GetDataCount : Get transferred data count.
  int32_t              (*Control)         (uint32_t control, uint32_t arg);   ///< Pointer to \ref ARM_SPI_Control : Control SPI Interface.
  ARM_SPI_STATUS       (*GetStatus)       (void);                             ///< Pointer to \ref ARM_SPI_GetStatus : Get SPI status.
} const ARM_DRIVER_SPI;

在这里插入图片描述
下的DriverTemplates目录下只是做了驱动模型的壳子
在这里插入图片描述我们要与Driver_SPI.h对接的驱动文件在安装的芯片软件包里
在这里插入图片描述

#if (RTE_SSP1)
static int32_t        SSP1_Initialize          (ARM_SPI_SignalEvent_t pSignalEvent)                { return SSPx_Initialize   (pSignalEvent, &SSP1_Resources); }
static int32_t        SSP1_Uninitialize        (void)                                              { return SSPx_Uninitialize (&SSP1_Resources); }
static int32_t        SSP1_PowerControl        (ARM_POWER_STATE state)                             { return SSPx_PowerControl (state, &SSP1_Resources); }
static int32_t        SSP1_Send                (const void *data, uint32_t num)                    { return SSPx_Send         (data, num, &SSP1_Resources); }
static int32_t        SSP1_Receive             (void *data, uint32_t num)                          { return SSPx_Receive      (data, num, &SSP1_Resources); }
static int32_t        SSP1_Transfer            (const void *data_out, void *data_in, uint32_t num) { return SSPx_Transfer     (data_out, data_in, num, &SSP1_Resources); }
static uint32_t       SSP1_GetDataCount        (void)                                              { return SSPx_GetDataCount (&SSP1_Resources); }
static int32_t        SSP1_Control             (uint32_t control, uint32_t arg)                    { return SSPx_Control      (control, arg, &SSP1_Resources); }
static ARM_SPI_STATUS SSP1_GetStatus           (void)                                              { return SSPx_GetStatus    (&SSP1_Resources); }
       void           SSP1_GPDMA_Tx_SignalEvent(uint32_t event)                                    { SSPx_GPDMA_Tx_SignalEvent(event, &SSP1_Resources); }
       void           SSP1_GPDMA_Rx_SignalEvent(uint32_t event)                                    { SSPx_GPDMA_Rx_SignalEvent(event, &SSP1_Resources); }
       void           SSP1_IRQHandler          (void)                                              { SSPx_IRQHandler          (&SSP1_Resources); }

// SPI1 Driver Control Block
ARM_DRIVER_SPI Driver_SPI1 = {
  SSP_GetVersion,
  SSP_GetCapabilities,
  SSP1_Initialize,
  SSP1_Uninitialize,
  SSP1_PowerControl,
  SSP1_Send,
  SSP1_Receive,
  SSP1_Transfer,
  SSP1_GetDataCount,
  SSP1_Control,
  SSP1_GetStatus
};
#endif

这里就把我们上面的驱动接口对接到具体的实现函数
对于外设配置的相关驱动对接的引脚再
文件RTE_Device.h里

// <e> SSP0 (Synchronous Serial Port 0) [Driver_SPI0]
// <i> Configuration settings for Driver_SPI0 in component ::Drivers:SPI
#define RTE_SSP0                        0

//   <h> Pin Configuration
//     <o> SSP0_SSEL <0=>Not used <1=>P0_16 <2=>P1_21
//     <i> Slave Select for SSP0
#define   RTE_SSP0_SSEL_PIN_SEL         1
#if      (RTE_SSP0_SSEL_PIN_SEL == 0)
#define   RTE_SSP0_SSEL_PIN_EN          0
#elif    (RTE_SSP0_SSEL_PIN_SEL == 1)
  #define RTE_SSP0_SSEL_PORT            0
  #define RTE_SSP0_SSEL_BIT             16
  #define RTE_SSP0_SSEL_FUNC            2
#elif    (RTE_SSP0_SSEL_PIN_SEL == 2)
  #define RTE_SSP0_SSEL_PORT            1
  #define RTE_SSP0_SSEL_BIT             21
  #define RTE_SSP0_SSEL_FUNC            3
#else
  #error "Invalid SSP0 SSP0_SSEL Pin Configuration!"
#endif
#ifndef   RTE_SSP0_SSEL_PIN_EN
#define   RTE_SSP0_SSEL_PIN_EN          1
#endif

//     <o> SSP0_SCK <0=>P0_15 <1=>P1_20
//     <i> Serial clock for SSP0
#define   RTE_SSP0_SCK_PIN_SEL          0
#if      (RTE_SSP0_SCK_PIN_SEL == 0)
  #define RTE_SSP0_SCK_PORT             0
  #define RTE_SSP0_SCK_BIT              15
  #define RTE_SSP0_SCK_FUNC             2
#elif    (RTE_SSP0_SCK_PIN_SEL == 1)
  #define RTE_SSP0_SCK_PORT             1
  #define RTE_SSP0_SCK_BIT              20
  #define RTE_SSP0_SCK_FUNC             3
#else
  #error "Invalid SSP0 SSP0_SCK Pin Configuration!"
#endif

//     <o> SSP0_MISO <0=>Not used <1=>P0_17 <2=>P1_23
//     <i> Master In Slave Out for SSP0
#define   RTE_SSP0_MISO_PIN_SEL         0
#if      (RTE_SSP0_MISO_PIN_SEL == 0)
  #define RTE_SSP0_MISO_PIN_EN          0
#elif    (RTE_SSP0_MISO_PIN_SEL == 1)
  #define RTE_SSP0_MISO_PORT            0
  #define RTE_SSP0_MISO_BIT             17
  #define RTE_SSP0_MISO_FUNC            2
#elif    (RTE_SSP0_MISO_PIN_SEL == 2)
  #define RTE_SSP0_MISO_PORT            1
  #define RTE_SSP0_MISO_BIT             23
  #define RTE_SSP0_MISO_FUNC            3
#else
  #error "Invalid SSP0 SSP0_MISO Pin Configuration!"
#endif
#ifndef   RTE_SSP0_MISO_PIN_EN
#define   RTE_SSP0_MISO_PIN_EN          1
#endif

//     <o> SSP0_MOSI <0=>Not used <1=>P0_18 <2=>P1_24
//     <i> Master Out Slave In for SSP0
#define   RTE_SSP0_MOSI_PIN_SEL         0
#if      (RTE_SSP0_MOSI_PIN_SEL == 0)
  #define RTE_SSP0_MOSI_PIN_EN          0
#elif    (RTE_SSP0_MOSI_PIN_SEL == 1)
  #define RTE_SSP0_MOSI_PORT            0
  #define RTE_SSP0_MOSI_BIT             18
  #define RTE_SSP0_MOSI_FUNC            2
#elif    (RTE_SSP0_MOSI_PIN_SEL == 2)
  #define RTE_SSP0_MOSI_PORT            1
  #define RTE_SSP0_MOSI_BIT             24
  #define RTE_SSP0_MOSI_FUNC            3
#else
  #error "Invalid SSP0 SSP0_MOSI Pin Configuration!"
#endif
#ifndef   RTE_SSP0_MOSI_PIN_EN
#define   RTE_SSP0_MOSI_PIN_EN          1
#endif

对此基于CMSIS驱动框架的大致结构就是如此。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: CMSIS-DAP是一种常用的调试和编程接口,可用于与多种开发板和微控制器进行通信。为了能够使用CMSIS-DAP接口进行调试和编程操作,需要下载和安装相应的CDC驱动。 首先,打开浏览器,输入“CMSIS-DAP CDC驱动下载”进行搜索。可以在搜索结果中找到各种网站和资源提供了CMSIS-DAP CDC驱动程序的下载。可以根据自己使用的操作系统选择下载相应的驱动程序。 一般来说,CDC驱动程序可以在Windows、Mac和Linux操作系统中使用。根据自己使用的操作系统,选择合适的驱动程序版本进行下载。 下载完成后,双击驱动程序安装文件进行安装。按照安装向导的指引,完成驱动程序的安装。 安装完成后,需要将CMSIS-DAP接口连接到计算机。将CMSIS-DAP接口插入计算机的USB接口中。操作系统会自动识别并安装驱动程序。 完成上述步骤后,CMSIS-DAP CDC驱动就成功地安装在了计算机上。现在可以通过CMSIS-DAP接口与开发板和微控制器进行调试和编程操作了。 通过下载和安装CMSIS-DAP CDC驱动,可以保证计算机能够正确地识别CMSIS-DAP接口并与其进行通信,从而方便地进行开发板和微控制器的调试和编程工作。 ### 回答2: 要下载CMSIS-DAP CDC驱动,首先需要明确CMSIS-DAP是一种用于远程调试和编程的开源接口。CDC驱动是指使用USB通信协议进行串口通信的驱动程序。 要下载CMSIS-DAP CDC驱动,可以按照以下步骤进行: 1. 打开互联网浏览器,进入CMSIS-DAP官方网站,例如https://www.keil.com/download/product/。 2. 在网站上找到与CMSIS-DAP CDC驱动相关的下载链接或页面。这些链接可能位于“驱动程序”或“下载”等菜单选项下。 3. 点击下载链接,选择适用于您的操作系统的驱动程序版本。通常有Windows、Mac和Linux等操作系统的驱动可供选择。 4. 确认下载前先阅读和同意相关的许可协议和条款。 5. 下载完成后,打开下载的驱动程序安装包。 6. 按照安装程序的指示,选择安装驱动程序的位置和选项。 7. 等待驱动程序安装完成。 8. 安装完成后,重新启动计算机,以确保驱动程序正确加载和生效。 9. 连接使用CMSIS-DAP接口的设备到计算机,例如使用USB线连接。 10. 等待设备被识别并建立通信连接,系统会自动识别并加载所需的CDC驱动。 以上是下载CMSIS-DAP CDC驱动的一般步骤,具体下载方式可能因不同网站、驱动版本和操作系统而略有差异。建议在下载和安装驱动程序之前,阅读官方网站上提供的相关文档和指南,以获得更准确的操作步骤和说明。 ### 回答3: CMSIS-DAP是一种用于调试和编程的接口协议,可以与微处理器进行通信。其中的CDC驱动是为CMSIS-DAP提供虚拟串口功能的驱动程序。这个驱动程序可以用于将CMSIS-DAP设备在计算机上识别为串口设备,使得开发者可以通过串口终端程序或者使用串口通信的开发工具与CMSIS-DAP进行通信。 要下载CMSIS-DAP CDC驱动程序,首先需要在互联网上找到可靠且安全的网站。可以使用搜索引擎搜索"CMSIS-DAP CDC驱动下载"来找到相关的网站。在搜索结果列表中,选择一个可信度高的网站,并确保它提供了最新版本的驱动程序。 在选择合适的网站后,进入下载页面。一般来说,网站会提供选择操作系统的选项,因此请确保选择适用于您的操作系统的驱动程序版本。然后,点击下载按钮或链接,开始下载驱动程序。 下载完成后,可以通过双击下载的驱动程序文件运行安装程序。按照安装程序的指示进行操作,直到安装完成。 安装完成后,计算机将能够识别CMSIS-DAP设备并将其识别为串口设备。这样,您就可以使用串口终端程序或开发工具与CMSIS-DAP进行通信,从而进行调试和编程工作。 需要注意的是,下载和安装任何驱动程序时,请确保从官方和可靠的来源获取,以确保安全和兼容性。此外,如果您已经安装了CMSIS-DAP驱动,但设备无法正常工作,请确保驱动程序与操作系统的版本兼容,并尝试更新驱动程序以解决问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值