blob: 5b9c7f3fe4c60bc0e6e8af7d893f93ed35259919 [file] [log] [blame]
// Copyright 2016 The Fuchsia Authors
// Copyright (c) 2008 Travis Geiselbrecht
//
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file or at
// https://opensource.org/licenses/MIT
#ifndef ZIRCON_KERNEL_INCLUDE_PLATFORM_H_
#define ZIRCON_KERNEL_INCLUDE_PLATFORM_H_
#include <sys/types.h>
#include <zircon/boot/crash-reason.h>
#include <zircon/boot/image.h>
#include <zircon/compiler.h>
#include <zircon/types.h>
__BEGIN_CDECLS
#define BOOT_CPU_ID 0
typedef enum {
HALT_ACTION_HALT = 0, // Spin forever.
HALT_ACTION_REBOOT, // Reset the CPU.
HALT_ACTION_REBOOT_BOOTLOADER, // Reboot into the bootloader.
HALT_ACTION_REBOOT_RECOVERY, // Reboot into the recovery partition.
HALT_ACTION_SHUTDOWN, // Shutdown and power off.
} platform_halt_action;
/* current time in nanoseconds */
zx_time_t current_time(void);
/* high-precision timer ticks per second */
zx_ticks_t ticks_per_second(void);
/* Reads a platform-specific fixed-rate monotonic counter
* The "raw" form of the counter should give the current counter value (and is
* almost certainly not what you want). The normal form will give the counter
* value, potentially adjusted by a constant used to make the ticks timeline
* start ticking from 0 when the system boots.
*/
zx_ticks_t platform_current_raw_ticks(void);
zx_ticks_t platform_current_ticks(void);
/* Access the platform specific offset from the raw ticks timeline to the ticks
* timeline. The only current legit uses for this function are when
* initializing the RO data for the VDSO, and when fixing up timer values during
* vmexit on ARM (see arch/arm64/hypervisor/vmexit.cc).
*/
zx_ticks_t platform_get_raw_ticks_to_ticks_offset(void);
/* high-precision timer current_ticks */
static inline zx_ticks_t current_ticks(void) { return platform_current_ticks(); }
/* a bool indicating whether or not user mode has direct access to the registers
* which allow directly observing the tick counter or not. */
bool platform_usermode_can_access_tick_registers(void);
/* super early platform initialization, before almost everything */
void platform_early_init(void);
/* Perform any set up required before virtual memory is enabled, or the heap is set up. */
void platform_prevm_init(void);
/* later init, after the kernel has come up */
void platform_init(void);
/* platform_halt halts the system and performs the |suggested_action|.
*
* This function is used in both the graceful shutdown and panic paths so it
* does not perform more complex actions like switching to the primary CPU,
* unloading the run queue of secondary CPUs, stopping secondary CPUs, etc.
*
* There is no returning from this function.
*/
void platform_halt(platform_halt_action suggested_action, zircon_crash_reason_t reason) __NO_RETURN;
/* The platform specific actions to be taken in a halt situation. This is a
* weak symbol meant to be overloaded by platform specific implementations and
* called from the common |platform_halt| implementation. Do not call this
* function directly, call |platform_halt| instead.
*
* There is no returning from this function.
*/
void platform_specific_halt(platform_halt_action suggested_action, zircon_crash_reason_t reason,
bool halt_on_panic) __NO_RETURN;
/* optionally stop the current cpu in a way the platform finds appropriate */
void platform_halt_cpu(void);
// Called just before initiating a system suspend to give the platform layer a
// chance to save state. Must be called with interrupts disabled.
void platform_suspend(void);
// Called immediately after resuming from a system suspend to let the platform layer
// reinitialize arch components. Must be called with interrupts disabled.
void platform_resume(void);
// Returns true if this system has a debug serial port that is enabled
bool platform_serial_enabled(void);
// Returns true if the early graphics console is enabled
bool platform_early_console_enabled(void);
// Accessors for the HW reboot reason which may or may not have been delivered
// by the bootloader.
void platform_set_hw_reboot_reason(zbi_hw_reboot_reason_t reason);
zbi_hw_reboot_reason_t platform_hw_reboot_reason(void);
// TODO(fxbug.dev/91213): Remove this when zx_pc_firmware_tables() goes away.
extern zx_paddr_t gAcpiRsdp;
// TODO(fxbug.dev/91213): Remove this when zx_pc_firmware_tables() goes away.
extern zx_paddr_t gSmbiosPhys;
__END_CDECLS
#ifdef __cplusplus
#include <lib/arch/ticks.h>
#include <ktl/string_view.h>
namespace affine {
class Ratio; // Fwd decl.
} // namespace affine
// Setter/getter pair for the ratio which defines the relationship between the
// system's tick counter, and the current_time/clock_monotonic clock. This gets
// set once by architecture specific plaform code, after an appropriate ticks
// source has been selected and characterized.
void platform_set_ticks_to_time_ratio(const affine::Ratio& ticks_to_time);
const affine::Ratio& platform_get_ticks_to_time_ratio(void);
// Convert a sample taken early on to a proper zx_ticks_t, if possible.
// This returns 0 if early samples are not convertible.
zx_ticks_t platform_convert_early_ticks(arch::EarlyTicks sample);
// platform_panic_start informs the system that a panic message is about
// to be printed and that platform_halt will be called shortly. The
// platform should stop other CPUs if requested and do whatever is necessary
// to safely ensure that the panic message will be visible to the user.
enum class PanicStartHaltOtherCpus { No = 0, Yes };
void platform_panic_start(PanicStartHaltOtherCpus option = PanicStartHaltOtherCpus::Yes);
#endif // __cplusplus
#endif // ZIRCON_KERNEL_INCLUDE_PLATFORM_H_