Anforderungen  |   Konzepte  |   Entwurf  |   Entwicklung  |   Qualitätssicherung  |   Lebenszyklus  |   Steuerung
 
 
 
 


Quelle  reboot.h   Sprache: C

 
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _LINUX_REBOOT_H
#define _LINUX_REBOOT_H


#include <linux/notifier.h>
#include <uapi/linux/reboot.h>

struct device;
struct sys_off_handler;

#define SYS_DOWN 0x0001 /* Notify of system down */
#define SYS_RESTART SYS_DOWN
#define SYS_HALT 0x0002 /* Notify of system halt */
#define SYS_POWER_OFF 0x0003 /* Notify of system power off */

enum reboot_mode {
 REBOOT_UNDEFINED = -1,
 REBOOT_COLD = 0,
 REBOOT_WARM,
 REBOOT_HARD,
 REBOOT_SOFT,
 REBOOT_GPIO,
};
extern enum reboot_mode reboot_mode;
extern enum reboot_mode panic_reboot_mode;

enum reboot_type {
 BOOT_TRIPLE = 't',
 BOOT_KBD = 'k',
 BOOT_BIOS = 'b',
 BOOT_ACPI = 'a',
 BOOT_EFI = 'e',
 BOOT_CF9_FORCE = 'p',
 BOOT_CF9_SAFE = 'q',
};
extern enum reboot_type reboot_type;

extern int reboot_default;
extern int reboot_cpu;
extern int reboot_force;


extern int register_reboot_notifier(struct notifier_block *);
extern int unregister_reboot_notifier(struct notifier_block *);

extern int devm_register_reboot_notifier(struct device *, struct notifier_block *);

extern int register_restart_handler(struct notifier_block *);
extern int unregister_restart_handler(struct notifier_block *);
extern void do_kernel_restart(char *cmd);

/*
 * Architecture-specific implementations of sys_reboot commands.
 */


extern void migrate_to_reboot_cpu(void);
extern void machine_restart(char *cmd);
extern void machine_halt(void);
extern void machine_power_off(void);

extern void machine_shutdown(void);
struct pt_regs;
extern void machine_crash_shutdown(struct pt_regs *);

void do_kernel_power_off(void);

/*
 * sys-off handler API.
 */


/*
 * Standard sys-off priority levels. Users are expected to set priorities
 * relative to the standard levels.
 *
 * SYS_OFF_PRIO_PLATFORM: Use this for platform-level handlers.
 *
 * SYS_OFF_PRIO_LOW: Use this for handler of last resort.
 *
 * SYS_OFF_PRIO_DEFAULT: Use this for normal handlers.
 *
 * SYS_OFF_PRIO_HIGH: Use this for higher priority handlers.
 *
 * SYS_OFF_PRIO_FIRMWARE: Use this if handler uses firmware call.
 */

#define SYS_OFF_PRIO_PLATFORM  -256
#define SYS_OFF_PRIO_LOW  -128
#define SYS_OFF_PRIO_DEFAULT  0
#define SYS_OFF_PRIO_HIGH  192
#define SYS_OFF_PRIO_FIRMWARE  224

enum sys_off_mode {
 /**
 * @SYS_OFF_MODE_POWER_OFF_PREPARE:
 *
 * Handlers prepare system to be powered off. Handlers are
 * allowed to sleep.
 */

 SYS_OFF_MODE_POWER_OFF_PREPARE,

 /**
 * @SYS_OFF_MODE_POWER_OFF:
 *
 * Handlers power-off system. Handlers are disallowed to sleep.
 */

 SYS_OFF_MODE_POWER_OFF,

 /**
 * @SYS_OFF_MODE_RESTART_PREPARE:
 *
 * Handlers prepare system to be restarted. Handlers are
 * allowed to sleep.
 */

 SYS_OFF_MODE_RESTART_PREPARE,

 /**
 * @SYS_OFF_MODE_RESTART:
 *
 * Handlers restart system. Handlers are disallowed to sleep.
 */

 SYS_OFF_MODE_RESTART,
};

