/* SPDX-License-Identifier: GPL-2.0+ */1#ifndef __CF_FSI_FW_H2#define __CF_FSI_FW_H34/*5* uCode file layout6*7* 0000...03ff : m68k exception vectors8* 0400...04ff : Header info & boot config block9* 0500....... : Code & stack10*/1112/*13* Header info & boot config area14*15* The Header info is built into the ucode and provide version and16* platform information.17*18* the Boot config needs to be adjusted by the ARM prior to starting19* the ucode if the Command/Status area isn't at 0x320000 in CF space20* (ie. beginning of SRAM).21*/2223#define HDR_OFFSET 0x4002425/* Info: Signature & version */26#define HDR_SYS_SIG 0x00 /* 2 bytes system signature */27#define SYS_SIG_SHARED 0x534828#define SYS_SIG_SPLIT 0x535029#define HDR_FW_VERS 0x02 /* 2 bytes Major.Minor */30#define HDR_API_VERS 0x04 /* 2 bytes Major.Minor */31#define API_VERSION_MAJ 2 /* Current version */32#define API_VERSION_MIN 133#define HDR_FW_OPTIONS 0x08 /* 4 bytes option flags */34#define FW_OPTION_TRACE_EN 0x00000001 /* FW tracing enabled */35#define FW_OPTION_CONT_CLOCK 0x00000002 /* Continuous clocking supported */36#define HDR_FW_SIZE 0x10 /* 4 bytes size for combo image */3738/* Boot Config: Address of Command/Status area */39#define HDR_CMD_STAT_AREA 0x80 /* 4 bytes CF address */40#define HDR_FW_CONTROL 0x84 /* 4 bytes control flags */41#define FW_CONTROL_CONT_CLOCK 0x00000002 /* Continuous clocking enabled */42#define FW_CONTROL_DUMMY_RD 0x00000004 /* Extra dummy read (AST2400) */43#define FW_CONTROL_USE_STOP 0x00000008 /* Use STOP instructions */44#define HDR_CLOCK_GPIO_VADDR 0x90 /* 2 bytes offset from GPIO base */45#define HDR_CLOCK_GPIO_DADDR 0x92 /* 2 bytes offset from GPIO base */46#define HDR_DATA_GPIO_VADDR 0x94 /* 2 bytes offset from GPIO base */47#define HDR_DATA_GPIO_DADDR 0x96 /* 2 bytes offset from GPIO base */48#define HDR_TRANS_GPIO_VADDR 0x98 /* 2 bytes offset from GPIO base */49#define HDR_TRANS_GPIO_DADDR 0x9a /* 2 bytes offset from GPIO base */50#define HDR_CLOCK_GPIO_BIT 0x9c /* 1 byte bit number */51#define HDR_DATA_GPIO_BIT 0x9d /* 1 byte bit number */52#define HDR_TRANS_GPIO_BIT 0x9e /* 1 byte bit number */5354/*55* Command/Status area layout: Main part56*/5758/* Command/Status register:59*60* +---------------------------+61* | STAT | RLEN | CLEN | CMD |62* | 8 | 8 | 8 | 8 |63* +---------------------------+64* | | | |65* status | | |66* Response len | |67* (in bits) | |68* | |69* Command len |70* (in bits) |71* |72* Command code73*74* Due to the big endian layout, that means that a byte read will75* return the status byte76*/77#define CMD_STAT_REG 0x0078#define CMD_REG_CMD_MASK 0x000000ff79#define CMD_REG_CMD_SHIFT 080#define CMD_NONE 0x0081#define CMD_COMMAND 0x0182#define CMD_BREAK 0x0283#define CMD_IDLE_CLOCKS 0x03 /* clen = #clocks */84#define CMD_INVALID 0xff85#define CMD_REG_CLEN_MASK 0x0000ff0086#define CMD_REG_CLEN_SHIFT 887#define CMD_REG_RLEN_MASK 0x00ff000088#define CMD_REG_RLEN_SHIFT 1689#define CMD_REG_STAT_MASK 0xff00000090#define CMD_REG_STAT_SHIFT 2491#define STAT_WORKING 0x0092#define STAT_COMPLETE 0x0193#define STAT_ERR_INVAL_CMD 0x8094#define STAT_ERR_INVAL_IRQ 0x8195#define STAT_ERR_MTOE 0x829697/* Response tag & CRC */98#define STAT_RTAG 0x0499100/* Response CRC */101#define STAT_RCRC 0x05102103/* Echo and Send delay */104#define ECHO_DLY_REG 0x08105#define SEND_DLY_REG 0x09106107/* Command data area108*109* Last byte of message must be left aligned110*/111#define CMD_DATA 0x10 /* 64 bit of data */112113/* Response data area, right aligned, unused top bits are 1 */114#define RSP_DATA 0x20 /* 32 bit of data */115116/* Misc */117#define INT_CNT 0x30 /* 32-bit interrupt count */118#define BAD_INT_VEC 0x34 /* 32-bit bad interrupt vector # */119#define CF_STARTED 0x38 /* byte, set to -1 when copro started */120#define CLK_CNT 0x3c /* 32-bit, clock count (debug only) */121122/*123* SRAM layout: GPIO arbitration part124*/125#define ARB_REG 0x40126#define ARB_ARM_REQ 0x01127#define ARB_ARM_ACK 0x02128129/* Misc2 */130#define CF_RESET_D0 0x50131#define CF_RESET_D1 0x54132#define BAD_INT_S0 0x58133#define BAD_INT_S1 0x5c134#define STOP_CNT 0x60135136/* Internal */137138/*139* SRAM layout: Trace buffer (debug builds only)140*/141#define TRACEBUF 0x100142#define TR_CLKOBIT0 0xc0143#define TR_CLKOBIT1 0xc1144#define TR_CLKOSTART 0x82145#define TR_OLEN 0x83 /* + len */146#define TR_CLKZ 0x84 /* + count */147#define TR_CLKWSTART 0x85148#define TR_CLKTAG 0x86 /* + tag */149#define TR_CLKDATA 0x87 /* + len */150#define TR_CLKCRC 0x88 /* + raw crc */151#define TR_CLKIBIT0 0x90152#define TR_CLKIBIT1 0x91153#define TR_END 0xff154155#endif /* __CF_FSI_FW_H */156157158159