2015-09-08 18:38:43 +02:00
|
|
|
/*
|
|
|
|
* hw/arm/linux-boot-if.h : interface for devices which need to behave
|
|
|
|
* specially for direct boot of an ARM Linux kernel
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef HW_ARM_LINUX_BOOT_IF_H
|
|
|
|
#define HW_ARM_LINUX_BOOT_IF_H
|
|
|
|
|
|
|
|
#include "qom/object.h"
|
|
|
|
|
|
|
|
#define TYPE_ARM_LINUX_BOOT_IF "arm-linux-boot-if"
|
2020-09-03 22:43:22 +02:00
|
|
|
typedef struct ARMLinuxBootIfClass ARMLinuxBootIfClass;
|
2020-08-31 23:07:33 +02:00
|
|
|
DECLARE_CLASS_CHECKERS(ARMLinuxBootIfClass, ARM_LINUX_BOOT_IF,
|
|
|
|
TYPE_ARM_LINUX_BOOT_IF)
|
2015-09-08 18:38:43 +02:00
|
|
|
#define ARM_LINUX_BOOT_IF(obj) \
|
|
|
|
INTERFACE_CHECK(ARMLinuxBootIf, (obj), TYPE_ARM_LINUX_BOOT_IF)
|
|
|
|
|
2018-12-04 15:20:06 +01:00
|
|
|
typedef struct ARMLinuxBootIf ARMLinuxBootIf;
|
2015-09-08 18:38:43 +02:00
|
|
|
|
2020-09-03 22:43:22 +02:00
|
|
|
struct ARMLinuxBootIfClass {
|
2015-09-08 18:38:43 +02:00
|
|
|
/*< private >*/
|
|
|
|
InterfaceClass parent_class;
|
|
|
|
|
|
|
|
/*< public >*/
|
|
|
|
/** arm_linux_init: configure the device for a direct boot
|
|
|
|
* of an ARM Linux kernel (so that device reset puts it into
|
|
|
|
* the state the kernel expects after firmware initialization,
|
|
|
|
* rather than the true hardware reset state). This callback is
|
|
|
|
* called once after machine construction is complete (before the
|
|
|
|
* first system reset).
|
|
|
|
*
|
|
|
|
* @obj: the object implementing this interface
|
|
|
|
* @secure_boot: true if we are booting Secure, false for NonSecure
|
|
|
|
* (or for a CPU which doesn't support TrustZone)
|
|
|
|
*/
|
|
|
|
void (*arm_linux_init)(ARMLinuxBootIf *obj, bool secure_boot);
|
2020-09-03 22:43:22 +02:00
|
|
|
};
|
2015-09-08 18:38:43 +02:00
|
|
|
|
|
|
|
#endif
|