/* $OpenBSD: ueaglereg.h,v 1.3 2007/06/09 11:06:53 mbalmer Exp $ */ /*- * Copyright (c) 2003-2005 * Damien Bergamini * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ /* OPTN: default values from analog devices */ #ifndef UEAGLE_OPTN0 #define UEAGLE_OPTN0 0x80020066 #endif #ifndef UEAGLE_OPTN2 #define UEAGLE_OPTN2 0x23700000 #endif #ifndef UEAGLE_OPTN7 #define UEAGLE_OPTN7 0x02cd8044 #endif #define UEAGLE_CONFIG_NO 1 #define UEAGLE_INTR_IFACE_NO 0 #define UEAGLE_US_IFACE_NO 1 #define UEAGLE_DS_IFACE_NO 2 #define UEAGLE_ESISTR 4 #define UEAGLE_TX_PIPE 0x02 #define UEAGLE_IDMA_PIPE 0x04 #define UEAGLE_INTR_PIPE 0x84 #define UEAGLE_RX_PIPE 0x88 #define UEAGLE_REQUEST 0 #define UEAGLE_SETBLOCK 0x0001 #define UEAGLE_SETMODE 0x0003 #define UEAGLE_SET2183DATA 0x0004 #define UEAGLE_LOOPBACKOFF 0x0002 #define UEAGLE_LOOPBACKON 0x0003 #define UEAGLE_BOOTIDMA 0x0006 #define UEAGLE_STARTRESET 0x0007 #define UEAGLE_ENDRESET 0x0008 #define UEAGLE_SWAPMAILBOX 0x7fcd #define UEAGLE_MPTXSTART 0x7fce #define UEAGLE_MPTXMAILBOX 0x7fd6 #define UEAGLE_MPRXMAILBOX 0x7fdf /* block within a firmware page */ struct ueagle_block_info { uWord wHdr; #define UEAGLE_BLOCK_INFO_HDR 0xabcd uWord wAddress; uWord wSize; uWord wOvlOffset; uWord wOvl; /* overlay */ uWord wLast; } __packed; /* CMV (Configuration and Management Variable) */ struct ueagle_cmv { uWord wPreamble; #define UEAGLE_CMV_PREAMBLE 0x535c uByte bDst; #define UEAGLE_HOST 0x01 #define UEAGLE_MODEM 0x10 uByte bFunction; #define UEAGLE_CR 0x10 #define UEAGLE_CW 0x11 #define UEAGLE_CR_ACK 0x12 #define UEAGLE_CW_ACK 0x13 #define UEAGLE_MODEMREADY 0x71 uWord wIndex; uDWord dwSymbolicAddress; #define UEAGLE_MAKESA(a, b, c, d) ((c) << 24 | (d) << 16 | (a) << 8 | (b)) #define UEAGLE_CMV_CNTL UEAGLE_MAKESA('C', 'N', 'T', 'L') #define UEAGLE_CMV_DIAG UEAGLE_MAKESA('D', 'I', 'A', 'G') #define UEAGLE_CMV_INFO UEAGLE_MAKESA('I', 'N', 'F', 'O') #define UEAGLE_CMV_OPTN UEAGLE_MAKESA('O', 'P', 'T', 'N') #define UEAGLE_CMV_RATE UEAGLE_MAKESA('R', 'A', 'T', 'E') #define UEAGLE_CMV_STAT UEAGLE_MAKESA('S', 'T', 'A', 'T') uWord wOffsetAddress; uDWord dwData; #define UGETDATA(w) ((w)[2] | (w)[3] << 8 | (w)[0] << 16 | (w)[1] << 24) #define USETDATA(w, v) \ ((w)[2] = (uint8_t)(v), \ (w)[3] = (uint8_t)((v) >> 8), \ (w)[0] = (uint8_t)((v) >> 16), \ (w)[1] = (uint8_t)((v) >> 24)) } __packed; struct ueagle_swap { uByte bPageNo; uByte bOvl; /* overlay */ } __packed; struct ueagle_intr { uByte bType; uByte bNotification; uWord wValue; uWord wIndex; uWord wLength; uWord wInterrupt; #define UEAGLE_INTR_SWAP 1 #define UEAGLE_INTR_CMV 2 } __packed; #define UEAGLE_INTR_MAXSIZE 28