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