/**
 * struct sys_off_data - sys-off callback argument
 *
 * @mode: Mode ID. Currently used only by the sys-off restart mode,
 *        see enum reboot_mode for the available modes.
 * @cb_data: User's callback data.
 * @cmd: Command string. Currently used only by the sys-off restart mode,
 *       NULL otherwise.
 * @dev: Device of the sys-off handler. Only if known (devm_register_*),
 *       NULL otherwise.
 */

struct sys_off_data {
 int mode;
 void *cb_data;
 const char *cmd;
 struct device *dev;
};

struct sys_off_handler *
register_sys_off_handler(enum sys_off_mode mode,
    int priority,
    int (*callback)(struct sys_off_data *data),
    void *cb_data);
void unregister_sys_off_handler(struct sys_off_handler *handler);

int devm_register_sys_off_handler(struct device *dev,
      enum sys_off_mode mode,
      int priority,
      int (*callback)(struct sys_off_data *data),
      void *cb_data);

int devm_register_power_off_handler(struct device *dev,
        int (*callback)(struct sys_off_data *data),
        void *cb_data);

int devm_register_restart_handler(struct device *dev,
      int (*callback)(struct sys_off_data *data),
      void *cb_data);

int register_platform_power_off(void (*power_off)(void));
void unregister_platform_power_off(void (*power_off)(void));

/*
 * Architecture independent implemenations of sys_reboot commands.
 */


extern void kernel_restart_prepare(char *cmd);
extern void kernel_restart(char *cmd);
extern void kernel_halt(void);
extern void kernel_power_off(void);
extern bool kernel_can_power_off(void);

void ctrl_alt_del(void);

extern void orderly_poweroff(bool force);
extern void orderly_reboot(void);

/**
 * enum hw_protection_action - Hardware protection action
 *
 * @HWPROT_ACT_DEFAULT:
 *      The default action should be taken. This is HWPROT_ACT_SHUTDOWN
 *      by default, but can be overridden.
 * @HWPROT_ACT_SHUTDOWN:
 * The system should be shut down (powered off) for HW protection.
 * @HWPROT_ACT_REBOOT:
 * The system should be rebooted for HW protection.
 */

enum hw_protection_action { HWPROT_ACT_DEFAULT, HWPROT_ACT_SHUTDOWN, HWPROT_ACT_REBOOT };

void __hw_protection_trigger(const char *reason, int ms_until_forced,
        enum hw_protection_action action);

/**
 * hw_protection_trigger - Trigger default emergency system hardware protection action
 *
 * @reason: Reason of emergency shutdown or reboot to be printed.
 * @ms_until_forced: Time to wait for orderly shutdown or reboot before
 * triggering it. Negative value disables the forced
 * shutdown or reboot.
 *
 * Initiate an emergency system shutdown or reboot in order to protect
 * hardware from further damage. The exact action taken is controllable at
 * runtime and defaults to shutdown.
 */

static inline void hw_protection_trigger(const char *reason, int ms_until_forced)
{
 __hw_protection_trigger(reason, ms_until_forced, HWPROT_ACT_DEFAULT);
}

/*
 * Emergency restart, callable from an interrupt handler.
 */


extern void emergency_restart(void);
#include <asm/emergency-restart.h>

#endif /* _LINUX_REBOOT_H */

99%


¤ Dauer der Verarbeitung: 0.12 Sekunden  (vorverarbeitet)  ¤

*© Formatika GbR, Deutschland






Wurzel

Suchen

Beweissystem der NASA

Beweissystem Isabelle

NIST Cobol Testsuite

Cephes Mathematical Library

Wiener Entwicklungsmethode

Haftungshinweis

Die Informationen auf dieser Webseite wurden nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit, noch Qualität der bereit gestellten Informationen zugesichert.

Bemerkung:

Die farbliche Syntaxdarstellung ist noch experimentell.






                                                                                                                                                                                                                                                                                                                                                                                                     


Neuigkeiten

     Aktuelles
     Motto des Tages

Software

     Produkte
     Quellcodebibliothek

Aktivitäten

     Artikel über Sicherheit
     Anleitung zur Aktivierung von SSL

Muße

     Gedichte
     Musik
     Bilder

Jenseits des Üblichen ....

Besucherstatistik

Besucherstatistik

Monitoring

Montastic status badge