/* * The MIT License (MIT) * * Copyright (c) 2018, hathach (tinyusb.org) * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. * * This file is part of the TinyUSB stack. */ #ifdef BOARD_PCA10056 #include "bsp/board.h" #include "nrfx/hal/nrf_gpio.h" #include "nrfx/drivers/include/nrfx_power.h" #include "nrfx/drivers/include/nrfx_qspi.h" #ifdef SOFTDEVICE_PRESENT #include "nrf_sdm.h" #include "nrf_soc.h" #endif #include "tusb.h" /*------------------------------------------------------------------*/ /* MACRO TYPEDEF CONSTANT ENUM *------------------------------------------------------------------*/ #define LED_PIN 13 #define LED_STATE_ON 0 uint8_t _button_pins[] = { 11, 12, 24, 25 }; #define BOARD_BUTTON_COUNT sizeof(_button_pins) /*------------------------------------------------------------------*/ /* TUSB HAL MILLISECOND *------------------------------------------------------------------*/ #if CFG_TUSB_OS == OPT_OS_NONE volatile uint32_t system_ticks = 0; void SysTick_Handler (void) { system_ticks++; } uint32_t tusb_hal_millis(void) { return board_tick2ms(system_ticks); } #endif /*------------------------------------------------------------------*/ /* BOARD API *------------------------------------------------------------------*/ enum { QSPI_CMD_RSTEN = 0x66, QSPI_CMD_RST = 0x99, QSPI_CMD_WRSR = 0x01, QSPI_CMD_READID = 0x90 }; /* tinyusb function that handles power event (detected, ready, removed) * We must call it within SD's SOC event handler, or set it as power event handler if SD is not enabled. */ extern void tusb_hal_nrf_power_event(uint32_t event); void board_init(void) { // Config clock source: XTAL or RC in sdk_config.h NRF_CLOCK->LFCLKSRC = (uint32_t)((CLOCK_LFCLKSRC_SRC_Xtal << CLOCK_LFCLKSRC_SRC_Pos) & CLOCK_LFCLKSRC_SRC_Msk); NRF_CLOCK->TASKS_LFCLKSTART = 1UL; // LEDs nrf_gpio_cfg_output(LED_PIN); board_led_control(false); // Button for(uint8_t i=0; iCINSTRDAT1; uint8_t mfgr_id = (uint8_t) ( NRF_QSPI->CINSTRDAT0 >> 24 ); // Switch to quad mode uint16_t sr_quad_en = 0x40; cinstr_cfg.opcode = QSPI_CMD_WRSR; cinstr_cfg.length = 3; cinstr_cfg.wipwait = cinstr_cfg.wren = true; nrfx_qspi_cinstr_xfer(&cinstr_cfg, &sr_quad_en, NULL); #endif NVIC_SetPriority(USBD_IRQn, 2); // USB power may already be ready at this time -> no event generated // We need to invoke the handler based on the status initially uint32_t usb_reg; #ifdef SOFTDEVICE_PRESENT // Enable to test enable SD before USB scenario #if 1 extern void nrf_error_cb(uint32_t id, uint32_t pc, uint32_t info); nrf_clock_lf_cfg_t clock_cfg = { // LFXO .source = NRF_CLOCK_LF_SRC_XTAL, .rc_ctiv = 0, .rc_temp_ctiv = 0, .accuracy = NRF_CLOCK_LF_ACCURACY_20_PPM }; sd_softdevice_enable(&clock_cfg, nrf_error_cb); NVIC_EnableIRQ(SD_EVT_IRQn); #endif uint8_t sd_en = false; sd_softdevice_is_enabled(&sd_en); if ( sd_en ) { sd_power_usbdetected_enable(true); sd_power_usbpwrrdy_enable(true); sd_power_usbremoved_enable(true); sd_power_usbregstatus_get(&usb_reg); }else #endif { // Power module init const nrfx_power_config_t pwr_cfg = { 0 }; nrfx_power_init(&pwr_cfg); // Register tusb function as USB power handler const nrfx_power_usbevt_config_t config = { .handler = (nrfx_power_usb_event_handler_t) tusb_hal_nrf_power_event }; nrfx_power_usbevt_init(&config); nrfx_power_usbevt_enable(); usb_reg = NRF_POWER->USBREGSTATUS; } if ( usb_reg & POWER_USBREGSTATUS_VBUSDETECT_Msk ) { tusb_hal_nrf_power_event(NRFX_POWER_USB_EVT_DETECTED); } if ( usb_reg & POWER_USBREGSTATUS_OUTPUTRDY_Msk ) { tusb_hal_nrf_power_event(NRFX_POWER_USB_EVT_READY); } } void board_led_control(bool state) { nrf_gpio_pin_write(LED_PIN, state ? LED_STATE_ON : (1-LED_STATE_ON)); } uint32_t board_buttons(void) { uint32_t ret = 0; for(uint8_t i=0; i= 0) tusb_hal_nrf_power_event(usbevt); } return err; } uint32_t proc_ble(void) { // do nothing with ble return NRF_ERROR_NOT_FOUND; } void SD_EVT_IRQHandler(void) { // process BLE and SOC until there is no more events while( (NRF_ERROR_NOT_FOUND != proc_ble()) || (NRF_ERROR_NOT_FOUND != proc_soc()) ) { } } void nrf_error_cb(uint32_t id, uint32_t pc, uint32_t info) { (void) id; (void) pc; (void) info; } #endif #endif