Merge pull request #610 from hathach/rp2040-followup2

Rp2040 followup2
This commit is contained in:
Ha Thach 2021-02-01 12:44:53 +07:00 committed by GitHub
commit 78f50518a4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 44 additions and 21 deletions

View File

@ -55,10 +55,6 @@ int main(void)
{ {
uint32_t interval_ms = board_button_read() ? BLINK_PRESSED : BLINK_UNPRESSED; uint32_t interval_ms = board_button_read() ? BLINK_PRESSED : BLINK_UNPRESSED;
// uart echo
// uint8_t ch;
// if ( board_uart_read(&ch, 1) ) board_uart_write(&ch, 1);
// Blink every interval ms // Blink every interval ms
if ( !(board_millis() - start_ms < interval_ms) ) if ( !(board_millis() - start_ms < interval_ms) )
{ {

View File

@ -35,10 +35,13 @@
#define LED_STATE_ON 1 #define LED_STATE_ON 1
// Button pin is BOOTSEL which is flash CS pin // Button pin is BOOTSEL which is flash CS pin
#define BUTTON_BOOTSEL #define BUTTON_BOOTSEL
#define BUTTON_STATE_ACTIVE 0 #define BUTTON_STATE_ACTIVE 0
#define UART_DEV uart0
#define UART_TX_PIN 0
#define UART_RX_PIN 1
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View File

@ -35,10 +35,13 @@
#define LED_STATE_ON 1 #define LED_STATE_ON 1
// Button pin is BOOTSEL which is flash CS pin // Button pin is BOOTSEL which is flash CS pin
#define BUTTON_BOOTSEL #define BUTTON_BOOTSEL
#define BUTTON_STATE_ACTIVE 0 #define BUTTON_STATE_ACTIVE 0
#define UART_DEV uart0
#define UART_TX_PIN 0
#define UART_RX_PIN 1
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View File

@ -36,10 +36,14 @@
#define LED_STATE_ON 1 #define LED_STATE_ON 1
// Button pin is BOOTSEL which is flash CS pin // Button pin is BOOTSEL which is flash CS pin
#define BUTTON_BOOTSEL #define BUTTON_BOOTSEL
#define BUTTON_STATE_ACTIVE 0 #define BUTTON_STATE_ACTIVE 0
#define UART_DEV uart0
#define UART_TX_PIN 0
#define UART_RX_PIN 1
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View File

@ -35,10 +35,13 @@
#define LED_STATE_ON 1 #define LED_STATE_ON 1
// Button pin is BOOTSEL which is flash CS pin // Button pin is BOOTSEL which is flash CS pin
#define BUTTON_BOOTSEL #define BUTTON_BOOTSEL
#define BUTTON_STATE_ACTIVE 0 #define BUTTON_STATE_ACTIVE 0
#define UART_DEV uart0
#define UART_TX_PIN 0
#define UART_RX_PIN 1
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View File

@ -78,7 +78,6 @@ bool __no_inline_not_in_flash_func(get_bootsel_button)() {
void board_init(void) void board_init(void)
{ {
setup_default_uart();
gpio_init(LED_PIN); gpio_init(LED_PIN);
gpio_set_dir(LED_PIN, GPIO_OUT); gpio_set_dir(LED_PIN, GPIO_OUT);
@ -86,6 +85,12 @@ void board_init(void)
#ifndef BUTTON_BOOTSEL #ifndef BUTTON_BOOTSEL
#endif #endif
#ifdef UART_DEV
uart_init(UART_DEV, CFG_BOARD_UART_BAUDRATE);
gpio_set_function(UART_TX_PIN, GPIO_FUNC_UART);
gpio_set_function(UART_RX_PIN, GPIO_FUNC_UART);
#endif
// todo probably set up device mode? // todo probably set up device mode?
#if TUSB_OPT_DEVICE_ENABLED #if TUSB_OPT_DEVICE_ENABLED
@ -116,18 +121,27 @@ uint32_t board_button_read(void)
int board_uart_read(uint8_t* buf, int len) int board_uart_read(uint8_t* buf, int len)
{ {
#ifdef UART_DEV
for(int i=0;i<len;i++) { for(int i=0;i<len;i++) {
buf[i] = uart_getc(uart_default); buf[i] = uart_getc(UART_DEV);
} }
return len;
#else
return 0; return 0;
#endif
} }
int board_uart_write(void const * buf, int len) int board_uart_write(void const * buf, int len)
{ {
#ifdef UART_DEV
char const* bufch = (uint8_t const*) buf;
for(int i=0;i<len;i++) { for(int i=0;i<len;i++) {
uart_putc(uart_default, ((char *)buf)[i]); uart_putc(UART_DEV, bufch[i]);
} }
return len;
#else
return 0; return 0;
#endif
} }
//--------------------------------------------------------------------+ //--------------------------------------------------------------------+

View File

@ -46,7 +46,6 @@
#define usb_hw_clear hw_clear_alias(usb_hw) #define usb_hw_clear hw_clear_alias(usb_hw)
// Init these in dcd_init // Init these in dcd_init
static uint8_t assigned_address;
static uint8_t *next_buffer_ptr; static uint8_t *next_buffer_ptr;
// Endpoints 0-15, direction 0 for out and 1 for in. // Endpoints 0-15, direction 0 for out and 1 for in.
@ -313,8 +312,7 @@ static void dcd_rp2040_irq(void)
if (status & USB_INTS_BUS_RESET_BITS) if (status & USB_INTS_BUS_RESET_BITS)
{ {
pico_trace("BUS RESET (addr %d -> %d)\n", assigned_address, 0); pico_trace("BUS RESET (addr %d -> %d)\n", assigned_address, 0);
assigned_address = 0; usb_hw->dev_addr_ctrl = 0;
usb_hw->dev_addr_ctrl = assigned_address;
handled |= USB_INTS_BUS_RESET_BITS; handled |= USB_INTS_BUS_RESET_BITS;
dcd_event_bus_signal(0, DCD_EVENT_BUS_RESET, true); dcd_event_bus_signal(0, DCD_EVENT_BUS_RESET, true);
usb_hw_clear->sie_status = USB_SIE_STATUS_BUS_RESET_BITS; usb_hw_clear->sie_status = USB_SIE_STATUS_BUS_RESET_BITS;
@ -349,7 +347,6 @@ void dcd_init (uint8_t rhport)
irq_set_exclusive_handler(USBCTRL_IRQ, dcd_rp2040_irq); irq_set_exclusive_handler(USBCTRL_IRQ, dcd_rp2040_irq);
memset(hw_endpoints, 0, sizeof(hw_endpoints)); memset(hw_endpoints, 0, sizeof(hw_endpoints));
assigned_address = 0;
next_buffer_ptr = &usb_dpram->epx_data[0]; next_buffer_ptr = &usb_dpram->epx_data[0];
// EP0 always exists so init it now // EP0 always exists so init it now
@ -388,14 +385,12 @@ void dcd_set_address (uint8_t rhport, uint8_t dev_addr)
assert(rhport == 0); assert(rhport == 0);
// Can't set device address in hardware until status xfer has complete // Can't set device address in hardware until status xfer has complete
assigned_address = dev_addr;
ep0_0len_status(); ep0_0len_status();
} }
void dcd_remote_wakeup(uint8_t rhport) void dcd_remote_wakeup(uint8_t rhport)
{ {
panic("dcd_remote_wakeup %d\n", rhport); pico_info("dcd_remote_wakeup %d is not supported yet\n", rhport);
assert(rhport == 0); assert(rhport == 0);
} }
@ -429,7 +424,7 @@ void dcd_edpt0_status_complete(uint8_t rhport, tusb_control_request_t const * re
request->bRequest == TUSB_REQ_SET_ADDRESS) request->bRequest == TUSB_REQ_SET_ADDRESS)
{ {
pico_trace("Set HW address %d\n", assigned_address); pico_trace("Set HW address %d\n", assigned_address);
usb_hw->dev_addr_ctrl = assigned_address; usb_hw->dev_addr_ctrl = (uint8_t) request->wValue;
} }
reset_ep0(); reset_ep0();

View File

@ -24,10 +24,13 @@
* This file is part of the TinyUSB stack. * This file is part of the TinyUSB stack.
*/ */
#include "tusb_option.h"
#if CFG_TUSB_MCU == OPT_MCU_RP2040
#include <stdlib.h> #include <stdlib.h>
#include "rp2040_usb.h" #include "rp2040_usb.h"
#include "hardware/clocks.h" #include "hardware/clocks.h"
#include "tusb_option.h"
// Direction strings for debug // Direction strings for debug
const char *ep_dir_string[] = { const char *ep_dir_string[] = {
@ -277,3 +280,4 @@ void _hw_endpoint_xfer(struct hw_endpoint *ep, uint8_t *buffer, uint16_t total_l
} }
} }
#endif

View File

@ -49,6 +49,7 @@ def build_family(example, family):
for entry in os.scandir("hw/bsp/{}/boards".format(family)): for entry in os.scandir("hw/bsp/{}/boards".format(family)):
if entry.is_dir(): if entry.is_dir():
all_boards.append(entry.name) all_boards.append(entry.name)
filter_with_input(all_boards)
all_boards.sort() all_boards.sort()
for board in all_boards: for board in all_boards:
@ -83,7 +84,7 @@ def build_board(example, board):
print(build_format.format(example, board, success, "{:.2f}s".format(build_duration), flash_size, sram_size)) print(build_format.format(example, board, success, "{:.2f}s".format(build_duration), flash_size, sram_size))
if build_result.returncode != 0: if build_result.returncode != 0:
print(build_result.stdout.decode("utf-8")) print(build_result.stdout.decode("utf-8"))
def build_size(example, board): def build_size(example, board):
#elf_file = 'examples/device/{}/_build/{}/{}-firmware.elf'.format(example, board, board) #elf_file = 'examples/device/{}/_build/{}/{}-firmware.elf'.format(example, board, board)