xref: /openbmc/qemu/include/hw/register.h (revision 4d63ef20)
1 /*
2  * Register Definition API
3  *
4  * Copyright (c) 2016 Xilinx Inc.
5  * Copyright (c) 2013 Peter Crosthwaite <peter.crosthwaite@xilinx.com>
6  *
7  * This work is licensed under the terms of the GNU GPL, version 2.  See
8  * the COPYING file in the top-level directory.
9  */
10 
11 #ifndef REGISTER_H
12 #define REGISTER_H
13 
14 #include "hw/qdev-core.h"
15 #include "exec/memory.h"
16 #include "hw/registerfields.h"
17 #include "qom/object.h"
18 
19 typedef struct RegisterInfo RegisterInfo;
20 typedef struct RegisterAccessInfo RegisterAccessInfo;
21 typedef struct RegisterInfoArray RegisterInfoArray;
22 
23 /**
24  * Access description for a register that is part of guest accessible device
25  * state.
26  *
27  * @name: String name of the register
28  * @ro: whether or not the bit is read-only
29  * @w1c: bits with the common write 1 to clear semantic.
30  * @reset: reset value.
31  * @cor: Bits that are clear on read
32  * @rsvd: Bits that are reserved and should not be changed
33  *
34  * @pre_write: Pre write callback. Passed the value that's to be written,
35  * immediately before the actual write. The returned value is what is written,
36  * giving the handler a chance to modify the written value.
37  * @post_write: Post write callback. Passed the written value. Most write side
38  * effects should be implemented here. This is called during device reset.
39  *
40  * @post_read: Post read callback. Passes the value that is about to be returned
41  * for a read. The return value from this function is what is ultimately read,
42  * allowing this function to modify the value before return to the client.
43  */
44 
45 struct RegisterAccessInfo {
46     const char *name;
47     uint64_t ro;
48     uint64_t w1c;
49     uint64_t reset;
50     uint64_t cor;
51     uint64_t rsvd;
52     uint64_t unimp;
53 
54     uint64_t (*pre_write)(RegisterInfo *reg, uint64_t val);
55     void (*post_write)(RegisterInfo *reg, uint64_t val);
56 
57     uint64_t (*post_read)(RegisterInfo *reg, uint64_t val);
58 
59     hwaddr addr;
60 };
61 
62 /**
63  * A register that is part of guest accessible state
64  * @data: pointer to the register data. Will be cast
65  * to the relevant uint type depending on data_size.
66  * @data_size: Size of the register in bytes. Must be
67  * 1, 2, 4 or 8
68  *
69  * @access: Access description of this register
70  *
71  * @debug: Whether or not verbose debug is enabled
72  * @prefix: String prefix for log and debug messages
73  *
74  * @opaque: Opaque data for the register
75  */
76 
77 struct RegisterInfo {
78     /* <private> */
79     DeviceState parent_obj;
80 
81     /* <public> */
82     void *data;
83     int data_size;
84 
85     const RegisterAccessInfo *access;
86 
87     void *opaque;
88 };
89 
90 #define TYPE_REGISTER "qemu-register"
91 DECLARE_INSTANCE_CHECKER(RegisterInfo, REGISTER,
92                          TYPE_REGISTER)
93 
94 /**
95  * This structure is used to group all of the individual registers which are
96  * modeled using the RegisterInfo structure.
97  *
98  * @r is an array containing of all the relevant RegisterInfo structures.
99  *
100  * @num_elements is the number of elements in the array r
101  *
102  * @mem: optional Memory region for the register
103  */
104 
105 struct RegisterInfoArray {
106     MemoryRegion mem;
107 
108     int num_elements;
109     RegisterInfo **r;
110 
111     bool debug;
112     const char *prefix;
113 };
114 
115 /**
116  * write a value to a register, subject to its restrictions
117  * @reg: register to write to
118  * @val: value to write
119  * @we: write enable mask
120  * @prefix: The device prefix that should be printed before the register name
121  * @debug: Should the write operation debug information be printed?
122  */
123 
124 void register_write(RegisterInfo *reg, uint64_t val, uint64_t we,
125                     const char *prefix, bool debug);
126 
127 /**
128  * read a value from a register, subject to its restrictions
129  * @reg: register to read from
130  * @re: read enable mask
131  * @prefix: The device prefix that should be printed before the register name
132  * @debug: Should the read operation debug information be printed?
133  * returns: value read
134  */
135 
136 uint64_t register_read(RegisterInfo *reg, uint64_t re, const char* prefix,
137                        bool debug);
138 
139 /**
140  * Resets a register. This will also call the post_write hook if it exists.
141  * @reg: The register to reset.
142  */
143 
144 void register_reset(RegisterInfo *reg);
145 
146 /**
147  * Initialize a register.
148  * @reg: Register to initialize
149  */
150 
151 void register_init(RegisterInfo *reg);
152 
153 /**
154  * Memory API MMIO write handler that will write to a Register API register.
155  * @opaque: RegisterInfo to write to
156  * @addr: Address to write
157  * @value: Value to write
158  * @size: Number of bytes to write
159  */
160 
161 void register_write_memory(void *opaque, hwaddr addr, uint64_t value,
162                            unsigned size);
163 
164 /**
165  * Memory API MMIO read handler that will read from a Register API register.
166  * @opaque: RegisterInfo to read from
167  * @addr: Address to read
168  * @size: Number of bytes to read
169  * returns: Value read from register
170  */
171 
172 uint64_t register_read_memory(void *opaque, hwaddr addr, unsigned size);
173 
174 /**
175  * Init a block of registers into a container MemoryRegion. A
176  * number of constant register definitions are parsed to create a corresponding
177  * array of RegisterInfo's.
178  *
179  * @owner: device owning the registers
180  * @rae: Register definitions to init
181  * @num: number of registers to init (length of @rae)
182  * @ri: Register array to init, must already be allocated
183  * @data: Array to use for register data, must already be allocated
184  * @ops: Memory region ops to access registers.
185  * @debug enabled: turn on/off verbose debug information
186  * @memory_size: Size of the memory region
187  * returns: A structure containing all of the registers and an initialized
188  *          memory region (r_array->mem) the caller should add to a container.
189  */
190 
191 RegisterInfoArray *register_init_block8(DeviceState *owner,
192                                         const RegisterAccessInfo *rae,
193                                         int num, RegisterInfo *ri,
194                                         uint8_t *data,
195                                         const MemoryRegionOps *ops,
196                                         bool debug_enabled,
197                                         uint64_t memory_size);
198 
199 RegisterInfoArray *register_init_block32(DeviceState *owner,
200                                          const RegisterAccessInfo *rae,
201                                          int num, RegisterInfo *ri,
202                                          uint32_t *data,
203                                          const MemoryRegionOps *ops,
204                                          bool debug_enabled,
205                                          uint64_t memory_size);
206 
207 RegisterInfoArray *register_init_block64(DeviceState *owner,
208                                          const RegisterAccessInfo *rae,
209                                          int num, RegisterInfo *ri,
210                                          uint64_t *data,
211                                          const MemoryRegionOps *ops,
212                                          bool debug_enabled,
213                                          uint64_t memory_size);
214 
215 /**
216  * This function should be called to cleanup the registers that were initialized
217  * when calling register_init_block32(). This function should only be called
218  * from the device's instance_finalize function.
219  *
220  * Any memory operations that the device performed that require cleanup (such
221  * as creating subregions) need to be called before calling this function.
222  *
223  * @r_array: A structure containing all of the registers, as returned by
224  *           register_init_block32()
225  */
226 
227 void register_finalize_block(RegisterInfoArray *r_array);
228 
229 #endif
230