#define S12Z_H
/* This byte is used to prefix instructions in "page 2" of the opcode
- space */
+ space. */
#define PAGE2_PREBYTE (0x1b)
struct reg
{
- char *name; /* The canonical name of the register */
- int bytes; /* its size, in bytes */
+ char *name; /* The canonical name of the register. */
+ int bytes; /* its size, in bytes. */
};
/* How many registers do we have. Actually there are only 13,
because CCL and CCH are the low and high bytes of CCW. But
for assemnbly / disassembly purposes they are considered
- distinct registers. */
+ distinct registers. */
#define S12Z_N_REGISTERS 15
extern const struct reg registers[S12Z_N_REGISTERS];
-enum {
+/* Solaris defines REG_Y in sys/regset.h; undef it here to avoid
+ breaking compilation when this target is enabled. */
+#undef REG_Y
+
+enum
+ {
REG_D2 = 0,
REG_D3,
REG_D4,
REG_CCW
};
-/* Any of the registers d0, d1, ... d7 */
+/* Any of the registers d0, d1, ... d7. */
#define REG_BIT_Dn \
((0x1U << REG_D2) | \
(0x1U << REG_D3) | \
(0x1U << REG_D0) | \
(0x1U << REG_D1))
-/* Any of the registers x, y or z */
+/* Any of the registers x, y or z. */
#define REG_BIT_XYS \
((0x1U << REG_X) | \
(0x1U << REG_Y) | \
(0x1U << REG_S))
-/* Any of the registers x, y, z or p */
+/* Any of the registers x, y, z or p. */
#define REG_BIT_XYSP \
((0x1U << REG_X) | \
(0x1U << REG_Y) | \
(0x1U << REG_S) | \
(0x1U << REG_P))
-/* The x register or the y register */
+/* The x register or the y register. */
#define REG_BIT_XY \
((0x1U << REG_X) | \
(0x1U << REG_Y))
-
#endif