Linux Audio

Check our new training course

Loading...
v4.10.11
 
 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
v6.8
 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