Annotation of sys/dev/usb/uowreg.h, Revision 1.1
1.1 ! nbrk 1: /* $OpenBSD: uowreg.h,v 1.5 2006/10/08 20:04:23 grange Exp $ */
! 2:
! 3: /*
! 4: * Copyright (c) 2006 Alexander Yurchenko <grange@openbsd.org>
! 5: *
! 6: * Permission to use, copy, modify, and distribute this software for any
! 7: * purpose with or without fee is hereby granted, provided that the above
! 8: * copyright notice and this permission notice appear in all copies.
! 9: *
! 10: * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
! 11: * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
! 12: * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
! 13: * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
! 14: * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
! 15: * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
! 16: * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
! 17: */
! 18:
! 19: #ifndef _DEV_USB_UOWREG_H_
! 20: #define _DEV_USB_UOWREG_H_
! 21:
! 22: /*
! 23: * Maxim/Dallas DS2490 USB 1-Wire adapter register definitions.
! 24: */
! 25:
! 26: /* USB core interface */
! 27: #define DS2490_USB_CONFIG 1 /* configuration */
! 28: #define DS2490_USB_IFACE 0 /* interface */
! 29:
! 30: /* Command type codes */
! 31: #define DS2490_CONTROL_CMD 0x00 /* control */
! 32: #define DS2490_COMM_CMD 0x01 /* communication */
! 33: #define DS2490_MODE_CMD 0x02 /* mode */
! 34:
! 35: /* Control command codes */
! 36: #define DS2490_CTL_RESET_DEVICE 0x0000
! 37: #define DS2490_CTL_START_EXE 0x0001
! 38: #define DS2490_CTL_RESUME_EXE 0x0002
! 39: #define DS2490_CTL_HALT_EXE_IDLE 0x0003
! 40: #define DS2490_CTL_HALT_EXE_DONE 0x0004
! 41: #define DS2490_CTL_FLUSH_COMM_CMDS 0x0007
! 42: #define DS2490_CTL_FLUSH_RCV_BUFFER 0x0008
! 43: #define DS2490_CTL_FLUSH_XMT_BUFFER 0x0009
! 44: #define DS2490_CTL_GET_COMM_CMDS 0x000a
! 45:
! 46: /* Communication command codes */
! 47: #define DS2490_COMM_SET_DURATION 0x0012
! 48: #define DS2490_COMM_PULSE 0x0030
! 49: #define DS2490_COMM_1WIRE_RESET 0x0042
! 50: #define DS2490_COMM_BIT_IO 0x0020
! 51: #define DS2490_COMM_BYTE_IO 0x0052
! 52: #define DS2490_COMM_BLOCK_IO 0x0074
! 53: #define DS2490_COMM_MATCH_ACCESS 0x0064
! 54: #define DS2490_COMM_READ_STRAIGHT 0x0080
! 55: #define DS2490_COMM_DO_RELEASE 0x6092
! 56: #define DS2490_COMM_SET_PATH 0x00a2
! 57: #define DS2490_COMM_WRITE_SRAM_PAGE 0x00b2
! 58: #define DS2490_COMM_WRITE_EPROM 0x00c4
! 59: #define DS2490_COMM_READ_CRC_PROT_PAGE 0x00d4
! 60: #define DS2490_COMM_READ_REDIR_PAGE_CRC 0x21e4
! 61: #define DS2490_COMM_SEARCH_ACCESS 0x00f4
! 62:
! 63: /* Communication command embedded command parameter bits */
! 64: #define DS2490_BIT_IM (1 << 0)
! 65: #define DS2490_BIT_D (1 << 3)
! 66: #define DS2490_BIT_CH (1 << 3)
! 67: #define DS2490_BIT_R (1 << 3)
! 68: #define DS2490_BIT_SE (1 << 3)
! 69: #define DS2490_BIT_SM (1 << 3)
! 70: #define DS2490_BIT_TYPE (1 << 3)
! 71: #define DS2490_BIT_Z (1 << 3)
! 72: #define DS2490_BIT_RST (1 << 8)
! 73: #define DS2490_BIT_ICP (1 << 9)
! 74: #define DS2490_BIT_NTF (1 << 10)
! 75: #define DS2490_BIT_F (1 << 11)
! 76: #define DS2490_BIT_SPU (1 << 12)
! 77: #define DS2490_BIT_DT (1 << 13)
! 78: #define DS2490_BIT_CIB (1 << 14)
! 79: #define DS2490_BIT_PS (1 << 14)
! 80: #define DS2490_BIT_PST (1 << 14)
! 81: #define DS2490_BIT_RTS (1 << 14)
! 82:
! 83: /* Mode command codes */
! 84: #define DS2490_MOD_PULSE_EN 0x0000
! 85: #define DS2490_MOD_SPEED_CHANGE_EN 0x0001
! 86: #define DS2490_MOD_1WIRE_SPEED 0x0002
! 87: #define DS2490_MOD_STRONG_PU_DURATION 0x0003
! 88: #define DS2490_MOD_PULLDOWN_SLEWRATE 0x0004
! 89: #define DS2490_MOD_PROG_PULSE_DURATION 0x0005
! 90: #define DS2490_MOD_WRITE1_LOWTIME 0x0006
! 91: #define DS2490_MOD_DSOW0_TREC 0x0007
! 92:
! 93: /* State registers */
! 94: #define DS2490_ST_BEGIN 0x00
! 95: #define DS2490_ST_ENFL 0x00 /* enabled flags */
! 96: #define DS2490_ST_ENFL_SPUE (1 << 0) /* strong pullup */
! 97: #define DS2490_ST_ENFL_PRGE (1 << 1) /* programming pulse */
! 98: #define DS2490_ST_ENFL_SPCE (1 << 2) /* speed change */
! 99: #define DS2490_ST_SPEED 0x01 /* bus speed */
! 100: #define DS2490_ST_SPUDUR 0x02 /* strong pullup duration */
! 101: #define DS2490_ST_PRGDUR 0x03 /* programming pullup duration */
! 102: #define DS2490_ST_PDSRC 0x04 /* pulldown slew rate control */
! 103: #define DS2490_ST_W1LT 0x05 /* write-1 low time */
! 104: #define DS2490_ST_DSO 0x06 /* data sample offset */
! 105: #define DS2490_ST_STFL 0x08 /* status flags */
! 106: #define DS2490_ST_STFL_SPUA (1 << 0) /* strong pullup */
! 107: #define DS2490_ST_STFL_PRGA (1 << 1) /* programming pulse */
! 108: #define DS2490_ST_STFL_12VP (1 << 2) /* 12V prog voltage */
! 109: #define DS2490_ST_STFL_PMOD (1 << 3) /* ext power */
! 110: #define DS2490_ST_STFL_HALT (1 << 4) /* halted */
! 111: #define DS2490_ST_STFL_IDLE (1 << 5) /* idle */
! 112: #define DS2490_ST_STFL_EP0F (1 << 7) /* EP0 FIFO status */
! 113: #define DS2490_ST_STFL_BITS "\020\001SPUA\002PRGA\00312VP\004PMOD\005HALT\006IDLE\010EP0F"
! 114:
! 115: #define DS2490_ST_CC1 0x09 /* communication command byte 1 */
! 116: #define DS2490_ST_CC2 0x0a /* communication command byte 2 */
! 117: #define DS2490_ST_CCBUF 0x0b /* communication command buf status */
! 118: #define DS2490_ST_OBUF 0x0c /* data out buf status */
! 119: #define DS2490_ST_IBUF 0x0d /* data in buf status */
! 120: #define DS2490_ST_END 0x0f
! 121:
! 122: /* Result registers */
! 123: #define DS2490_RES_BEGIN 0x10
! 124: #define DS2490_RES_END 0x1f
! 125: #define DS2490_RES_DETECT 0xa5 /* device detect */
! 126:
! 127: #define DS2490_NREGS (DS2490_RES_END + 1)
! 128:
! 129: #define DS2490_CMDFIFOSIZE 16 /* command FIFO size */
! 130: #define DS2490_DATAFIFOSIZE 128 /* data FIFO size */
! 131:
! 132: #endif /* !_DEV_USB_UOWREG_H_ */
CVSweb