I'm trying to port GRBL 1.1 to the STM32F746 chip. Tell me the solution, thanks.
usb/usb_endp.c@0:8f0d870509fe, 2017-09-04 (annotated)
- Committer:
- Sergunb
- Date:
- Mon Sep 04 12:04:13 2017 +0000
- Revision:
- 0:8f0d870509fe
Initial commit
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
Sergunb | 0:8f0d870509fe | 1 | /******************** (C) COPYRIGHT 2011 STMicroelectronics ******************** |
Sergunb | 0:8f0d870509fe | 2 | * File Name : usb_endp.c |
Sergunb | 0:8f0d870509fe | 3 | * Author : MCD Application Team |
Sergunb | 0:8f0d870509fe | 4 | * Version : V3.3.0 |
Sergunb | 0:8f0d870509fe | 5 | * Date : 21-March-2011 |
Sergunb | 0:8f0d870509fe | 6 | * Description : Endpoint routines |
Sergunb | 0:8f0d870509fe | 7 | ******************************************************************************** |
Sergunb | 0:8f0d870509fe | 8 | * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS |
Sergunb | 0:8f0d870509fe | 9 | * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME. |
Sergunb | 0:8f0d870509fe | 10 | * AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT, |
Sergunb | 0:8f0d870509fe | 11 | * INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE |
Sergunb | 0:8f0d870509fe | 12 | * CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING |
Sergunb | 0:8f0d870509fe | 13 | * INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS. |
Sergunb | 0:8f0d870509fe | 14 | *******************************************************************************/ |
Sergunb | 0:8f0d870509fe | 15 | |
Sergunb | 0:8f0d870509fe | 16 | #include "usb_lib.h" |
Sergunb | 0:8f0d870509fe | 17 | #include "usb_desc.h" |
Sergunb | 0:8f0d870509fe | 18 | #include "usb_mem.h" |
Sergunb | 0:8f0d870509fe | 19 | #include "hw_config.h" |
Sergunb | 0:8f0d870509fe | 20 | #include "usb_istr.h" |
Sergunb | 0:8f0d870509fe | 21 | #include "usb_pwr.h" |
Sergunb | 0:8f0d870509fe | 22 | #include "serial.h" |
Sergunb | 0:8f0d870509fe | 23 | uint8_t USB_Rx_Buffer[VIRTUAL_COM_PORT_DATA_SIZE]; |
Sergunb | 0:8f0d870509fe | 24 | |
Sergunb | 0:8f0d870509fe | 25 | extern uint8_t serial_tx_buffer[]; |
Sergunb | 0:8f0d870509fe | 26 | extern uint8_t serial_tx_buffer_head; |
Sergunb | 0:8f0d870509fe | 27 | extern volatile uint8_t serial_tx_buffer_tail; |
Sergunb | 0:8f0d870509fe | 28 | |
Sergunb | 0:8f0d870509fe | 29 | void EP3_OUT_Callback(void) |
Sergunb | 0:8f0d870509fe | 30 | { |
Sergunb | 0:8f0d870509fe | 31 | uint16_t USB_Rx_Cnt; |
Sergunb | 0:8f0d870509fe | 32 | |
Sergunb | 0:8f0d870509fe | 33 | /* Get the received data buffer and update the counter */ |
Sergunb | 0:8f0d870509fe | 34 | USB_Rx_Cnt = USB_SIL_Read(EP3_OUT, USB_Rx_Buffer); |
Sergunb | 0:8f0d870509fe | 35 | |
Sergunb | 0:8f0d870509fe | 36 | /* USB data will be immediately processed, this allow next USB traffic being |
Sergunb | 0:8f0d870509fe | 37 | NAKed till the end of the USART Xfer */ |
Sergunb | 0:8f0d870509fe | 38 | |
Sergunb | 0:8f0d870509fe | 39 | OnUsbDataRx(USB_Rx_Buffer, USB_Rx_Cnt); |
Sergunb | 0:8f0d870509fe | 40 | |
Sergunb | 0:8f0d870509fe | 41 | /* Enable the receive of data on EP3 */ |
Sergunb | 0:8f0d870509fe | 42 | SetEPRxValid(ENDP3); |
Sergunb | 0:8f0d870509fe | 43 | } |
Sergunb | 0:8f0d870509fe | 44 | void EP1_IN_Callback (void) |
Sergunb | 0:8f0d870509fe | 45 | { |
Sergunb | 0:8f0d870509fe | 46 | if (serial_tx_buffer_head != serial_tx_buffer_tail && (_GetEPTxStatus(ENDP1) == EP_TX_NAK)) |
Sergunb | 0:8f0d870509fe | 47 | { |
Sergunb | 0:8f0d870509fe | 48 | uint16_t USB_Tx_length; |
Sergunb | 0:8f0d870509fe | 49 | |
Sergunb | 0:8f0d870509fe | 50 | if (serial_tx_buffer_head > serial_tx_buffer_tail) |
Sergunb | 0:8f0d870509fe | 51 | USB_Tx_length = serial_tx_buffer_head - serial_tx_buffer_tail; |
Sergunb | 0:8f0d870509fe | 52 | else |
Sergunb | 0:8f0d870509fe | 53 | { |
Sergunb | 0:8f0d870509fe | 54 | USB_Tx_length = TX_BUFFER_SIZE - serial_tx_buffer_tail + serial_tx_buffer_head; |
Sergunb | 0:8f0d870509fe | 55 | } |
Sergunb | 0:8f0d870509fe | 56 | |
Sergunb | 0:8f0d870509fe | 57 | if (USB_Tx_length != 0) |
Sergunb | 0:8f0d870509fe | 58 | { |
Sergunb | 0:8f0d870509fe | 59 | if (USB_Tx_length > 64) |
Sergunb | 0:8f0d870509fe | 60 | USB_Tx_length = 64; |
Sergunb | 0:8f0d870509fe | 61 | |
Sergunb | 0:8f0d870509fe | 62 | // UserToPMABufferCopy(&serial_tx_buffer[serial_tx_buffer_tail], ENDP1_TXADDR, USB_Tx_length); |
Sergunb | 0:8f0d870509fe | 63 | { |
Sergunb | 0:8f0d870509fe | 64 | uint8_t *pbUsrBuf = serial_tx_buffer + serial_tx_buffer_tail; |
Sergunb | 0:8f0d870509fe | 65 | uint32_t n = (USB_Tx_length + 1) >> 1; /* n = (wNBytes + 1) / 2 */ |
Sergunb | 0:8f0d870509fe | 66 | uint32_t i, temp1; |
Sergunb | 0:8f0d870509fe | 67 | uint16_t *pdwVal; |
Sergunb | 0:8f0d870509fe | 68 | pdwVal = (uint16_t *)(ENDP1_TXADDR * 2 + PMAAddr); |
Sergunb | 0:8f0d870509fe | 69 | for (i = n; i != 0; i--) |
Sergunb | 0:8f0d870509fe | 70 | { |
Sergunb | 0:8f0d870509fe | 71 | temp1 = (uint16_t) * pbUsrBuf; |
Sergunb | 0:8f0d870509fe | 72 | pbUsrBuf++; |
Sergunb | 0:8f0d870509fe | 73 | if (pbUsrBuf - serial_tx_buffer == TX_BUFFER_SIZE) |
Sergunb | 0:8f0d870509fe | 74 | pbUsrBuf = serial_tx_buffer; |
Sergunb | 0:8f0d870509fe | 75 | |
Sergunb | 0:8f0d870509fe | 76 | *pdwVal++ = temp1 | (uint16_t) * pbUsrBuf << 8; |
Sergunb | 0:8f0d870509fe | 77 | pdwVal++; |
Sergunb | 0:8f0d870509fe | 78 | pbUsrBuf++; |
Sergunb | 0:8f0d870509fe | 79 | if (pbUsrBuf - serial_tx_buffer == TX_BUFFER_SIZE) |
Sergunb | 0:8f0d870509fe | 80 | pbUsrBuf = serial_tx_buffer; |
Sergunb | 0:8f0d870509fe | 81 | } |
Sergunb | 0:8f0d870509fe | 82 | } |
Sergunb | 0:8f0d870509fe | 83 | |
Sergunb | 0:8f0d870509fe | 84 | SetEPTxCount(ENDP1, USB_Tx_length); |
Sergunb | 0:8f0d870509fe | 85 | SetEPTxValid(ENDP1); |
Sergunb | 0:8f0d870509fe | 86 | |
Sergunb | 0:8f0d870509fe | 87 | serial_tx_buffer_tail += USB_Tx_length; |
Sergunb | 0:8f0d870509fe | 88 | if (serial_tx_buffer_tail >= TX_BUFFER_SIZE) |
Sergunb | 0:8f0d870509fe | 89 | serial_tx_buffer_tail -= TX_BUFFER_SIZE; |
Sergunb | 0:8f0d870509fe | 90 | } |
Sergunb | 0:8f0d870509fe | 91 | } |
Sergunb | 0:8f0d870509fe | 92 | } |
Sergunb | 0:8f0d870509fe | 93 | |
Sergunb | 0:8f0d870509fe | 94 | |
Sergunb | 0:8f0d870509fe | 95 | /* \brief Start Of Frame (SOF) callback |
Sergunb | 0:8f0d870509fe | 96 | */ |
Sergunb | 0:8f0d870509fe | 97 | void SOF_Callback(void) |
Sergunb | 0:8f0d870509fe | 98 | { |
Sergunb | 0:8f0d870509fe | 99 | if(bDeviceState == CONFIGURED) |
Sergunb | 0:8f0d870509fe | 100 | { |
Sergunb | 0:8f0d870509fe | 101 | /* Check the data to be sent through IN pipe */ |
Sergunb | 0:8f0d870509fe | 102 | EP1_IN_Callback(); |
Sergunb | 0:8f0d870509fe | 103 | } |
Sergunb | 0:8f0d870509fe | 104 | } |
Sergunb | 0:8f0d870509fe | 105 | /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/ |
Sergunb | 0:8f0d870509fe | 106 |