4 #define FW_FLAG_LE 0x01 /* little endian? convert */
5 #define FW_FLAG_V4 0x02 /* b43 vs. b43legacy */
6 #define FW_FLAG_UNSUPPORTED 0x04 /* not supported/working */
8 #define fwcutter_stringify_1(x) #x
9 #define fwcutter_stringify(x) fwcutter_stringify_1(x)
10 #define FWCUTTER_VERSION fwcutter_stringify(FWCUTTER_VERSION_)
12 typedef uint16_t be16_t; /* Big-endian 16bit */
13 typedef uint32_t be32_t; /* Big-endian 32bit */
16 #define bswap_16 bswap16
17 #define bswap_32 bswap32
25 FWCM_EXTRACT = 0, /* default */
32 const char *target_dir;
33 enum fwcutter_mode mode;
39 uint16_t op1, op2, op3;
42 /* The IV how it's done in the binary driver files. */
46 } __attribute__((__packed__));
49 EXT_UNDEFINED, /* error catcher */
50 EXT_UCODE_1, /* rev <= 4 ucode */
51 EXT_UCODE_2, /* rev 5..14 ucode */
52 EXT_UCODE_3, /* rev >= 15 ucode */
53 EXT_PCM, /* "pcm" values */
54 EXT_IV, /* initial values */
59 const uint32_t offset;
60 const uint32_t length;
61 const enum extract_type type;
64 #define EXTRACT_LIST_END { .name = NULL, }
69 const char *ucode_version;
71 const struct extract *extract;
75 /* The header that's put in to every .fw file */
77 /* Type of the firmware data */
79 /* Version number of the firmware data format */
82 /* Size of the data. For ucode and PCM this is in bytes.
83 * For IV this is in number-of-ivs. */
85 } __attribute__((__packed__));
87 #define FW_TYPE_UCODE 'u'
88 #define FW_TYPE_PCM 'p'
89 #define FW_TYPE_IV 'i'
91 #define FW_HDR_VER 0x01
93 /* The IV in the .fw file */
99 } data __attribute__((__packed__));
100 } __attribute__((__packed__));
102 #define FW_IV_OFFSET_MASK 0x7FFF
103 #define FW_IV_32BIT 0x8000
106 #endif /* _FWCUTTER_H_ */