/** * struct reg - A register descriptor * @offset: Register offset relative to base of register memory * @stride: Distance between two instances, if parameterized * @fcount: Number of entries in the @fmask array * @fmask: Array of mask values defining position and width of fields * @name: Upper-case name of the register
*/ struct reg {
u32 offset;
u32 stride;
u32 fcount; const u32 *fmask; /* BIT(nr) or GENMASK(h, l) */ constchar *name;
};
/** * struct regs - Description of registers supported by hardware * @reg_count: Number of registers in the @reg[] array * @reg: Array of register descriptors
*/ struct regs {
u32 reg_count; conststruct reg **reg;
};
staticinlineconststruct reg *reg(conststruct regs *regs, u32 reg_id)
{ if (WARN(reg_id >= regs->reg_count, "reg out of range (%u > %u)\n", reg_id, regs->reg_count - 1)) return NULL;
return regs->reg[reg_id];
}
/* Return the field mask for a field in a register, or 0 on error */ staticinline u32 reg_fmask(conststruct reg *reg, u32 field_id)
{ if (!reg || WARN_ON(field_id >= reg->fcount)) return 0;
return reg->fmask[field_id];
}
/* Return the mask for a single-bit field in a register, or 0 on error */ staticinline u32 reg_bit(conststruct reg *reg, u32 field_id)
{
u32 fmask = reg_fmask(reg, field_id);
if (WARN_ON(!is_power_of_2(fmask))) return 0;
return fmask;
}
/* Return the maximum value representable by the given field; always 2^n - 1 */ staticinline u32 reg_field_max(conststruct reg *reg, u32 field_id)
{
u32 fmask = reg_fmask(reg, field_id);
return fmask ? fmask >> __ffs(fmask) : 0;
}
/* Encode a value into the given field of a register */ staticinline u32 reg_encode(conststruct reg *reg, u32 field_id, u32 val)
{
u32 fmask = reg_fmask(reg, field_id);
if (!fmask) return 0;
val <<= __ffs(fmask); if (WARN_ON(val & ~fmask)) return 0;
return val;
}
/* Given a register value, decode (extract) the value in the given field */ staticinline u32 reg_decode(conststruct reg *reg, u32 field_id, u32 val)
{
u32 fmask = reg_fmask(reg, field_id);
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.