2019-02-26 02:02:50 +03:00
|
|
|
/*
|
|
|
|
** Copyright 2003, Axel Dörfler, axeld@pinc-software.de. All rights reserved.
|
|
|
|
** Distributed under the terms of the MIT License.
|
|
|
|
*/
|
|
|
|
#ifndef KERNEL_ARCH_RISCV64_KERNEL_ARGS_H
|
|
|
|
#define KERNEL_ARCH_RISCV64_KERNEL_ARGS_H
|
|
|
|
|
|
|
|
#ifndef KERNEL_BOOT_KERNEL_ARGS_H
|
|
|
|
# error This file is included from <boot/kernel_args.h> only
|
|
|
|
#endif
|
|
|
|
|
2020-02-05 23:04:08 +03:00
|
|
|
|
|
|
|
#include <util/FixedWidthPointer.h>
|
2021-08-18 03:03:21 +03:00
|
|
|
#include <boot/uart.h>
|
2020-02-05 23:04:08 +03:00
|
|
|
|
|
|
|
|
2019-04-04 22:20:14 +03:00
|
|
|
#define _PACKED __attribute__((packed))
|
|
|
|
|
|
|
|
#define MAX_VIRTUAL_RANGES_TO_KEEP 32
|
|
|
|
|
|
|
|
|
2021-07-25 21:09:02 +03:00
|
|
|
enum {
|
2021-06-06 16:57:41 +03:00
|
|
|
kPlatformNone,
|
|
|
|
kPlatformMNative,
|
|
|
|
kPlatformSbi,
|
2021-07-25 21:09:02 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2019-02-26 02:02:50 +03:00
|
|
|
// kernel args
|
|
|
|
typedef struct {
|
2021-07-25 21:09:02 +03:00
|
|
|
// Virtual address range of RAM physical memory mapping region
|
|
|
|
addr_range physMap;
|
|
|
|
|
2019-04-04 22:20:14 +03:00
|
|
|
// The virtual ranges we want to keep in the kernel.
|
|
|
|
uint32 num_virtual_ranges_to_keep;
|
|
|
|
addr_range virtual_ranges_to_keep[MAX_VIRTUAL_RANGES_TO_KEEP];
|
2020-02-05 23:04:08 +03:00
|
|
|
|
2021-06-06 16:57:41 +03:00
|
|
|
// MNative hooks, or SBI
|
|
|
|
uint32 machine_platform;
|
2021-07-25 21:09:02 +03:00
|
|
|
|
2021-08-17 18:16:39 +03:00
|
|
|
uint64 timerFrequency; // in Hz
|
2021-07-25 21:09:02 +03:00
|
|
|
|
|
|
|
// All following address are virtual
|
2020-02-05 23:04:08 +03:00
|
|
|
FixedWidthPointer<void> acpi_root;
|
2021-04-22 20:15:57 +03:00
|
|
|
FixedWidthPointer<void> fdt;
|
2021-07-25 21:09:02 +03:00
|
|
|
|
|
|
|
addr_range htif;
|
|
|
|
addr_range plic;
|
|
|
|
addr_range clint;
|
2021-08-18 03:03:21 +03:00
|
|
|
|
|
|
|
uart_info uart;
|
2021-11-09 21:39:16 +03:00
|
|
|
|
|
|
|
uint32 hartIds[SMP_MAX_CPUS];
|
|
|
|
uint32 plicContexts[SMP_MAX_CPUS];
|
2020-02-05 23:04:08 +03:00
|
|
|
} _PACKED arch_kernel_args;
|
2019-02-26 02:02:50 +03:00
|
|
|
|
|
|
|
#endif /* KERNEL_ARCH_RISCV64_KERNEL_ARGS_H */
|