1 #ifndef _DUMPREGS_ 2 #define _DUMPREGS_ 3 /*- 4 * Copyright (c) 2002-2008 Sam Leffler, Errno Consulting 5 * All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer, 12 * without modification. 13 * 2. Redistributions in binary form must reproduce at minimum a disclaimer 14 * similar to the "NO WARRANTY" disclaimer below ("Disclaimer") and any 15 * redistribution must be conditioned upon including a substantially 16 * similar Disclaimer requirement for further binary redistribution. 17 * 18 * NO WARRANTY 19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 21 * LIMITED TO, THE IMPLIED WARRANTIES OF NONINFRINGEMENT, MERCHANTIBILITY 22 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL 23 * THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, 24 * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER 27 * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF 29 * THE POSSIBILITY OF SUCH DAMAGES. 30 */ 31 32 #define __constructor __attribute__((constructor)) 33 34 struct dumpreg { 35 uint32_t addr; 36 const char *name; 37 const char *bits; 38 int type; 39 u_int srevMin, srevMax; 40 u_int phyMin, phyMax; 41 }; 42 #define SREV(v,r) (((v) << 16) | (r)) 43 #define MAC_MATCH(dr, mv, mr) \ 44 ((dr)->srevMin <= SREV(mv,mr) && SREV(mv,mr) < (dr)->srevMax) 45 46 #define PHY_MATCH(dr, pr) \ 47 ((dr)->phyMin <= (pr) && (pr) < (dr)->phyMax) 48 #define PHYANY 0,0xffff 49 50 enum { 51 DUMP_BASIC = 0x0001, /* basic/default registers */ 52 DUMP_KEYCACHE = 0x0002, /* key cache */ 53 DUMP_BASEBAND = 0x0004, /* baseband */ 54 DUMP_INTERRUPT = 0x0008, /* interrupt state */ 55 DUMP_XR = 0x0010, /* XR state */ 56 DUMP_QCU = 0x0020, /* QCU state */ 57 DUMP_DCU = 0x0040, /* DCU state */ 58 59 DUMP_PUBLIC = 0x0061, /* public = BASIC+QCU+DCU */ 60 DUMP_ALL = 0xffff 61 }; 62 63 #define _DEFREG(_addr, _name, _type) \ 64 { .addr = _addr, .name = _name, .type = _type } 65 #define _DEFREGx(_addr, _name, _type, _srevmin, _srevmax) \ 66 { .addr = _addr, .name = _name, .type = _type, \ 67 .srevMin = _srevmin, .srevMax = _srevmax } 68 #define _DEFREGfmt(_addr, _name, _type, _fmt) \ 69 { .addr = _addr, .name = _name, .type = _type, .bits = _fmt } 70 #define DEFVOID(_addr, _name) _DEFREG(_addr, _name, 0) 71 #define DEFVOIDx(_addr, _name, _smin, _smax) \ 72 __DEFREGx(_addr, _name, _smin, _smax, 0) 73 #define DEFVOIDfmt(_addr, _name, _fmt) \ 74 _DEFREGfmt(_addr, _name, 0, _fmt) 75 #define DEFBASIC(_addr, _name) _DEFREG(_addr, _name, DUMP_BASIC) 76 #define DEFBASICfmt(_addr, _name, _fmt) \ 77 _DEFREGfmt(_addr, _name, DUMP_BASIC, _fmt) 78 #define DEFBASICx(_addr, _name, _smin, _smax) \ 79 _DEFREGx(_addr, _name, DUMP_BASIC, _smin, _smax) 80 #define DEFBB(_addr, _name) _DEFREG(_addr, _name, DUMP_BASEBAND) 81 #define DEFINT(_addr, _name) _DEFREG(_addr, _name, DUMP_INTERRUPT) 82 #define DEFINTfmt(_addr, _name, _fmt) \ 83 _DEFREGfmt(_addr, _name, DUMP_INTERRUPT, _fmt) 84 #define DEFQCU(_addr, _name) _DEFREG(_addr, _name, DUMP_QCU) 85 #define DEFDCU(_addr, _name) _DEFREG(_addr, _name, DUMP_DCU) 86 87 void register_regs(struct dumpreg *_regs, u_int _nregs, 88 int def_srev_min, int def_srev_max, 89 int def_phy_min, int def_phy_max); 90 void register_keycache(u_int nslots, 91 int def_srev_min, int def_srev_max, 92 int def_phy_min, int def_phy_max); 93 void register_range(u_int brange, u_int erange, int what, 94 int def_srev_min, int def_srev_max, 95 int def_phy_min, int def_phy_max); 96 #endif /* _DUMPREGS_ */ 97