qemu/include/hw/register.h
<<
>>
Prefs
   1/*
   2 * Register Definition API
   3 *
   4 * Copyright (c) 2013 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/irq.h"
  17
  18typedef struct RegisterInfo RegisterInfo;
  19typedef struct RegisterAccessInfo RegisterAccessInfo;
  20typedef struct RegisterDecodeInfo RegisterDecodeInfo;
  21
  22/**
  23 * A register access error message
  24 * @mask: Bits in the register the error applies to
  25 * @reason: Reason why this access is an error
  26 */
  27
  28typedef struct RegisterAccessError {
  29    uint64_t mask;
  30    const char *reason;
  31} RegisterAccessError;
  32
  33#define REG_GPIO_POL_HIGH 0
  34#define REG_GPIO_POL_LOW  1
  35typedef struct RegisterGPIOMapping {
  36    const char *name;
  37    uint8_t bit_pos;
  38    bool input;
  39    bool polarity;
  40    uint8_t num;
  41    uint8_t width;
  42} RegisterGPIOMapping;
  43
  44/**
  45 * Access description for a register that is part of guest accessible device
  46 * state.
  47 *
  48 * @name: String name of the register
  49 * @ro: whether or not the bit is read-only
  50 * @w1c: bits with the common write 1 to clear semantic.
  51 * @reset: reset value.
  52 * @cor: Bits that are clear on read
  53 * @rsvd: Bits that are reserved and should not be changed
  54 *
  55 * @ge1: Bits that when written 1 indicate a guest error
  56 * @ge0: Bits that when written 0 indicate a guest error
  57 * @ui1: Bits that when written 1 indicate use of an unimplemented feature
  58 * @ui0: Bits that when written 0 indicate use of an unimplemented feature
  59 *
  60 * @pre_write: Pre write callback. Passed the value that's to be written,
  61 * immediately before the actual write. The returned value is what is written,
  62 * giving the handler a chance to modify the written value.
  63 * @post_write: Post write callback. Passed the written value. Most write side
  64 * effects should be implemented here.
  65 *
  66 * @post_read: Post read callback. Passes the value that is about to be returned
  67 * for a read. The return value from this function is what is ultimately read,
  68 * allowing this function to modify the value before return to the client.
  69 */
  70
  71#define REG_DECODE_READ (1 << 0)
  72#define REG_DECODE_WRITE (1 << 1)
  73#define REG_DECODE_EXECUTE (1 << 2)
  74#define REG_DECODE_RW (REG_DECODE_READ | REG_DECODE_WRITE)
  75
  76struct RegisterAccessInfo {
  77    const char *name;
  78    uint64_t ro;
  79    uint64_t w1c;
  80    uint64_t reset;
  81    uint64_t cor;
  82    uint64_t rsvd;
  83    /* HACK - get rid of me */
  84    uint64_t inhibit_reset;
  85
  86    const RegisterAccessError *ge0;
  87    const RegisterAccessError *ge1;
  88    const RegisterAccessError *ui0;
  89    const RegisterAccessError *ui1;
  90
  91    uint64_t (*pre_write)(RegisterInfo *reg, uint64_t val);
  92    void (*post_write)(RegisterInfo *reg, uint64_t val);
  93
  94    uint64_t (*post_read)(RegisterInfo *reg, uint64_t val);
  95
  96    const RegisterGPIOMapping *gpios;
  97
  98    size_t storage;
  99    int data_size;
 100
 101    struct {
 102        hwaddr addr;
 103        uint8_t flags;
 104    } decode;
 105
 106    void *opaque;
 107};
 108
 109/**
 110 * A register that is part of guest accessible state
 111 * @data: pointer to the register data. Will be cast
 112 * to the relevant uint type depending on data_size.
 113 * @data_size: Size of the register in bytes. Must be
 114 * 1, 2, 4 or 8
 115 * @data_big_endian: Define endianess of data register
 116 *
 117 * @access: Access desciption of this register
 118 *
 119 * @debug: Whether or not verbose debug is enabled
 120 * @prefix: String prefix for log and debug messages
 121 *
 122 * @opaque: Opaque data for the register
 123 *
 124 * @mem: optional Memory region for the register
 125 */
 126
 127struct RegisterInfo {
 128    DeviceState parent_obj;
 129
 130    void *data;
 131    int data_size;
 132
 133    const RegisterAccessInfo *access;
 134
 135    bool debug;
 136    const char *prefix;
 137
 138    void *opaque;
 139    /* private */
 140    bool read_lite;
 141    bool write_lite;
 142
 143    MemoryRegion mem;
 144};
 145
 146#define TYPE_REGISTER "qemu,register"
 147#define REGISTER(obj) OBJECT_CHECK(RegisterInfo, (obj), TYPE_REGISTER)
 148
 149struct RegisterDecodeInfo {
 150    RegisterInfo *reg;
 151    hwaddr addr;
 152    unsigned len;
 153};
 154
 155/**
 156 * write a value to a register, subject to its restrictions
 157 * @reg: register to write to
 158 * @val: value to write
 159 * @we: write enable mask
 160 */
 161
 162void register_write(RegisterInfo *reg, uint64_t val, uint64_t we);
 163
 164/**
 165 * read a value from a register, subject to its restrictions
 166 * @reg: register to read from
 167 * returns: value read
 168 */
 169
 170uint64_t register_read(RegisterInfo *reg);
 171
 172/**
 173 * reset a register
 174 * @reg: register to reset
 175 */
 176
 177void register_reset(RegisterInfo *reg);
 178
 179/**
 180 * initialize a register. Gpio's are setup as IOs to the specified device.
 181 * @reg: Register to initialize
 182 */
 183
 184void register_init(RegisterInfo *reg);
 185
 186/**
 187 * Refresh GPIO outputs based on diff between old value register current value.
 188 * GPIOs are refreshed for fields where the old value differs to the current
 189 * value.
 190 *
 191 * @reg: Register to refresh GPIO outs
 192 * @old_value: previous value of register
 193 */
 194
 195void register_refresh_gpios(RegisterInfo *reg, uint64_t old_value);
 196
 197void register_write_memory_be(void *opaque, hwaddr addr, uint64_t value,
 198                              unsigned size);
 199void register_write_memory_le(void *opaque, hwaddr addr, uint64_t value,
 200                              unsigned size);
 201
 202uint64_t register_read_memory_be(void *opaque, hwaddr addr, unsigned size);
 203uint64_t register_read_memory_le(void *opaque, hwaddr addr, unsigned size);
 204
 205/* Define constants for a 32 bit register */
 206
 207#define REG32(reg, addr) \
 208enum { A_ ## reg = (addr) }; \
 209enum { R_ ## reg = (addr) / 4 };
 210
 211/* Define SHIFT, LEGTH and MASK constants for a field within a register */
 212
 213#define FIELD(reg, field, length, shift) \
 214enum { R_ ## reg ## _ ## field ## _SHIFT = (shift)}; \
 215enum { R_ ## reg ## _ ## field ## _LENGTH = (length)}; \
 216enum { R_ ## reg ## _ ## field ## _MASK = (((1ULL << (length)) - 1) \
 217                                          << (shift)) };
 218
 219/* Extract a field from a register */
 220
 221#define F_EX32(storage, reg, field) \
 222    extract32((storage), R_ ## reg ## _ ## field ## _SHIFT, \
 223              R_ ## reg ## _ ## field ## _LENGTH)
 224
 225/* Extract a field from an array of registers */
 226
 227#define AF_EX32(regs, reg, field) \
 228    F_EX32((regs)[R_ ## reg], reg, field)
 229
 230/* Deposit a register field.  */
 231
 232#define F_DP32(storage, reg, field, val) ({                               \
 233    struct {                                                              \
 234        unsigned int v:R_ ## reg ## _ ## field ## _LENGTH;                \
 235    } v = { .v = val };                                                   \
 236    uint32_t d;                                                           \
 237    d = deposit32((storage), R_ ## reg ## _ ## field ## _SHIFT,           \
 238                  R_ ## reg ## _ ## field ## _LENGTH, v.v);               \
 239    d; })
 240
 241/* Deposit a field to array of registers.  */
 242
 243#define AF_DP32(regs, reg, field, val) \
 244    (regs)[R_ ## reg] = F_DP32((regs)[R_ ## reg], reg, field, val);
 245#endif
 246