xref: /freebsd/sys/dev/rtwn/if_rtwn_fw.h (revision 2ff63af9b88c7413b7d71715b5532625752a248e)
1*7453645fSAndriy Voskoboinyk /*-
2*7453645fSAndriy Voskoboinyk  * Copyright (c) 2010 Damien Bergamini <damien.bergamini@free.fr>
3*7453645fSAndriy Voskoboinyk  * Copyright (c) 2016 Andriy Voskoboinyk <avos@FreeBSD.org>
4*7453645fSAndriy Voskoboinyk  *
5*7453645fSAndriy Voskoboinyk  * Permission to use, copy, modify, and distribute this software for any
6*7453645fSAndriy Voskoboinyk  * purpose with or without fee is hereby granted, provided that the above
7*7453645fSAndriy Voskoboinyk  * copyright notice and this permission notice appear in all copies.
8*7453645fSAndriy Voskoboinyk  *
9*7453645fSAndriy Voskoboinyk  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10*7453645fSAndriy Voskoboinyk  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11*7453645fSAndriy Voskoboinyk  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12*7453645fSAndriy Voskoboinyk  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13*7453645fSAndriy Voskoboinyk  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14*7453645fSAndriy Voskoboinyk  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15*7453645fSAndriy Voskoboinyk  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16*7453645fSAndriy Voskoboinyk  *
17*7453645fSAndriy Voskoboinyk  * $OpenBSD: if_urtwnreg.h,v 1.3 2010/11/16 18:02:59 damien Exp $
18*7453645fSAndriy Voskoboinyk  */
19*7453645fSAndriy Voskoboinyk 
20*7453645fSAndriy Voskoboinyk #ifndef IF_RTWN_FW_H
21*7453645fSAndriy Voskoboinyk #define IF_RTWN_FW_H
22*7453645fSAndriy Voskoboinyk 
23*7453645fSAndriy Voskoboinyk /*
24*7453645fSAndriy Voskoboinyk  * Firmware base address.
25*7453645fSAndriy Voskoboinyk  */
26*7453645fSAndriy Voskoboinyk #define R92C_FW_START_ADDR		0x1000
27*7453645fSAndriy Voskoboinyk #define R92C_FW_PAGE_SIZE		4096
28*7453645fSAndriy Voskoboinyk #define R92C_FW_MAX_BLOCK_SIZE		196
29*7453645fSAndriy Voskoboinyk 
30*7453645fSAndriy Voskoboinyk /*
31*7453645fSAndriy Voskoboinyk  * Firmware image header.
32*7453645fSAndriy Voskoboinyk  */
33*7453645fSAndriy Voskoboinyk struct r92c_fw_hdr {
34*7453645fSAndriy Voskoboinyk 	/* QWORD0 */
35*7453645fSAndriy Voskoboinyk 	uint16_t	signature;
36*7453645fSAndriy Voskoboinyk 	uint8_t		category;
37*7453645fSAndriy Voskoboinyk 	uint8_t		function;
38*7453645fSAndriy Voskoboinyk 	uint16_t	version;
39*7453645fSAndriy Voskoboinyk 	uint16_t	subversion;
40*7453645fSAndriy Voskoboinyk 	/* QWORD1 */
41*7453645fSAndriy Voskoboinyk 	uint8_t		month;
42*7453645fSAndriy Voskoboinyk 	uint8_t		date;
43*7453645fSAndriy Voskoboinyk 	uint8_t		hour;
44*7453645fSAndriy Voskoboinyk 	uint8_t		minute;
45*7453645fSAndriy Voskoboinyk 	uint16_t	ramcodesize;
46*7453645fSAndriy Voskoboinyk 	uint16_t	reserved2;
47*7453645fSAndriy Voskoboinyk 	/* QWORD2 */
48*7453645fSAndriy Voskoboinyk 	uint32_t	svnidx;
49*7453645fSAndriy Voskoboinyk 	uint32_t	reserved3;
50*7453645fSAndriy Voskoboinyk 	/* QWORD3 */
51*7453645fSAndriy Voskoboinyk 	uint32_t	reserved4;
52*7453645fSAndriy Voskoboinyk 	uint32_t	reserved5;
53*7453645fSAndriy Voskoboinyk } __packed;
54*7453645fSAndriy Voskoboinyk 
55*7453645fSAndriy Voskoboinyk int		rtwn_load_firmware(struct rtwn_softc *);
56*7453645fSAndriy Voskoboinyk 
57*7453645fSAndriy Voskoboinyk #endif	/* IF_RTWN_FW_H */
58