The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/dev/sbus/bppreg.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*      $NetBSD: bppreg.h,v 1.1 1998/09/21 21:20:48 pk Exp $ */
    2 
    3 /*-
    4  * Copyright (c) 1998 The NetBSD Foundation, Inc.
    5  * All rights reserved.
    6  *
    7  * This code is derived from software contributed to The NetBSD Foundation
    8  * by Paul Kranenburg.
    9  *
   10  * Redistribution and use in source and binary forms, with or without
   11  * modification, are permitted provided that the following conditions
   12  * are met:
   13  * 1. Redistributions of source code must retain the above copyright
   14  *    notice, this list of conditions and the following disclaimer.
   15  * 2. Redistributions in binary form must reproduce the above copyright
   16  *    notice, this list of conditions and the following disclaimer in the
   17  *    documentation and/or other materials provided with the distribution.
   18  * 3. All advertising materials mentioning features or use of this software
   19  *    must display the following acknowledgement:
   20  *        This product includes software developed by the NetBSD
   21  *        Foundation, Inc. and its contributors.
   22  * 4. Neither the name of The NetBSD Foundation nor the names of its
   23  *    contributors may be used to endorse or promote products derived
   24  *    from this software without specific prior written permission.
   25  *
   26  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
   27  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
   28  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
   29  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
   30  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
   31  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
   32  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
   33  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
   34  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
   35  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
   36  * POSSIBILITY OF SUCH DAMAGE.
   37  */
   38 
   39 /* Hardware Configuration Register */
   40 #define BPP_HCR_DSS_MASK        0x003f  /* Data before strobe */
   41 #define BPP_HCR_DSS_SHFT        0       /*   (in Sbus clocks)*/
   42 #define BPP_HCR_DSW_MASK        0x7f00  /* Data Strobe Width */
   43 #define BPP_HCR_DSW_SHFT        8       /*   (in Sbus clocks)*/
   44 #define BPP_HCR_TEST            0x8000  /* */
   45 #define BPP_HCR_BITS            "\177\020" \
   46                                 "f\0\6DSS\0f\1\7DSW\0b\17TEST\0"
   47 
   48 
   49 /* Operation Configuration Register */
   50 #define BPP_OCR_IDLE            0x0008  /* State machines are idle */
   51 #define BPP_OCR_SRST            0x0080  /* Reset bit */
   52 #define BPP_OCR_ACK_OP          0x0100  /* ACK handshake operation */
   53 #define BPP_OCR_BUSY_OP         0x0200  /* BUSY handshake operation */
   54 #define BPP_OCR_EN_DIAG         0x0400  /* */
   55 #define BPP_OCR_ACK_DSEL        0x0800  /* ack line is bidirectional */
   56 #define BPP_OCR_BUSY_DSEL       0x1000  /* busy line is bidirectional */
   57 #define BPP_OCR_DS_DSEL         0x2000  /* data strobe line is bidirectional */
   58 #define BPP_OCR_DATA_SRC        0x4000  /* Data source for `memory clear' */
   59 #define BPP_OCR_MEM_SRC         0x8000  /* Enable `memory clear' */
   60 #define BPP_OCR_BITS            "\177\020" \
   61                                 "b\3IDLE\0b\7SRST\0b\10ACK_OP\0b\11BUSY_OP\0" \
   62                                 "b\12EN_DIAG\0b\13ACK_DSEL\0b\14BUSY_DSEL\0" \
   63                                 "b\15DS_DSEL\0b\16DATA_SRC\0b\17MEM_SRC\0"
   64 /* User settable bits */
   65 #define BPP_OCR_USER    \
   66         (BPP_OCR_ACK_OP|BPP_OCR_BUSY_OP|BPP_OCR_ACK_DSEL|\
   67          BPP_OCR_BUSY_DSEL|BPP_OCR_DS_DSEL)
   68 
   69 /* Transfer Control Register */
   70 #define BPP_TCR_DS              0x01    /* Data Strobe */
   71 #define BPP_TCR_ACK             0x02    /* Acknowledge */
   72 #define BPP_TCR_BUSY            0x04    /* Busy */
   73 #define BPP_TCR_DIR             0x08    /* Direction control */
   74 #define BPP_TCR_BITS            "\177\020" \
   75                                 "b\0DS\0b\1ACK\0b\2BUSY\0b\3DIR\0"
   76 #define BPP_TCR_USER            (BPP_TCR_DS|BPP_TCR_ACK|BPP_TCR_BUSY)
   77 
   78 /* Output Register */
   79 #define BPP_OR_SLCTIN           0x01    /* Select */
   80 #define BPP_OR_AFXN             0x02    /* Auto Feed */
   81 #define BPP_OR_INIT             0x04    /* Initialize */
   82 #define BPP_OR_BITS             "\177\020" \
   83                                 "b\0SLCTIN\0b\1AFXN\0b\2INIT\0"
   84 #define BPP_OR_USER             (BPP_OR_SLCTIN|BPP_OR_AFXN)
   85 
   86 /* Input Register (read-only) */
   87 #define BPP_IR_ERR              0x01    /* Err input pin */
   88 #define BPP_IR_SLCT             0x02    /* Select input pin */
   89 #define BPP_IR_PE               0x04    /* Paper Out input pin */
   90 #define BPP_IR_BITS             "\177\020" \
   91                                 "b\0ERR\0b\1SLCT\0b\2PE\0"
   92 
   93 /* Interrupt Control Register */
   94 #define BPP_ERR_IRQ_EN          0x0001  /* Error interrupt enable */
   95 #define BPP_ERR_IRP             0x0002  /* ERR interrupt polarity */
   96 #define BPP_SLCT_IRQ_EN         0x0004  /* Select interrupt enable */
   97 #define BPP_SLCT_IRP            0x0008  /* Select interrupt polarity */
   98 #define BPP_PE_IRQ_EN           0x0010  /* Paper Empty interrupt enable */
   99 #define BPP_PE_IRP              0x0020  /* PE interrupt polarity */
  100 #define BPP_BUSY_IRQ_EN         0x0040  /* BUSY interrupt enable */
  101 #define BPP_BUSY_IRP            0x0080  /* BUSY interrupt polarity */
  102 #define BPP_ACK_IRQ_EN          0x0100  /* ACK interrupt enable */
  103 #define BPP_DS_IRQ_EN           0x0200  /* Data Strobe interrupt enable */
  104 #define BPP_ERR_IRQ             0x0400  /* ERR interrupt pending */
  105 #define BPP_SLCT_IRQ            0x0800  /* SLCT interrupt pending */
  106 #define BPP_PE_IRQ              0x1000  /* PE interrupt pending */
  107 #define BPP_BUSY_IRQ            0x2000  /* BUSY interrupt pending */
  108 #define BPP_ACK_IRQ             0x4000  /* ACK interrupt pending */
  109 #define BPP_DS_IRQ              0x8000  /* DS interrupt pending */
  110 
  111 /* Define mask for each of all irq request, all polarity and all enable bits */
  112 #define BPP_ALLIRQ      (BPP_ERR_IRQ|BPP_SLCT_IRQ|BPP_PE_IRQ|   \
  113                          BPP_BUSY_IRQ|BPP_ACK_IRQ|BPP_DS_IRQ)
  114 #define BPP_ALLEN       (BPP_ERR_IRQ_EN|BPP_SLCT_IRQ_EN|        \
  115                          BPP_PE_IRQ_EN|BPP_BUSY_IRQ_EN|         \
  116                          BPP_ACK_IRQ_EN|BPP_DS_IRQ_EN)
  117 #define BPP_ALLIRP      (BPP_ERR_IRP|BPP_PE_IRP|BPP_BUSY_IRP)
  118 #define BPP_IRQ_USER    BPP_ALLIRP
  119 
  120 #define BPP_IRQ_BITS    "\177\020"                                      \
  121                         "b\0ERR_IRQ_EN\0b\1ERR_IRP\0b\2SLCT_IRQ_EN\0"   \
  122                         "b\3SLCT_IRP\0b\4PE_IRQ_EN\0b\5PE_IRP\0"        \
  123                         "b\6BUSY_IRQ_EN\0b\7BUSY_IRP\0b\10ACK_IRQ_EN\0" \
  124                         "b\11DS_IRQ_EN\0b\12ERR_IRQ\0b\13SLCT_IRQ\0"    \
  125                         "b\14PE_IRQ\0b\15BUSY_IRQ\0b\16ACK_IRQ\0"       \
  126                         "b\17DS_IRQ\0"

Cache object: f2c51bd6a2c50662e803f8516254bb25


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.