URL
https://opencores.org/ocsvn/neorv32/neorv32/trunk
Subversion Repositories neorv32
Compare Revisions
- This comparison shows the changes necessary to convert path
/neorv32/trunk/sw/lib
- from Rev 65 to Rev 66
- ↔ Reverse comparison
Rev 65 → Rev 66
/include/neorv32.h
492,6 → 492,89
|
|
/**********************************************************************//** |
* @defgroup FIRQ_ALIASES Fast Interrupt Requests (FIRQ) Aliases (MIE, MIP, MCAUSE, RTE-ID) |
* @name Fast Interrupt Requests (FIRQ) Aliases (MIE, MIP, MCAUSE, RTE-ID) |
**************************************************************************/ |
/**@{*/ |
/** @name Watchdog Timer (WDT) */ |
/**@{*/ |
#define WDT_FIRQ_ENABLE CSR_MIE_FIRQ0E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define WDT_FIRQ_PENDING CSR_MIP_FIRQ0P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define WDT_RTE_ID RTE_TRAP_FIRQ_0 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define WDT_TRAP_CODE TRAP_CODE_FIRQ_0 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
/**@}*/ |
/** @name Custom Functions Subsystem (CFS) */ |
/**@{*/ |
#define CFS_FIRQ_ENABLE CSR_MIE_FIRQ1E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define CFS_FIRQ_PENDING CSR_MIP_FIRQ1P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define CFS_RTE_ID RTE_TRAP_FIRQ_1 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define CFS_TRAP_CODE TRAP_CODE_FIRQ_1 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
/**@}*/ |
/** @name Primary Universal Asynchronous Receiver/Transmitter (UART0) */ |
/**@{*/ |
#define UART0_RX_FIRQ_ENABLE CSR_MIE_FIRQ2E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define UART0_RX_FIRQ_PENDING CSR_MIP_FIRQ2P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define UART0_RX_RTE_ID RTE_TRAP_FIRQ_2 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define UART0_RX_TRAP_CODE TRAP_CODE_FIRQ_2 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
#define UART0_TX_FIRQ_ENABLE CSR_MIE_FIRQ3E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define UART0_TX_FIRQ_PENDING CSR_MIP_FIRQ3P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define UART0_TX_RTE_ID RTE_TRAP_FIRQ_3 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define UART0_TX_TRAP_CODE TRAP_CODE_FIRQ_4 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
/**@}*/ |
/** @name Secondary Universal Asynchronous Receiver/Transmitter (UART1) */ |
/**@{*/ |
#define UART1_RX_FIRQ_ENABLE CSR_MIE_FIRQ4E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define UART1_RX_FIRQ_PENDING CSR_MIP_FIRQ4P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define UART1_RX_RTE_ID RTE_TRAP_FIRQ_4 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define UART1_RX_TRAP_CODE TRAP_CODE_FIRQ_4 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
#define UART1_TX_FIRQ_ENABLE CSR_MIE_FIRQ5E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define UART1_TX_FIRQ_PENDING CSR_MIP_FIRQ5P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define UART1_TX_RTE_ID RTE_TRAP_FIRQ_5 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define UART1_TX_TRAP_CODE TRAP_CODE_FIRQ_5 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
/**@}*/ |
/** @name Serial Peripheral Interface (SPI) */ |
/**@{*/ |
#define SPI_FIRQ_ENABLE CSR_MIE_FIRQ6E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define SPI_FIRQ_PENDING CSR_MIP_FIRQ6P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define SPI_RTE_ID RTE_TRAP_FIRQ_6 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define SPI_TRAP_CODE TRAP_CODE_FIRQ_6 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
/**@}*/ |
/** @name Two-Wire Interface (TWI) */ |
/**@{*/ |
#define TWI_FIRQ_ENABLE CSR_MIE_FIRQ7E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define TWI_FIRQ_PENDING CSR_MIP_FIRQ7P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define TWI_RTE_ID RTE_TRAP_FIRQ_7 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define TWI_TRAP_CODE TRAP_CODE_FIRQ_7 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
/**@}*/ |
/** @name External Interrupt Controller (XIRQ) */ |
/**@{*/ |
#define XIRQ_FIRQ_ENABLE CSR_MIE_FIRQ8E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define XIRQ_FIRQ_PENDING CSR_MIP_FIRQ8P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define XIRQ_RTE_ID RTE_TRAP_FIRQ_8 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define XIRQ_TRAP_CODE TRAP_CODE_FIRQ_8 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
/**@}*/ |
/** @name Smart LED Controller (NEOLED) */ |
/**@{*/ |
#define NEOLED_FIRQ_ENABLE CSR_MIE_FIRQ9E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define NEOLED_FIRQ_PENDING CSR_MIP_FIRQ9P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define NEOLED_RTE_ID RTE_TRAP_FIRQ_9 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define NEOLED_TRAP_CODE TRAP_CODE_FIRQ_9 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
/**@}*/ |
/** @name Stream Link Interface (SLINK) */ |
/**@{*/ |
#define SLINK_RX_FIRQ_ENABLE CSR_MIE_FIRQ10E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define SLINK_RX_FIRQ_PENDING CSR_MIP_FIRQ10P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define SLINK_RX_RTE_ID RTE_TRAP_FIRQ_10 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define SLINK_RX_TRAP_CODE TRAP_CODE_FIRQ_10 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
#define SLINK_TX_FIRQ_ENABLE CSR_MIE_FIRQ11E /**< MIE CSR bit (#NEORV32_CSR_MIE_enum) */ |
#define SLINK_TX_FIRQ_PENDING CSR_MIP_FIRQ11P /**< MIP CSR bit (#NEORV32_CSR_MIP_enum) */ |
#define SLINK_TX_RTE_ID RTE_TRAP_FIRQ_11 /**< RTE entry code (#NEORV32_RTE_TRAP_enum) */ |
#define SLINK_TX_TRAP_CODE TRAP_CODE_FIRQ_11 /**< MCAUSE CSR trap code (#NEORV32_EXCEPTION_CODES_enum) */ |
/**@}*/ |
/**@}*/ |
|
|
/**********************************************************************//** |
* @name Address space sections |
**************************************************************************/ |
/**@{*/ |
719,6 → 802,27
|
|
/**********************************************************************//** |
* @name IO Device: Bus Monitor (BUSKEEPER) |
**************************************************************************/ |
/**@{*/ |
/** BUSKEEPER module prototype */ |
typedef struct __attribute__((packed,aligned(4))) { |
uint32_t CTRL; /**< offset 0: control register (#NEORV32_BUSKEEPER_CTRL_enum) */ |
} neorv32_buskeeper_t; |
|
/** BUSKEEPER module hardware access (#neorv32_buskeeper_t) */ |
#define NEORV32_BUSKEEPER (*((volatile neorv32_buskeeper_t*) (0xFFFFFF7CUL))) |
|
/** BUSKEEPER control/data register bits */ |
enum NEORV32_BUSKEEPER_CTRL_enum { |
BUSKEEPER_ERR_TYPE = 0, /**< BUSKEEPER control register(0) (r/-): Bus error type: 0=device error, 1=access timeout */ |
BUSKEEPER_ERR_SRC = 1, /**< BUSKEEPER control register(1) (r/-): Bus error source: 0=processor-external, 1=processor-internal */ |
BUSKEEPER_ERR_FLAG = 31 /**< BUSKEEPER control register(31) (r/c): Sticky error flag, clears after read */ |
}; |
/**@}*/ |
|
|
/**********************************************************************//** |
* @name IO Device: External Interrupt Controller (XIRQ) |
**************************************************************************/ |
/**@{*/ |
805,8 → 909,8
UART_CTRL_PRSC2 = 26, /**< UART control register(26) (r/w): BAUD rate clock prescaler select bit 2 */ |
UART_CTRL_CTS = 27, /**< UART control register(27) (r/-): current state of CTS input */ |
UART_CTRL_EN = 28, /**< UART control register(28) (r/w): UART global enable */ |
UART_CTRL_RX_IRQ = 29, /**< UART control register(29) (r/w: RX IRQ mode: 1=FIFO at least half-full; 0=FIFO not empty */ |
UART_CTRL_TX_IRQ = 30, /**< UART control register(30) (r/w: TX IRQ mode: 1=FIFO less than half-full; 0=FIFO not full */ |
UART_CTRL_RX_IRQ = 29, /**< UART control register(29) (r/w): RX IRQ mode: 1=FIFO at least half-full; 0=FIFO not empty */ |
UART_CTRL_TX_IRQ = 30, /**< UART control register(30) (r/w): TX IRQ mode: 1=FIFO less than half-full; 0=FIFO not full */ |
UART_CTRL_TX_BUSY = 31 /**< UART control register(31) (r/-): Transmitter is busy when set */ |
}; |
|
1056,13 → 1160,12
SYSINFO_CPU_ZICSR = 0, /**< SYSINFO_CPU (0): Zicsr extension (I sub-extension) available when set (r/-) */ |
SYSINFO_CPU_ZIFENCEI = 1, /**< SYSINFO_CPU (1): Zifencei extension (I sub-extension) available when set (r/-) */ |
SYSINFO_CPU_ZMMUL = 2, /**< SYSINFO_CPU (2): Zmmul extension (M sub-extension) available when set (r/-) */ |
SYSINFO_CPU_ZBB = 3, /**< SYSINFO_CPU (3): Zbb extension (B sub-extension) available when set (r/-) */ |
|
SYSINFO_CPU_ZFINX = 5, /**< SYSINFO_CPU (5): Zfinx extension (F sub-/alternative-extension) available when set (r/-) */ |
SYSINFO_CPU_ZXSCNT = 6, /**< SYSINFO_CPU (6): Custom extension - Small CPU counters: "cycle" & "instret" CSRs have less than 64-bit when set (r/-) */ |
SYSINFO_CPU_ZXNOCNT = 7, /**< SYSINFO_CPU (7): Custom extension - NO CPU counters: "cycle" & "instret" CSRs are NOT available at all when set (r/-) */ |
SYSINFO_CPU_ZICNTR = 7, /**< SYSINFO_CPU (7): Basie CPU counters available when set (r/-) */ |
SYSINFO_CPU_PMP = 8, /**< SYSINFO_CPU (8): PMP (physical memory protection) extension available when set (r/-) */ |
SYSINFO_CPU_HPM = 9, /**< SYSINFO_CPU (9): HPM (hardware performance monitors) extension available when set (r/-) */ |
SYSINFO_CPU_ZIHPM = 9, /**< SYSINFO_CPU (9): HPM (hardware performance monitors) extension available when set (r/-) */ |
SYSINFO_CPU_DEBUGMODE = 10, /**< SYSINFO_CPU (10): RISC-V CPU debug mode available when set (r/-) */ |
|
SYSINFO_CPU_FASTMUL = 30, /**< SYSINFO_CPU (30): fast multiplications (via FAST_MUL_EN generic) available when set (r/-) */ |
/include/neorv32_spi.h
52,6 → 52,8
void neorv32_spi_cs_en(uint8_t cs); |
void neorv32_spi_cs_dis(uint8_t cs); |
uint32_t neorv32_spi_trans(uint32_t tx_data); |
void neorv32_spi_put_nonblocking(uint32_t tx_data); |
uint32_t neorv32_spi_get_nonblocking(void); |
int neorv32_spi_busy(void); |
|
#endif // neorv32_spi_h |
/include/neorv32_xirq.h
36,26 → 36,12
/**********************************************************************//** |
* @file neorv32_xirq.h |
* @author Stephan Nolting |
* @brief SExternal Interrupt controller HW driver header file. |
* @brief External Interrupt controller HW driver header file. |
**************************************************************************/ |
|
#ifndef neorv32_xirq_h |
#define neorv32_xirq_h |
|
|
/**********************************************************************//** |
* @name XIRQ fast interrupt channel |
**************************************************************************/ |
/**@{*/ |
/** XIRQ MIE FIRQ bit */ |
#define XIRQ_FIRQ_ENABLE CSR_MIE_FIRQ8E // MIE FIRQ bit |
/** XIRQ MIP FIRQ bit */ |
#define XIRQ_FIRQ_PENDING CSR_MIP_FIRQ8P // MIP FIRQ bit |
/** XIRQ RTE IRQ ID */ |
#define XIRQ_RTE_ID RTE_TRAP_FIRQ_8 // RTE IRQ ID |
/**@}*/ |
|
|
// prototypes |
int neorv32_xirq_available(void); |
int neorv32_xirq_setup(void); |
/source/neorv32_cpu.c
612,7 → 612,7
uint32_t neorv32_cpu_hpm_get_counters(void) { |
|
// HPMs implemented at all? |
if ((NEORV32_SYSINFO.CPU & (1<<SYSINFO_CPU_HPM)) == 0) { |
if ((NEORV32_SYSINFO.CPU & (1<<SYSINFO_CPU_ZIHPM)) == 0) { |
return 0; |
} |
|
695,7 → 695,7
uint32_t neorv32_cpu_hpm_get_size(void) { |
|
// HPMs implemented at all? |
if ((NEORV32_SYSINFO.CPU & (1<<SYSINFO_CPU_HPM)) == 0) { |
if ((NEORV32_SYSINFO.CPU & (1<<SYSINFO_CPU_ZIHPM)) == 0) { |
return 0; |
} |
|
/source/neorv32_neoled.c
96,7 → 96,7
|
/**********************************************************************//** |
* Configure NEOLED controller for using WS2812 LEDs (NeoPixel-compatible). This function computes |
* all the required timings and finally calls #neorv32_neoled_setup_raw. |
* all the required timings and finally calls #neorv32_neoled_setup. |
* |
* @note WS2812 timing: T_period = 1.2us, T_high_zero = 0.4us, T_high_one = 0.8us. Change the constants if required. |
* @note This function uses the SYSINFO_CLK value (from the SYSINFO HW module) to do the timing computations. |
/source/neorv32_rte.c
202,14 → 202,12
return; // handler cannot output anything if UART0 is not implemented |
} |
|
char tmp; |
|
// intro |
neorv32_uart0_print("<RTE> "); |
|
// cause |
register uint32_t trap_cause = neorv32_cpu_csr_read(CSR_MCAUSE); |
tmp = (char)(trap_cause & 0xf); |
register char tmp = (char)(trap_cause & 0xf); |
if (tmp >= 10) { |
tmp = 'a' + (tmp - 10); |
} |
249,9 → 247,25
default: neorv32_uart0_print("Unknown trap cause: "); __neorv32_rte_print_hex_word(trap_cause); break; |
} |
|
// check cause if bus access fault exception |
if ((trap_cause == TRAP_CODE_I_ACCESS) || (trap_cause == TRAP_CODE_L_ACCESS) || (trap_cause == TRAP_CODE_S_ACCESS)) { |
register uint32_t bus_err = NEORV32_BUSKEEPER.CTRL; |
if (bus_err & (1<<BUSKEEPER_ERR_FLAG)) { // exception caused by bus system? |
if (bus_err & (1<<BUSKEEPER_ERR_TYPE)) { |
neorv32_uart0_print(" [TIMEOUT_ERR]"); |
} |
else { |
neorv32_uart0_print(" [DEVICE_ERR]"); |
} |
} |
else { // exception was not caused by bus system -> has to be caused by PMP rule violation |
neorv32_uart0_print(" [PMP_ERR]"); |
} |
} |
|
// instruction address |
neorv32_uart0_print(" @ PC="); |
__neorv32_rte_print_hex_word(neorv32_cpu_csr_read(CSR_MSCRATCH)); // rte core stores actual mepc to mscratch |
__neorv32_rte_print_hex_word(neorv32_cpu_csr_read(CSR_MSCRATCH)); // rte core stores original mepc to mscratch |
|
// additional info |
neorv32_uart0_print(", MTVAL="); |
324,6 → 338,12
if (tmp & (1<<SYSINFO_CPU_ZICSR)) { |
neorv32_uart0_printf("Zicsr "); |
} |
if (tmp & (1<<SYSINFO_CPU_ZICNTR)) { |
neorv32_uart0_printf("Zicntr "); |
} |
if (tmp & (1<<SYSINFO_CPU_ZIHPM)) { |
neorv32_uart0_printf("Zihpm "); |
} |
if (tmp & (1<<SYSINFO_CPU_ZIFENCEI)) { |
neorv32_uart0_printf("Zifencei "); |
} |
330,23 → 350,16
if (tmp & (1<<SYSINFO_CPU_ZMMUL)) { |
neorv32_uart0_printf("Zmmul "); |
} |
if (tmp & (1<<SYSINFO_CPU_ZBB)) { |
neorv32_uart0_printf("Zbb "); |
} |
|
if (tmp & (1<<SYSINFO_CPU_ZFINX)) { |
neorv32_uart0_printf("Zfinx "); |
} |
if (tmp & (1<<SYSINFO_CPU_ZXNOCNT)) { |
neorv32_uart0_printf("Zxnocnt(!) "); |
} |
if (tmp & (1<<SYSINFO_CPU_ZXSCNT)) { |
neorv32_uart0_printf("Zxscnt(!) "); |
} |
|
if (tmp & (1<<SYSINFO_CPU_DEBUGMODE)) { |
neorv32_uart0_printf("Debug-Mode "); |
neorv32_uart0_printf("Debug "); |
} |
|
if (tmp & (1<<SYSINFO_CPU_FASTMUL)) { |
neorv32_uart0_printf("FAST_MUL "); |
} |
364,14 → 377,11
neorv32_uart0_printf("not implemented\n"); |
} |
|
// check hardware performance monitors |
neorv32_uart0_printf("HPM Counters: %u counters, %u-bit wide\n", neorv32_cpu_hpm_get_counters(), neorv32_cpu_hpm_get_size()); |
|
|
// Memory configuration |
neorv32_uart0_printf("\n=== << Memory System >> ===\n"); |
|
neorv32_uart0_printf("Boot Config.: Boot "); |
neorv32_uart0_printf("Boot Config.: Boot "); |
if (NEORV32_SYSINFO.SOC & (1 << SYSINFO_SOC_BOOTLOADER)) { |
neorv32_uart0_printf("via Bootloader\n"); |
} |
379,10 → 389,10
neorv32_uart0_printf("from memory (@ 0x%x)\n", NEORV32_SYSINFO.ISPACE_BASE); |
} |
|
neorv32_uart0_printf("Instr. base address: 0x%x\n", NEORV32_SYSINFO.ISPACE_BASE); |
neorv32_uart0_printf("Instr. base address: 0x%x\n", NEORV32_SYSINFO.ISPACE_BASE); |
|
// IMEM |
neorv32_uart0_printf("Internal IMEM: "); |
neorv32_uart0_printf("Internal IMEM: "); |
if (NEORV32_SYSINFO.SOC & (1 << SYSINFO_SOC_MEM_INT_IMEM)) { |
neorv32_uart0_printf("yes, %u bytes\n", NEORV32_SYSINFO.IMEM_SIZE); |
} |
391,8 → 401,8
} |
|
// DMEM |
neorv32_uart0_printf("Data base address: 0x%x\n", NEORV32_SYSINFO.DSPACE_BASE); |
neorv32_uart0_printf("Internal DMEM: "); |
neorv32_uart0_printf("Data base address: 0x%x\n", NEORV32_SYSINFO.DSPACE_BASE); |
neorv32_uart0_printf("Internal DMEM: "); |
if (NEORV32_SYSINFO.SOC & (1 << SYSINFO_SOC_MEM_INT_DMEM)) { |
neorv32_uart0_printf("yes, %u bytes\n", NEORV32_SYSINFO.DMEM_SIZE); |
} |
401,7 → 411,7
} |
|
// i-cache |
neorv32_uart0_printf("Internal i-cache: "); |
neorv32_uart0_printf("Internal i-cache: "); |
if (NEORV32_SYSINFO.SOC & (1 << SYSINFO_SOC_ICACHE)) { |
neorv32_uart0_printf("yes, "); |
|
439,9 → 449,9
neorv32_uart0_printf("no\n"); |
} |
|
neorv32_uart0_printf("Ext. bus interface: "); |
neorv32_uart0_printf("Ext. bus interface: "); |
__neorv32_rte_print_true_false(NEORV32_SYSINFO.SOC & (1 << SYSINFO_SOC_MEM_EXT)); |
neorv32_uart0_printf("Ext. bus Endianness: "); |
neorv32_uart0_printf("Ext. bus Endianness: "); |
if (NEORV32_SYSINFO.SOC & (1 << SYSINFO_SOC_MEM_EXT_ENDIAN)) { |
neorv32_uart0_printf("big\n"); |
} |
/source/neorv32_slink.c
34,7 → 34,7
|
|
/**********************************************************************//** |
* @file neorv32_slink.h |
* @file neorv32_slink.c |
* @author Stephan Nolting |
* @brief Stream Link Interface HW driver source file. |
**************************************************************************/ |
/source/neorv32_spi.c
143,8 → 143,6
/**********************************************************************//** |
* Initiate SPI transfer. |
* |
* @warning The SPI always sends MSB first. |
* |
* @note This function is blocking. |
* |
* @param tx_data Transmit data (8/16/24/32-bit, LSB-aligned). |
160,6 → 158,28
|
|
/**********************************************************************//** |
* Initiate SPI TX transfer (non-blocking). |
* |
* @param tx_data Transmit data (8/16/24/32-bit, LSB-aligned). |
**************************************************************************/ |
void neorv32_spi_put_nonblocking(uint32_t tx_data) { |
|
NEORV32_SPI.DATA = tx_data; // trigger transfer |
} |
|
|
/**********************************************************************//** |
* Get SPI RX data (non-blocking). |
* |
* @return Receive data (8/16/24/32-bit, LSB-aligned). |
**************************************************************************/ |
uint32_t neorv32_spi_get_nonblocking(void) { |
|
return NEORV32_SPI.DATA; |
} |
|
|
/**********************************************************************//** |
* Check if SPI transceiver is busy. |
* |
* @return 0 if idle, 1 if busy |
/source/neorv32_uart.c
256,11 → 256,10
uint8_t p = 0; // initial prsc = CLK/2 |
|
// raw clock prescaler |
#ifdef __riscv_div |
// use div instructions |
#ifndef make_bootloader |
i = (uint16_t)(clock / (2*baudrate)); |
#else |
// division via repeated subtraction |
// division via repeated subtraction (minimal size, only for bootloader) |
while (clock >= 2*baudrate) { |
clock -= 2*baudrate; |
i++; |
626,11 → 625,11
uint8_t p = 0; // initial prsc = CLK/2 |
|
// raw clock prescaler |
#ifdef __riscv_div |
#ifdef make_bootloader |
// use div instructions |
i = (uint16_t)(clock / (2*baudrate)); |
#else |
// division via repeated subtraction |
// division via repeated subtraction (minimal size, only for bootloader) |
while (clock >= 2*baudrate) { |
clock -= 2*baudrate; |
i++; |
/source/neorv32_xirq.c
34,7 → 34,7
|
|
/**********************************************************************//** |
* @file neorv32_xirq.h |
* @file neorv32_xirq.c |
* @author Stephan Nolting |
* @brief External Interrupt controller HW driver source file. |
**************************************************************************/ |
/README.md
3,4 → 3,4
This folder provides the hardware abstraction layer (HAL) libraries for the CPU itself and the individual processor modules (peripheral/IO devices). |
|
The `source` folder contains the actual C-code hardware driver functions (*.c*) while the `include` folder provides the according header files (*.h). |
Application programs should only include the *main NEORV32 define file* `source/neorv32.h`. This file automatically includes all other provided header files. |
Application programs should only include the *main NEORV32 define file* `include/neorv32.h`. This file automatically includes all other provided header files. |