Software APIs
device_sim_qemu.c
Go to the documentation of this file.
1// Copyright lowRISC contributors (OpenTitan project).
2// Licensed under the Apache License, Version 2.0, see LICENSE for details.
3// SPDX-License-Identifier: Apache-2.0
4
5#include <stdbool.h>
6
7#include "dt/dt_rv_core_ibex.h" // Generated
10#include "sw/device/silicon_creator/lib/drivers/ibex.h"
11#include "sw/device/silicon_creator/lib/drivers/uart.h"
12
13#include "rv_core_ibex_regs.h" // Generated
14
15// Use the first dt_rv_core_ibex_t enum, i.e. the first Ibex core instance.
16static const dt_rv_core_ibex_t kRvCoreIbexDt = (dt_rv_core_ibex_t)0;
17static_assert(kDtRvCoreIbexCount == 1, "Only single core tops are supported");
18
19static inline uintptr_t rv_core_ibex_base(void) {
20 return (uintptr_t)dt_rv_core_ibex_primary_reg_block(kRvCoreIbexDt);
21}
22
23/**
24 * @file
25 * @brief Device-specific symbol definitions for the QEMU emulation.
26 */
27
29
30const uint64_t kClockFreqCpuMhz = 24;
31
32const uint64_t kClockFreqCpuHz = kClockFreqCpuMhz * 1000 * 1000;
33
34uint64_t to_cpu_cycles(uint64_t usec) { return usec * kClockFreqCpuMhz; }
35
36const uint64_t kClockFreqHiSpeedPeripheralHz = 24 * 1000 * 1000; // 24MHz
37
38const uint64_t kClockFreqPeripheralHz = 6 * 1000 * 1000; // 6MHz
39
40const uint64_t kClockFreqUsbHz = 48 * 1000 * 1000; // 48MHz
41
42const uint64_t kClockFreqAonHz = 250 * 1000; // 250kHz
43
44const uint64_t kUartBaudrate = 115200;
45
46const uint32_t kUartNCOValue =
47 CALCULATE_UART_NCO(kUartBaudrate, kClockFreqPeripheralHz);
48
49const uint32_t kUartBaud115K =
50 CALCULATE_UART_NCO(115200, kClockFreqPeripheralHz);
51const uint32_t kUartBaud230K =
52 CALCULATE_UART_NCO(115200 * 2, kClockFreqPeripheralHz);
53const uint32_t kUartBaud460K =
54 CALCULATE_UART_NCO(115200 * 4, kClockFreqPeripheralHz);
55const uint32_t kUartBaud921K =
56 CALCULATE_UART_NCO(115200 * 8, kClockFreqPeripheralHz);
57const uint32_t kUartBaud1M33 =
58 CALCULATE_UART_NCO(1333333, kClockFreqPeripheralHz);
59const uint32_t kUartBaud1M50 =
60 CALCULATE_UART_NCO(1500000, kClockFreqPeripheralHz);
61
62const uint32_t kAstCheckPollCpuCycles =
64
66 return rv_core_ibex_base() + RV_CORE_IBEX_DV_SIM_WINDOW_REG_OFFSET;
67}
68
69uintptr_t device_log_bypass_uart_address(void) { return 0; }