Loading...
1/*
2 * Copyright (C) 2012 Samsung Electronics.
3 * Kyungmin Park <kyungmin.park@samsung.com>
4 * Tomasz Figa <t.figa@samsung.com>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
9 */
10
11#ifndef __ASM_ARM_FIRMWARE_H
12#define __ASM_ARM_FIRMWARE_H
13
14#include <linux/bug.h>
15
16/*
17 * struct firmware_ops
18 *
19 * A structure to specify available firmware operations.
20 *
21 * A filled up structure can be registered with register_firmware_ops().
22 */
23struct firmware_ops {
24 /*
25 * Inform the firmware we intend to enter CPU idle mode
26 */
27 int (*prepare_idle)(void);
28 /*
29 * Enters CPU idle mode
30 */
31 int (*do_idle)(unsigned long mode);
32 /*
33 * Sets boot address of specified physical CPU
34 */
35 int (*set_cpu_boot_addr)(int cpu, unsigned long boot_addr);
36 /*
37 * Gets boot address of specified physical CPU
38 */
39 int (*get_cpu_boot_addr)(int cpu, unsigned long *boot_addr);
40 /*
41 * Boots specified physical CPU
42 */
43 int (*cpu_boot)(int cpu);
44 /*
45 * Initializes L2 cache
46 */
47 int (*l2x0_init)(void);
48 /*
49 * Enter system-wide suspend.
50 */
51 int (*suspend)(void);
52 /*
53 * Restore state of privileged hardware after system-wide suspend.
54 */
55 int (*resume)(void);
56};
57
58/* Global pointer for current firmware_ops structure, can't be NULL. */
59extern const struct firmware_ops *firmware_ops;
60
61/*
62 * call_firmware_op(op, ...)
63 *
64 * Checks if firmware operation is present and calls it,
65 * otherwise returns -ENOSYS
66 */
67#define call_firmware_op(op, ...) \
68 ((firmware_ops->op) ? firmware_ops->op(__VA_ARGS__) : (-ENOSYS))
69
70/*
71 * register_firmware_ops(ops)
72 *
73 * A function to register platform firmware_ops struct.
74 */
75static inline void register_firmware_ops(const struct firmware_ops *ops)
76{
77 BUG_ON(!ops);
78
79 firmware_ops = ops;
80}
81
82#endif
1/* SPDX-License-Identifier: GPL-2.0-only */
2/*
3 * Copyright (C) 2012 Samsung Electronics.
4 * Kyungmin Park <kyungmin.park@samsung.com>
5 * Tomasz Figa <t.figa@samsung.com>
6 */
7
8#ifndef __ASM_ARM_FIRMWARE_H
9#define __ASM_ARM_FIRMWARE_H
10
11#include <linux/bug.h>
12
13/*
14 * struct firmware_ops
15 *
16 * A structure to specify available firmware operations.
17 *
18 * A filled up structure can be registered with register_firmware_ops().
19 */
20struct firmware_ops {
21 /*
22 * Inform the firmware we intend to enter CPU idle mode
23 */
24 int (*prepare_idle)(unsigned long mode);
25 /*
26 * Enters CPU idle mode
27 */
28 int (*do_idle)(unsigned long mode);
29 /*
30 * Sets boot address of specified physical CPU
31 */
32 int (*set_cpu_boot_addr)(int cpu, unsigned long boot_addr);
33 /*
34 * Gets boot address of specified physical CPU
35 */
36 int (*get_cpu_boot_addr)(int cpu, unsigned long *boot_addr);
37 /*
38 * Boots specified physical CPU
39 */
40 int (*cpu_boot)(int cpu);
41 /*
42 * Initializes L2 cache
43 */
44 int (*l2x0_init)(void);
45 /*
46 * Enter system-wide suspend.
47 */
48 int (*suspend)(void);
49 /*
50 * Restore state of privileged hardware after system-wide suspend.
51 */
52 int (*resume)(void);
53};
54
55/* Global pointer for current firmware_ops structure, can't be NULL. */
56extern const struct firmware_ops *firmware_ops;
57
58/*
59 * call_firmware_op(op, ...)
60 *
61 * Checks if firmware operation is present and calls it,
62 * otherwise returns -ENOSYS
63 */
64#define call_firmware_op(op, ...) \
65 ((firmware_ops->op) ? firmware_ops->op(__VA_ARGS__) : (-ENOSYS))
66
67/*
68 * register_firmware_ops(ops)
69 *
70 * A function to register platform firmware_ops struct.
71 */
72static inline void register_firmware_ops(const struct firmware_ops *ops)
73{
74 BUG_ON(!ops);
75
76 firmware_ops = ops;
77}
78
79#endif