银杏科技有限公司旗下技术文档发布平台 | |||
技术支持电话 | 0379-69926675-801 | ||
技术支持邮件 | Gingko@vip.163.com | ||
版本 | 日期 | 作者 | 修改内容 |
---|---|---|---|
V1.0 | 2020-03-20 | gingko | 初次建立 |
1.在主界面选择File–>New Project 或者直接点击ACCEE TO MCU SELECTOR
2.出现芯片型号选择,搜索自己芯片的型号,双击型号,或者点击Start Project进入配置
在搜索栏的下面,提供的各 种查找方式,可以选择芯片内核,型号,等等,可以帮助你查找芯片。本实验选取的芯片型号为:STM32H750IBKx。
3.配置RCC,使用外部时钟源
4.时基源选择SysTick
5.将PA10,PB7,PB8设置为GPIO_Output
6.引脚模式配置
7.配置USB_OTG_FS
8.配置USB_DEVICE
9.时钟源设置,选择外部高速时钟源,配置为最大主频
10.工程文件的设置, 这里就是工程的各种配置 我们只用到有限几个,其他的默认即可 IDE我们使用的是 MDK V5.27
11.点击Code Generator,进行进一步配置
int main(void) { /* MCU配置 */ /*重置所有外围设备,初始化Flash接口和Systick */ HAL_Init(); /* 配置系统时钟 */ SystemClock_Config(); i2c.initialize(); axp152.initialize(); axp152.set_dcdc1(3500);//[ARM & FPGA BK1/2/6 &OTHER] axp152.set_dcdc2(1200);//[FPGA INT & PLL D] axp152.set_aldo1(2500);//[FPGA PLL A] axp152.set_dcdc4(3300);//[POWER_OUTPUT] axp152.set_dcdc3(3300);//[FPGA BK4][Adjustable] axp152.set_aldo2(3300);//[FPGA BK3][Adjustable] axp152.set_dldo1(3300);//[FPGA BK7][Adjustable] axp152.set_dldo2(3300);//[FPGA BK5][Adjustable] /* 初始化所有已配置的外围设备 */ MX_GPIO_Init(); MX_USB_DEVICE_Init(); /* 无限循环 */ while (1) { }
/*初始化USB设备库,添加支持的类并启动该库*/ void MX_USB_DEVICE_Init(void) { /* 初始化设备堆栈并加载类驱动程序 */ if (USBD_Init(&hUsbDeviceFS, &FS_Desc, DEVICE_FS) != USBD_OK) { Error_Handler(); } /* 将类驱动程序链接到Device Core */ if (USBD_RegisterClass(&hUsbDeviceFS, &USBD_CDC) != USBD_OK) { Error_Handler(); } /* USBD_CDC寄存器接口 */ if (USBD_CDC_RegisterInterface(&hUsbDeviceFS, &USBD_Interface_fops_FS) != USBD_OK) { Error_Handler(); } /* 启动USB Device Core */ if (USBD_Start(&hUsbDeviceFS) != USBD_OK) { Error_Handler(); } /* 启用USB电压电平检测器 */ HAL_PWREx_EnableUSBVoltageDetector(); }
/* 在USB FS IP上初始化CDC底层媒体 */ /* 如果所有操作均正常,则为USBD_OK,否则为USBD_FAIL */ static int8_t CDC_Init_FS(void) { /* 设置应用程序缓冲区 */ USBD_CDC_SetTxBuffer(&hUsbDeviceFS, UserTxBufferFS, 0); USBD_CDC_SetRxBuffer(&hUsbDeviceFS, UserRxBufferFS); return (USBD_OK); } /* 取消初始化CDC媒体低层 */ /* 如果所有操作均正常,则为USBD_OK,否则为USBD_FAIL */ static int8_t CDC_DeInit_FS(void) { return (USBD_OK); }
/** * @brief 管理CDC类请求 * @param cmd: 指令码 * @param pbuf: 包含命令数据(请求参数)的缓冲区 * @param length:要发送的数据数(以字节为单位) * @retval 操作结果: 如果所有操作均正常,则为USBD_OK,否则为USBD_FAIL */ static int8_t CDC_Control_FS(uint8_t cmd, uint8_t* pbuf, uint16_t length) { switch(cmd) { case CDC_SEND_ENCAPSULATED_COMMAND: break; case CDC_GET_ENCAPSULATED_RESPONSE: break; case CDC_SET_COMM_FEATURE: break; case CDC_GET_COMM_FEATURE: break; case CDC_CLEAR_COMM_FEATURE: break; case CDC_SET_LINE_CODING: break; case CDC_GET_LINE_CODING: break; case CDC_SET_CONTROL_LINE_STATE: break; case CDC_SEND_BREAK: break; default: break; } return (USBD_OK); } <code> <code c> /** * @brief USB OUT端点接收的数据通过此函数发送给CDC接口 * @note 此函数将阻止USB端点上的所有OUT数据包接收,直到退出此功能。如果在CDC接口上完成 传输之前退出此功能(即使用DMA控制器),它将导致接收更多数据,而先前的数据仍未发送。 * @param Buf: 待接收数据的缓冲区 * @param Len: 接收的数据数(以字节为单位) * @retval 如果所有操作均正常,则为USBD_OK,否则为USBD_FAIL */ static int8_t CDC_Receive_FS(uint8_t* Buf, uint32_t *Len) { USBD_CDC_SetRxBuffer(&hUsbDeviceFS, &Buf[0]); USBD_CDC_ReceivePacket(&hUsbDeviceFS); CDC_Transmit_FS(Buf,(uint16_t)(*Len)); return (USBD_OK); }
/** * @brief 通过USB IN端点发送的数据通过此函数发送给CDC接口 * @param Buf: 要发送的数据缓冲区 * @param Len: 要发送的数据数(以字节为单位) * @retval 操作结果: 如果所有操作均正常返回USBD_OK,否则返回USBD_FAIL或USBD_BUSY */ uint8_t CDC_Transmit_FS(uint8_t* Buf, uint16_t Len) { uint8_t result = USBD_OK; USBD_CDC_HandleTypeDef *hcdc = (USBD_CDC_HandleTypeDef*)hUsbDeviceFS.pClassData; if (hcdc->TxState != 0){ return USBD_BUSY; } USBD_CDC_SetTxBuffer(&hUsbDeviceFS, Buf, Len); result = USBD_CDC_TransmitPacket(&hUsbDeviceFS); return result; }