mirror of
				https://github.com/esp8266/Arduino.git
				synced 2025-10-25 18:38:07 +03:00 
			
		
		
		
	Change UART register access methods
This commit is contained in:
		| @@ -20,6 +20,7 @@ | ||||
|  | ||||
|  Modified 31 March 2015 by Markus Sattler (rewrite the code for UART0 + UART1 support in ESP8266) | ||||
|  Modified 25 April 2015 by Thomas Flayols (add configuration different from 8N1 in ESP8266) | ||||
|  Modified 3 May 2015 by Hristo Gochkov (change register access methods) | ||||
|  */ | ||||
|  | ||||
| #include <stdlib.h> | ||||
| @@ -33,7 +34,6 @@ extern "C" { | ||||
| #include "osapi.h" | ||||
| #include "ets_sys.h" | ||||
| #include "mem.h" | ||||
| #include "uart_register.h" | ||||
| #include "user_interface.h" | ||||
| } | ||||
|  | ||||
| @@ -104,51 +104,51 @@ UARTnr_t uart_get_debug(); | ||||
| void ICACHE_RAM_ATTR uart_interrupt_handler(uart_t* uart) { | ||||
|  | ||||
|     // -------------- UART 0 -------------- | ||||
|     uint32_t status = READ_PERI_REG(UART_INT_ST(0)); | ||||
|     uint32_t status = U0IS; | ||||
|     if(Serial.isRxEnabled()) { | ||||
|         if(status & UART_RXFIFO_FULL_INT_ST) { | ||||
|         if(status & (1 << UIFF)) { | ||||
|             while(true) { | ||||
|                 int rx_count = (READ_PERI_REG(UART_STATUS(0)) >> UART_RXFIFO_CNT_S) & UART_RXFIFO_CNT; | ||||
|                 int rx_count = (U0S >> USTXC) & 0xFF; | ||||
|                 if(!rx_count) | ||||
|                     break; | ||||
|  | ||||
|                 while(rx_count--) { | ||||
|                     char c = READ_PERI_REG(UART_FIFO(0)) & 0xFF; | ||||
|                     char c = U0F & 0xFF; | ||||
|                     Serial._rx_complete_irq(c); | ||||
|                 } | ||||
|             } | ||||
|             WRITE_PERI_REG(UART_INT_CLR(0), UART_RXFIFO_FULL_INT_CLR); | ||||
|             U0IC = (1 << UIFF); | ||||
|         } | ||||
|     } | ||||
|     if(Serial.isTxEnabled()) { | ||||
|         if(status & UART_TXFIFO_EMPTY_INT_ST) { | ||||
|             WRITE_PERI_REG(UART_INT_CLR(0), UART_TXFIFO_EMPTY_INT_CLR); | ||||
|         if(status & (1 << UIFE)) { | ||||
|             U0IC = (1 << UIFE); | ||||
|             Serial._tx_empty_irq(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     // -------------- UART 1 -------------- | ||||
|  | ||||
|     status = READ_PERI_REG(UART_INT_ST(1)); | ||||
|     status = U1IS; | ||||
|     if(Serial1.isRxEnabled()) { | ||||
|         if(status & UART_RXFIFO_FULL_INT_ST) { | ||||
|         if(status & (1 << UIFF)) { | ||||
|             while(true) { | ||||
|                 int rx_count = (READ_PERI_REG(UART_STATUS(1)) >> UART_RXFIFO_CNT_S) & UART_RXFIFO_CNT; | ||||
|                 int rx_count = (U1S >> USTXC) & 0xFF; | ||||
|                 if(!rx_count) | ||||
|                     break; | ||||
|  | ||||
|                 while(rx_count--) { | ||||
|                     char c = READ_PERI_REG(UART_FIFO(1)) & 0xFF; | ||||
|                     char c = U1F & 0xFF; | ||||
|                     Serial1._rx_complete_irq(c); | ||||
|                 } | ||||
|             } | ||||
|             WRITE_PERI_REG(UART_INT_CLR(1), UART_RXFIFO_FULL_INT_CLR); | ||||
|             U1IC = (1 << UIFF); | ||||
|         } | ||||
|     } | ||||
|     if(Serial1.isTxEnabled()) { | ||||
|         status = READ_PERI_REG(UART_INT_ST(1)); | ||||
|         if(status & UART_TXFIFO_EMPTY_INT_ST) { | ||||
|             WRITE_PERI_REG(UART_INT_CLR(1), UART_TXFIFO_EMPTY_INT_CLR); | ||||
|         status = U1IS; | ||||
|         if(status & (1 << UIFE)) { | ||||
|             U1IC = (1 << UIFE); | ||||
|             Serial1._tx_empty_irq(); | ||||
|         } | ||||
|     } | ||||
| @@ -161,7 +161,7 @@ void ICACHE_FLASH_ATTR uart_wait_for_tx_fifo(uart_t* uart, size_t size_needed) { | ||||
|         return; | ||||
|     if(uart->txEnabled) { | ||||
|         while(true) { | ||||
|             size_t tx_count = (READ_PERI_REG(UART_STATUS(uart->uart_nr)) >> UART_TXFIFO_CNT_S) & UART_TXFIFO_CNT; | ||||
|             size_t tx_count = (USS(uart->uart_nr) >> USTXC) & 0xFF; | ||||
|             if(tx_count <= (UART_TX_FIFO_SIZE - size_needed)) | ||||
|                 break; | ||||
|         } | ||||
| @@ -172,7 +172,7 @@ size_t ICACHE_FLASH_ATTR uart_get_tx_fifo_room(uart_t* uart) { | ||||
|     if(uart == 0) | ||||
|         return 0; | ||||
|     if(uart->txEnabled) { | ||||
|         return UART_TX_FIFO_SIZE - ((READ_PERI_REG(UART_STATUS(uart->uart_nr)) >> UART_TXFIFO_CNT_S) & UART_TXFIFO_CNT); | ||||
|         return UART_TX_FIFO_SIZE - ((USS(uart->uart_nr) >> USTXC) & 0xFF); | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
| @@ -189,7 +189,7 @@ void ICACHE_FLASH_ATTR uart_transmit_char(uart_t* uart, char c) { | ||||
|     if(uart == 0) | ||||
|         return; | ||||
|     if(uart->txEnabled) { | ||||
|         WRITE_PERI_REG(UART_FIFO(uart->uart_nr), c); | ||||
|         USF(uart->uart_nr) = c; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -203,7 +203,7 @@ void ICACHE_FLASH_ATTR uart_transmit(uart_t* uart, const char* buf, size_t size) | ||||
|  | ||||
|             uart_wait_for_tx_fifo(uart, part_size); | ||||
|             for(; part_size; --part_size, ++buf) | ||||
|                 WRITE_PERI_REG(UART_FIFO(uart->uart_nr), *buf); | ||||
|                 USF(uart->uart_nr) = *buf; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -215,24 +215,24 @@ void ICACHE_FLASH_ATTR uart_flush(uart_t* uart) { | ||||
|         return; | ||||
|  | ||||
|     if(uart->rxEnabled) { | ||||
|         tmp |= UART_RXFIFO_RST; | ||||
|         tmp |= (1 << UCRXRST); | ||||
|     } | ||||
|  | ||||
|     if(uart->txEnabled) { | ||||
|         tmp |= UART_TXFIFO_RST; | ||||
|         tmp |= (1 << UCTXRST); | ||||
|     } | ||||
|  | ||||
|     SET_PERI_REG_MASK(UART_CONF0(uart->uart_nr), tmp); | ||||
|     CLEAR_PERI_REG_MASK(UART_CONF0(uart->uart_nr), tmp); | ||||
|     USC0(uart->uart_nr) |= (tmp); | ||||
|     USC0(uart->uart_nr) &= ~(tmp); | ||||
| } | ||||
|  | ||||
| void ICACHE_FLASH_ATTR uart_interrupt_enable(uart_t* uart) { | ||||
|     if(uart == 0) | ||||
|         return; | ||||
|     WRITE_PERI_REG(UART_INT_CLR(uart->uart_nr), 0x1ff); | ||||
|     USIC(uart->uart_nr) = 0x1ff; | ||||
|     ETS_UART_INTR_ATTACH(&uart_interrupt_handler, uart); // uart parameter is not osed in irq function! | ||||
|     if(uart->rxEnabled) { | ||||
|         SET_PERI_REG_MASK(UART_INT_ENA(uart->uart_nr), UART_RXFIFO_FULL_INT_ENA); | ||||
|         USIE(uart->uart_nr) |= (1 << UIFF); | ||||
|     } | ||||
|     ETS_UART_INTR_ENABLE(); | ||||
| } | ||||
| @@ -241,10 +241,10 @@ void ICACHE_FLASH_ATTR uart_interrupt_disable(uart_t* uart) { | ||||
|     if(uart == 0) | ||||
|         return; | ||||
|     if(uart->rxEnabled) { | ||||
|         CLEAR_PERI_REG_MASK(UART_INT_ENA(uart->uart_nr), UART_RXFIFO_FULL_INT_ENA); | ||||
|         USIE(uart->uart_nr) &= ~(1 << UIFF); | ||||
|     } | ||||
|     if(uart->txEnabled) { | ||||
|         CLEAR_PERI_REG_MASK(UART_INT_ENA(uart->uart_nr), UART_TXFIFO_EMPTY_INT_ENA); | ||||
|         USIE(uart->uart_nr) &= ~(1 << UIFE); | ||||
|     } | ||||
|     //ETS_UART_INTR_DISABLE(); // never disable irq complete may its needed by the other Serial Interface! | ||||
| } | ||||
| @@ -253,7 +253,7 @@ void ICACHE_FLASH_ATTR uart_arm_tx_interrupt(uart_t* uart) { | ||||
|     if(uart == 0) | ||||
|         return; | ||||
|     if(uart->txEnabled) { | ||||
|         SET_PERI_REG_MASK(UART_INT_ENA(uart->uart_nr), UART_TXFIFO_EMPTY_INT_ENA); | ||||
|         USIE(uart->uart_nr) |= (1 << UIFE); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -261,7 +261,7 @@ void ICACHE_FLASH_ATTR uart_disarm_tx_interrupt(uart_t* uart) { | ||||
|     if(uart == 0) | ||||
|         return; | ||||
|     if(uart->txEnabled) { | ||||
|         CLEAR_PERI_REG_MASK(UART_INT_ENA(uart->uart_nr), UART_TXFIFO_EMPTY_INT_ENA); | ||||
|         USIE(uart->uart_nr) &= ~(1 << UIFE); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -269,7 +269,7 @@ void ICACHE_FLASH_ATTR uart_set_baudrate(uart_t* uart, int baud_rate) { | ||||
|     if(uart == 0) | ||||
|         return; | ||||
|     uart->baud_rate = baud_rate; | ||||
|     uart_div_modify(uart->uart_nr, UART_CLK_FREQ / (uart->baud_rate)); | ||||
|     USD(uart->uart_nr) = (F_CPU / uart->baud_rate); | ||||
| } | ||||
|  | ||||
| int ICACHE_FLASH_ATTR uart_get_baudrate(uart_t* uart) { | ||||
| @@ -291,18 +291,15 @@ uart_t* ICACHE_FLASH_ATTR uart_init(UARTnr_t uart_nr, int baudrate, byte config) | ||||
|  | ||||
|     switch(uart->uart_nr) { | ||||
|         case UART0: | ||||
|             PIN_PULLUP_DIS(PERIPHS_IO_MUX_U0TXD_U); | ||||
|             PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0TXD_U, FUNC_U0TXD); | ||||
|             PIN_PULLUP_EN(PERIPHS_IO_MUX_U0RXD_U); | ||||
|             PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0RXD_U, FUNC_U0RXD); | ||||
|             pinMode(1, SPECIAL); | ||||
|             pinMode(3, SPECIAL); | ||||
|             uart->rxEnabled = true; | ||||
|             uart->txEnabled = true; | ||||
|             uart->rxPin = 3; | ||||
|             uart->txPin = 1; | ||||
|             break; | ||||
|         case UART1: | ||||
|             PIN_PULLUP_DIS(PERIPHS_IO_MUX_GPIO2_U); | ||||
|             PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO2_U, FUNC_U1TXD_BK); | ||||
|             pinMode(2, SPECIAL); | ||||
|             uart->rxEnabled = false; | ||||
|             uart->txEnabled = true; | ||||
|             uart->rxPin = 255; | ||||
| @@ -314,20 +311,20 @@ uart_t* ICACHE_FLASH_ATTR uart_init(UARTnr_t uart_nr, int baudrate, byte config) | ||||
|             break; | ||||
|     } | ||||
|     uart_set_baudrate(uart, baudrate); | ||||
|     WRITE_PERI_REG(UART_CONF0(uart->uart_nr), config); | ||||
|     USC0(uart->uart_nr) = config; | ||||
|  | ||||
|     uart_flush(uart); | ||||
|     uart_interrupt_enable(uart); | ||||
|  | ||||
|     if(uart->rxEnabled) { | ||||
|         conf1 |= ((0x01 & UART_RXFIFO_FULL_THRHD) << UART_RXFIFO_FULL_THRHD_S); | ||||
|         conf1 |= (0x01 << UCFFT); | ||||
|     } | ||||
|  | ||||
|     if(uart->txEnabled) { | ||||
|         conf1 |= ((0x20 & UART_TXFIFO_EMPTY_THRHD) << UART_TXFIFO_EMPTY_THRHD_S); | ||||
|         conf1 |= (0x20 << UCFET); | ||||
|     } | ||||
|  | ||||
|     WRITE_PERI_REG(UART_CONF1(uart->uart_nr), conf1); | ||||
|     USC1(uart->uart_nr) = conf1; | ||||
|  | ||||
|     return uart; | ||||
| } | ||||
| @@ -339,30 +336,25 @@ void ICACHE_FLASH_ATTR uart_uninit(uart_t* uart) { | ||||
|  | ||||
|     switch(uart->rxPin) { | ||||
|         case 3: | ||||
|             PIN_PULLUP_DIS(PERIPHS_IO_MUX_U0RXD_U); | ||||
|             PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0RXD_U, FUNC_GPIO3); | ||||
|             pinMode(3, INPUT); | ||||
|             break; | ||||
|         case 13: | ||||
|             PIN_PULLUP_DIS(PERIPHS_IO_MUX_MTCK_U); | ||||
|             PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTCK_U, FUNC_GPIO13); | ||||
|             pinMode(13, INPUT); | ||||
|             break; | ||||
|     } | ||||
|  | ||||
|     switch(uart->txPin) { | ||||
|         case 1: | ||||
|             PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0TXD_U, FUNC_GPIO1); | ||||
|             pinMode(1, INPUT); | ||||
|             break; | ||||
|         case 2: | ||||
|             PIN_FUNC_SELECT(PERIPHS_IO_MUX_GPIO2_U, FUNC_GPIO2); | ||||
|             pinMode(2, INPUT); | ||||
|             break; | ||||
|         case 15: | ||||
|             PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDO_U, FUNC_GPIO15); | ||||
|             pinMode(15, INPUT); | ||||
|             break; | ||||
|     } | ||||
|  | ||||
|     pinMode(uart->rxPin, INPUT); | ||||
|     pinMode(uart->txPin, INPUT); | ||||
|  | ||||
|     os_free(uart); | ||||
| } | ||||
|  | ||||
| @@ -372,39 +364,19 @@ void ICACHE_FLASH_ATTR uart_swap(uart_t* uart) { | ||||
|     switch(uart->uart_nr) { | ||||
|         case UART0: | ||||
|             if(uart->txPin == 1 && uart->rxPin == 3) { | ||||
|  | ||||
|                 PIN_PULLUP_DIS(PERIPHS_IO_MUX_MTCK_U); | ||||
|                 PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTCK_U, FUNC_UART0_CTS); | ||||
|  | ||||
|                 PIN_PULLUP_EN(PERIPHS_IO_MUX_MTDO_U); | ||||
|                 PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDO_U, FUNC_UART0_RTS); | ||||
|  | ||||
|                 //SWAP PIN : U0TXD<==>U0RTS(MTDO, GPIO15) , U0RXD<==>U0CTS(MTCK, GPIO13) | ||||
|                 SET_PERI_REG_MASK(0x3ff00028, BIT2); | ||||
|  | ||||
|                 PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0RXD_U, FUNC_GPIO3); | ||||
|                 PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0TXD_U, FUNC_GPIO1); | ||||
|  | ||||
|                 pinMode(uart->rxPin, INPUT); | ||||
|                 pinMode(uart->txPin, INPUT); | ||||
|  | ||||
|                 pinMode(15, FUNCTION_4);//TX | ||||
|                 pinMode(13, FUNCTION_4);//RX | ||||
|                 USWAP |= (1 << USWAP0); | ||||
|                 pinMode(1, INPUT);//TX | ||||
|                 pinMode(3, INPUT);//RX | ||||
|                 uart->rxPin = 13; | ||||
|                 uart->txPin = 15; | ||||
|  | ||||
|             } else { | ||||
|                 PIN_PULLUP_DIS(PERIPHS_IO_MUX_U0TXD_U); | ||||
|                 PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0TXD_U, FUNC_U0TXD); | ||||
|  | ||||
|                 PIN_PULLUP_EN(PERIPHS_IO_MUX_U0RXD_U); | ||||
|                 PIN_FUNC_SELECT(PERIPHS_IO_MUX_U0RXD_U, FUNC_U0RXD); | ||||
|  | ||||
|                 CLEAR_PERI_REG_MASK(0x3ff00028, BIT2); | ||||
|  | ||||
|                 PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTCK_U, FUNC_GPIO13); | ||||
|                 PIN_FUNC_SELECT(PERIPHS_IO_MUX_MTDO_U, FUNC_GPIO15); | ||||
|  | ||||
|                 pinMode(uart->rxPin, INPUT); | ||||
|                 pinMode(uart->txPin, INPUT); | ||||
|                 pinMode(1, SPECIAL);//TX | ||||
|                 pinMode(3, SPECIAL);//RX | ||||
|                 USWAP &= ~(1 << USWAP0); | ||||
|                 pinMode(15, INPUT);//TX | ||||
|                 pinMode(13, INPUT);//RX | ||||
|                 uart->rxPin = 3; | ||||
|                 uart->txPin = 1; | ||||
|             } | ||||
| @@ -433,9 +405,9 @@ void ICACHE_FLASH_ATTR uart0_write_char(char c) { | ||||
|         Serial.write(c); | ||||
|     } else { | ||||
|         if(c == '\n') { | ||||
|             WRITE_PERI_REG(UART_FIFO(0), '\r'); | ||||
|             USF(0) = '\r'; | ||||
|         } | ||||
|         WRITE_PERI_REG(UART_FIFO(0), c); | ||||
|         USF(0) = c; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -447,9 +419,9 @@ void ICACHE_FLASH_ATTR uart1_write_char(char c) { | ||||
|         Serial1.write(c); | ||||
|     } else { | ||||
|         if(c == '\n') { | ||||
|             WRITE_PERI_REG(UART_FIFO(1), '\r'); | ||||
|             USF(1) = '\r'; | ||||
|         } | ||||
|         WRITE_PERI_REG(UART_FIFO(1), c); | ||||
|         USF(1) = c; | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user