Replace #define with enum

This commit is contained in:
Vladimir 'phcoder' Serbinenko 2011-10-01 21:03:03 +02:00
parent 2f82ea948d
commit 679cbb4020

View file

@ -39,11 +39,14 @@ GRUB_MOD_LICENSE ("GPLv3+");
#define GRUB_EHCI_PCI_SBRN_REG 0x60 #define GRUB_EHCI_PCI_SBRN_REG 0x60
/* Capability registers offsets */ /* Capability registers offsets */
#define GRUB_EHCI_EHCC_CAPLEN 0x00 /* byte */ enum
#define GRUB_EHCI_EHCC_VERSION 0x02 /* word */ {
#define GRUB_EHCI_EHCC_SPARAMS 0x04 /* dword */ GRUB_EHCI_EHCC_CAPLEN = 0x00, /* byte */
#define GRUB_EHCI_EHCC_CPARAMS 0x08 /* dword */ GRUB_EHCI_EHCC_VERSION = 0x02, /* word */
#define GRUB_EHCI_EHCC_PROUTE 0x0c /* 60 bits */ GRUB_EHCI_EHCC_SPARAMS = 0x04, /* dword */
GRUB_EHCI_EHCC_CPARAMS = 0x08, /* dword */
GRUB_EHCI_EHCC_PROUTE = 0x0c, /* 60 bits */
};
#define GRUB_EHCI_EECP_MASK (0xff << 8) #define GRUB_EHCI_EECP_MASK (0xff << 8)
#define GRUB_EHCI_EECP_SHIFT 8 #define GRUB_EHCI_EECP_SHIFT 8
@ -52,20 +55,26 @@ GRUB_MOD_LICENSE ("GPLv3+");
#define GRUB_EHCI_POINTER_MASK (~0x1f) #define GRUB_EHCI_POINTER_MASK (~0x1f)
/* Capability register SPARAMS bits */ /* Capability register SPARAMS bits */
#define GRUB_EHCI_SPARAMS_N_PORTS (0xf <<0) enum
#define GRUB_EHCI_SPARAMS_PPC (1<<4) /* Power port control */ {
#define GRUB_EHCI_SPARAMS_PRR (1<<7) /* Port routing rules */ GRUB_EHCI_SPARAMS_N_PORTS = (0xf << 0),
#define GRUB_EHCI_SPARAMS_N_PCC (0xf<<8) /* No of ports per comp. */ GRUB_EHCI_SPARAMS_PPC = (1 << 4), /* Power port control */
#define GRUB_EHCI_SPARAMS_NCC (0xf<<12) /* No of com. controllers */ GRUB_EHCI_SPARAMS_PRR = (1 << 7), /* Port routing rules */
#define GRUB_EHCI_SPARAMS_P_IND (1<<16) /* Port indicators present */ GRUB_EHCI_SPARAMS_N_PCC = (0xf << 8), /* No of ports per comp. */
#define GRUB_EHCI_SPARAMS_DEBUG_P (0xf<<20) /* Debug port */ GRUB_EHCI_SPARAMS_NCC = (0xf << 12), /* No of com. controllers */
GRUB_EHCI_SPARAMS_P_IND = (1 << 16), /* Port indicators present */
GRUB_EHCI_SPARAMS_DEBUG_P = (0xf << 20) /* Debug port */
};
#define GRUB_EHCI_MAX_N_PORTS 15 /* Max. number of ports */ #define GRUB_EHCI_MAX_N_PORTS 15 /* Max. number of ports */
/* Capability register CPARAMS bits */ /* Capability register CPARAMS bits */
#define GRUB_EHCI_CPARAMS_64BIT (1<<0) enum
#define GRUB_EHCI_CPARAMS_PROG_FRAMELIST (1<<1) {
#define GRUB_EHCI_CPARAMS_PARK_CAP (1<<2) GRUB_EHCI_CPARAMS_64BIT = (1 << 0),
GRUB_EHCI_CPARAMS_PROG_FRAMELIST = (1 << 1),
GRUB_EHCI_CPARAMS_PARK_CAP = (1 << 2)
};
#define GRUB_EHCI_N_FRAMELIST 1024 #define GRUB_EHCI_N_FRAMELIST 1024
#define GRUB_EHCI_N_QH 256 #define GRUB_EHCI_N_QH 256
@ -74,137 +83,177 @@ GRUB_MOD_LICENSE ("GPLv3+");
#define GRUB_EHCI_QH_EMPTY 1 #define GRUB_EHCI_QH_EMPTY 1
/* USBLEGSUP bits and related OS OWNED byte offset */ /* USBLEGSUP bits and related OS OWNED byte offset */
#define GRUB_EHCI_BIOS_OWNED (1<<16) enum
#define GRUB_EHCI_OS_OWNED (1<<24) {
GRUB_EHCI_BIOS_OWNED = (1 << 16),
GRUB_EHCI_OS_OWNED = (1 << 24)
};
/* Operational registers offsets */ /* Operational registers offsets */
#define GRUB_EHCI_COMMAND 0x00 enum
#define GRUB_EHCI_STATUS 0x04 {
#define GRUB_EHCI_INTERRUPT 0x08 GRUB_EHCI_COMMAND = 0x00,
#define GRUB_EHCI_FRAME_INDEX 0x0c GRUB_EHCI_STATUS = 0x04,
#define GRUB_EHCI_64BIT_SEL 0x10 GRUB_EHCI_INTERRUPT = 0x08,
#define GRUB_EHCI_FL_BASE 0x14 GRUB_EHCI_FRAME_INDEX = 0x0c,
#define GRUB_EHCI_CUR_AL_ADDR 0x18 GRUB_EHCI_64BIT_SEL = 0x10,
#define GRUB_EHCI_CONFIG_FLAG 0x40 GRUB_EHCI_FL_BASE = 0x14,
#define GRUB_EHCI_PORT_STAT_CMD 0x44 GRUB_EHCI_CUR_AL_ADDR = 0x18,
GRUB_EHCI_CONFIG_FLAG = 0x40,
GRUB_EHCI_PORT_STAT_CMD = 0x44
};
/* Operational register COMMAND bits */ /* Operational register COMMAND bits */
#define GRUB_EHCI_CMD_RUNSTOP (1<<0) enum
#define GRUB_EHCI_CMD_HC_RESET (1<<1) {
#define GRUB_EHCI_CMD_FL_SIZE (3<<2) GRUB_EHCI_CMD_RUNSTOP = (1 << 0),
#define GRUB_EHCI_CMD_PS_ENABL (1<<4) GRUB_EHCI_CMD_HC_RESET = (1 << 1),
#define GRUB_EHCI_CMD_AS_ENABL (1<<5) GRUB_EHCI_CMD_FL_SIZE = (3 << 2),
#define GRUB_EHCI_CMD_AS_ADV_D (1<<6) GRUB_EHCI_CMD_PS_ENABL = (1 << 4),
#define GRUB_EHCI_CMD_L_HC_RES (1<<7) GRUB_EHCI_CMD_AS_ENABL = (1 << 5),
#define GRUB_EHCI_CMD_AS_PARKM (3<<8) GRUB_EHCI_CMD_AS_ADV_D = (1 << 6),
#define GRUB_EHCI_CMD_AS_PARKE (1<<11) GRUB_EHCI_CMD_L_HC_RES = (1 << 7),
#define GRUB_EHCI_CMD_INT_THRS (0xff<<16) GRUB_EHCI_CMD_AS_PARKM = (3 << 8),
GRUB_EHCI_CMD_AS_PARKE = (1 << 11),
GRUB_EHCI_CMD_INT_THRS = (0xff << 16)
};
/* Operational register STATUS bits */ /* Operational register STATUS bits */
#define GRUB_EHCI_ST_INTERRUPT (1<<0) enum
#define GRUB_EHCI_ST_ERROR_INT (1<<1) {
#define GRUB_EHCI_ST_PORT_CHG (1<<2) GRUB_EHCI_ST_INTERRUPT = (1 << 0),
#define GRUB_EHCI_ST_FL_ROLLOVR (1<<3) GRUB_EHCI_ST_ERROR_INT = (1 << 1),
#define GRUB_EHCI_ST_HS_ERROR (1<<4) GRUB_EHCI_ST_PORT_CHG = (1 << 2),
#define GRUB_EHCI_ST_AS_ADVANCE (1<<5) GRUB_EHCI_ST_FL_ROLLOVR = (1 << 3),
#define GRUB_EHCI_ST_HC_HALTED (1<<12) GRUB_EHCI_ST_HS_ERROR = (1 << 4),
#define GRUB_EHCI_ST_RECLAM (1<<13) GRUB_EHCI_ST_AS_ADVANCE = (1 << 5),
#define GRUB_EHCI_ST_PS_STATUS (1<<14) GRUB_EHCI_ST_HC_HALTED = (1 << 12),
#define GRUB_EHCI_ST_AS_STATUS (1<<15) GRUB_EHCI_ST_RECLAM = (1 << 13),
GRUB_EHCI_ST_PS_STATUS = (1 << 14),
GRUB_EHCI_ST_AS_STATUS = (1 << 15)
};
/* Operational register PORT_STAT_CMD bits */ /* Operational register PORT_STAT_CMD bits */
#define GRUB_EHCI_PORT_CONNECT (1<<0) enum
#define GRUB_EHCI_PORT_CONNECT_CH (1<<1) {
#define GRUB_EHCI_PORT_ENABLED (1<<2) GRUB_EHCI_PORT_CONNECT = (1<<0),
#define GRUB_EHCI_PORT_ENABLED_CH (1<<3) GRUB_EHCI_PORT_CONNECT_CH = (1<<1),
#define GRUB_EHCI_PORT_OVERCUR (1<<4) GRUB_EHCI_PORT_ENABLED = (1<<2),
#define GRUB_EHCI_PORT_OVERCUR_CH (1<<5) GRUB_EHCI_PORT_ENABLED_CH = (1<<3),
#define GRUB_EHCI_PORT_RESUME (1<<6) GRUB_EHCI_PORT_OVERCUR = (1<<4),
#define GRUB_EHCI_PORT_SUSPEND (1<<7) GRUB_EHCI_PORT_OVERCUR_CH = (1<<5),
#define GRUB_EHCI_PORT_RESET (1<<8) GRUB_EHCI_PORT_RESUME = (1<<6),
#define GRUB_EHCI_PORT_LINE_STAT (3<<10) GRUB_EHCI_PORT_SUSPEND = (1<<7),
#define GRUB_EHCI_PORT_POWER (1<<12) GRUB_EHCI_PORT_RESET = (1<<8),
#define GRUB_EHCI_PORT_OWNER (1<<13) GRUB_EHCI_PORT_LINE_STAT = (3<<10),
#define GRUB_EHCI_PORT_INDICATOR (3<<14) GRUB_EHCI_PORT_POWER = (1<<12),
#define GRUB_EHCI_PORT_TEST (0xf<<16) GRUB_EHCI_PORT_OWNER = (1<<13),
#define GRUB_EHCI_PORT_WON_CONN_E (1<<20) GRUB_EHCI_PORT_INDICATOR = (3<<14),
#define GRUB_EHCI_PORT_WON_DISC_E (1<<21) GRUB_EHCI_PORT_TEST = (0xf<<16),
#define GRUB_EHCI_PORT_WON_OVER_E (1<<22) GRUB_EHCI_PORT_WON_CONN_E = (1<<20),
GRUB_EHCI_PORT_WON_DISC_E = (1<<21),
GRUB_EHCI_PORT_WON_OVER_E = (1<<22),
#define GRUB_EHCI_PORT_LINE_SE0 (0<<10) GRUB_EHCI_PORT_LINE_SE0 = (0<<10),
#define GRUB_EHCI_PORT_LINE_K (1<<10) GRUB_EHCI_PORT_LINE_K = (1<<10),
#define GRUB_EHCI_PORT_LINE_J (2<<10) GRUB_EHCI_PORT_LINE_J = (2<<10),
#define GRUB_EHCI_PORT_LINE_UNDEF (3<<10) GRUB_EHCI_PORT_LINE_UNDEF = (3<<10),
#define GRUB_EHCI_PORT_LINE_LOWSP GRUB_EHCI_PORT_LINE_K /* K state means low speed */ GRUB_EHCI_PORT_LINE_LOWSP = GRUB_EHCI_PORT_LINE_K, /* K state means low speed */
GRUB_EHCI_PORT_WMASK = ~(GRUB_EHCI_PORT_CONNECT_CH
#define GRUB_EHCI_PORT_WMASK ~(GRUB_EHCI_PORT_CONNECT_CH | \ | GRUB_EHCI_PORT_ENABLED_CH
GRUB_EHCI_PORT_ENABLED_CH | \ | GRUB_EHCI_PORT_OVERCUR_CH)
GRUB_EHCI_PORT_OVERCUR_CH) };
/* Operational register CONFIGFLAGS bits */ /* Operational register CONFIGFLAGS bits */
#define GRUB_EHCI_CF_EHCI_OWNER (1<<0) enum
{
GRUB_EHCI_CF_EHCI_OWNER = (1<<0)
};
/* Queue Head & Transfer Descriptor constants */ /* Queue Head & Transfer Descriptor constants */
#define GRUB_EHCI_HPTR_OFF 5 /* Horiz. pointer bit offset */ #define GRUB_EHCI_HPTR_OFF 5 /* Horiz. pointer bit offset */
#define GRUB_EHCI_HPTR_TYPE_MASK (3<<1) enum
#define GRUB_EHCI_HPTR_TYPE_ITD (0<<1) {
#define GRUB_EHCI_HPTR_TYPE_QH (1<<1) GRUB_EHCI_HPTR_TYPE_MASK = (3<<1),
#define GRUB_EHCI_HPTR_TYPE_SITD (2<<1) GRUB_EHCI_HPTR_TYPE_ITD = (0<<1),
#define GRUB_EHCI_HPTR_TYPE_FSTN (3<<1) GRUB_EHCI_HPTR_TYPE_QH = (1<<1),
GRUB_EHCI_HPTR_TYPE_SITD = (2<<1),
GRUB_EHCI_HPTR_TYPE_FSTN = (3<<1)
};
#define GRUB_EHCI_C (1<<27) enum
#define GRUB_EHCI_MAXPLEN_MASK (0x7ff<<16) {
#define GRUB_EHCI_MAXPLEN_OFF 16 GRUB_EHCI_C = (1<<27),
#define GRUB_EHCI_H (1<<15) GRUB_EHCI_MAXPLEN_MASK = (0x7ff<<16),
#define GRUB_EHCI_DTC (1<<14) GRUB_EHCI_H = (1<<15),
#define GRUB_EHCI_SPEED_MASK (3<<12) GRUB_EHCI_DTC = (1<<14),
#define GRUB_EHCI_SPEED_OFF 12 GRUB_EHCI_SPEED_MASK = (3<<12),
#define GRUB_EHCI_SPEED_FULL (0<<12) GRUB_EHCI_SPEED_FULL = (0<<12),
#define GRUB_EHCI_SPEED_LOW (1<<12) GRUB_EHCI_SPEED_LOW = (1<<12),
#define GRUB_EHCI_SPEED_HIGH (2<<12) GRUB_EHCI_SPEED_HIGH = (2<<12),
#define GRUB_EHCI_SPEED_RESERVED (3<<12) GRUB_EHCI_SPEED_RESERVED = (3<<12),
#define GRUB_EHCI_EP_NUM_MASK (0xf<<8) GRUB_EHCI_EP_NUM_MASK = (0xf<<8),
#define GRUB_EHCI_EP_NUM_OFF 8 GRUB_EHCI_DEVADDR_MASK = 0x7f,
#define GRUB_EHCI_DEVADDR_MASK 0x7f GRUB_EHCI_TARGET_MASK = (GRUB_EHCI_EP_NUM_MASK
| GRUB_EHCI_DEVADDR_MASK)
};
#define GRUB_EHCI_TARGET_MASK (GRUB_EHCI_EP_NUM_MASK \ enum
| GRUB_EHCI_DEVADDR_MASK) {
GRUB_EHCI_MAXPLEN_OFF = 16,
GRUB_EHCI_SPEED_OFF = 12,
GRUB_EHCI_EP_NUM_OFF = 8
};
#define GRUB_EHCI_MULT_MASK (3<30) enum
#define GRUB_EHCI_MULT_OFF 30 {
#define GRUB_EHCI_MULT_RESERVED (0<<30) GRUB_EHCI_MULT_MASK = (3<<30),
#define GRUB_EHCI_MULT_ONE (0<<30) GRUB_EHCI_MULT_RESERVED = (0<<30),
#define GRUB_EHCI_MULT_TWO (0<<30) GRUB_EHCI_MULT_ONE = (0<<30),
#define GRUB_EHCI_MULT_THREE (0<<30) GRUB_EHCI_MULT_TWO = (0<<30),
#define GRUB_EHCI_DEVPORT_MASK (0x7f<<23) GRUB_EHCI_MULT_THREE = (0<<30),
#define GRUB_EHCI_DEVPORT_OFF 23 GRUB_EHCI_DEVPORT_MASK = (0x7f<<23),
#define GRUB_EHCI_HUBADDR_MASK (0x7f<<16) GRUB_EHCI_HUBADDR_MASK = (0x7f<<16)
#define GRUB_EHCI_HUBADDR_OFF 16 };
enum
{
GRUB_EHCI_MULT_OFF = 30,
GRUB_EHCI_DEVPORT_OFF = 23,
GRUB_EHCI_HUBADDR_OFF = 16
};
#define GRUB_EHCI_TERMINATE (1<<0) #define GRUB_EHCI_TERMINATE (1<<0)
#define GRUB_EHCI_TOGGLE (1<<31) #define GRUB_EHCI_TOGGLE (1<<31)
#define GRUB_EHCI_TOTAL_MASK (0x7fff << 16) enum
#define GRUB_EHCI_TOTAL_OFF 16 {
#define GRUB_EHCI_CERR_MASK (3<<10) GRUB_EHCI_TOTAL_MASK = (0x7fff << 16),
#define GRUB_EHCI_CERR_OFF 10 GRUB_EHCI_CERR_MASK = (3<<10),
#define GRUB_EHCI_CERR_0 (0<<10) GRUB_EHCI_CERR_0 = (0<<10),
#define GRUB_EHCI_CERR_1 (1<<10) GRUB_EHCI_CERR_1 = (1<<10),
#define GRUB_EHCI_CERR_2 (2<<10) GRUB_EHCI_CERR_2 = (2<<10),
#define GRUB_EHCI_CERR_3 (3<<10) GRUB_EHCI_CERR_3 = (3<<10),
#define GRUB_EHCI_PIDCODE_OUT (0<<8) GRUB_EHCI_PIDCODE_OUT = (0<<8),
#define GRUB_EHCI_PIDCODE_IN (1<<8) GRUB_EHCI_PIDCODE_IN = (1<<8),
#define GRUB_EHCI_PIDCODE_SETUP (2<<8) GRUB_EHCI_PIDCODE_SETUP = (2<<8),
#define GRUB_EHCI_STATUS_MASK 0xff GRUB_EHCI_STATUS_MASK = 0xff,
#define GRUB_EHCI_STATUS_ACTIVE (1<<7) GRUB_EHCI_STATUS_ACTIVE = (1<<7),
#define GRUB_EHCI_STATUS_HALTED (1<<6) GRUB_EHCI_STATUS_HALTED = (1<<6),
#define GRUB_EHCI_STATUS_BUFERR (1<<5) GRUB_EHCI_STATUS_BUFERR = (1<<5),
#define GRUB_EHCI_STATUS_BABBLE (1<<4) GRUB_EHCI_STATUS_BABBLE = (1<<4),
#define GRUB_EHCI_STATUS_TRANERR (1<<3) GRUB_EHCI_STATUS_TRANERR = (1<<3),
#define GRUB_EHCI_STATUS_MISSDMF (1<<2) GRUB_EHCI_STATUS_MISSDMF = (1<<2),
#define GRUB_EHCI_STATUS_SPLITST (1<<1) GRUB_EHCI_STATUS_SPLITST = (1<<1),
#define GRUB_EHCI_STATUS_PINGERR (1<<0) GRUB_EHCI_STATUS_PINGERR = (1<<0)
};
enum
{
GRUB_EHCI_TOTAL_OFF = 16,
GRUB_EHCI_CERR_OFF = 10
};
#define GRUB_EHCI_BUFPTR_MASK (0xfffff<<12) #define GRUB_EHCI_BUFPTR_MASK (0xfffff<<12)
#define GRUB_EHCI_QHTDPTR_MASK 0xffffffe0 #define GRUB_EHCI_QHTDPTR_MASK 0xffffffe0
@ -214,10 +263,6 @@ GRUB_MOD_LICENSE ("GPLv3+");
#define GRUB_EHCI_BUFPAGELEN 0x1000 #define GRUB_EHCI_BUFPAGELEN 0x1000
#define GRUB_EHCI_MAXBUFLEN 0x5000 #define GRUB_EHCI_MAXBUFLEN 0x5000
#define GRUB_EHCI_QHPTR_TO_INDEX (qh) \
((grub_uint32_t)qh - (grub_uint32_t)e->qh) / \
sizeof(grub_ehci_qh_t)
struct grub_ehci_td; struct grub_ehci_td;
struct grub_ehci_qh; struct grub_ehci_qh;
typedef volatile struct grub_ehci_td *grub_ehci_td_t; typedef volatile struct grub_ehci_td *grub_ehci_td_t;