Home | History | Annotate | Line # | Download | only in dev
      1  1.14  thorpej /*	$NetBSD: zsvar.h,v 1.14 2024/01/19 03:59:47 thorpej Exp $	*/
      2   1.1    chuck 
      3   1.1    chuck /*-
      4   1.1    chuck  * Copyright (c) 1996 The NetBSD Foundation, Inc.
      5   1.1    chuck  * All rights reserved.
      6   1.1    chuck  *
      7   1.1    chuck  * This code is derived from software contributed to The NetBSD Foundation
      8   1.9      scw  * by Jason R. Thorpe.
      9   1.1    chuck  *
     10   1.1    chuck  * Redistribution and use in source and binary forms, with or without
     11   1.1    chuck  * modification, are permitted provided that the following conditions
     12   1.1    chuck  * are met:
     13   1.1    chuck  * 1. Redistributions of source code must retain the above copyright
     14   1.1    chuck  *    notice, this list of conditions and the following disclaimer.
     15   1.1    chuck  * 2. Redistributions in binary form must reproduce the above copyright
     16   1.1    chuck  *    notice, this list of conditions and the following disclaimer in the
     17   1.1    chuck  *    documentation and/or other materials provided with the distribution.
     18   1.1    chuck  *
     19   1.1    chuck  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     20   1.1    chuck  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     21   1.1    chuck  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     22   1.3      jtc  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     23   1.3      jtc  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     24   1.1    chuck  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     25   1.1    chuck  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     26   1.1    chuck  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     27   1.1    chuck  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     28   1.1    chuck  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     29   1.1    chuck  * POSSIBILITY OF SUCH DAMAGE.
     30   1.1    chuck  */
     31   1.1    chuck 
     32   1.1    chuck /*
     33  1.13   andvar  * Non-exported definitions common to the different attachment
     34   1.1    chuck  * types for the SCC on the Motorola MVME series of computers.
     35   1.1    chuck  */
     36   1.1    chuck 
     37  1.14  thorpej #include "opt_mvmeconf.h"
     38  1.14  thorpej 
     39   1.1    chuck /*
     40   1.8      scw  * The MVME-147 provides a 5 MHz clock to the SCC chips.
     41   1.1    chuck  */
     42   1.9      scw #define PCLK_147	5000000		/* PCLK pin input clock rate */
     43   1.7      scw 
     44   1.7      scw /*
     45   1.8      scw  * The MVME-162 provides a 10 MHz clock to the SCC chips.
     46   1.7      scw  */
     47   1.9      scw #define PCLK_162	10000000	/* PCLK pin input clock rate */
     48   1.9      scw 
     49   1.9      scw /*
     50   1.9      scw  * SCC should interrupt host at level 4.
     51   1.9      scw  */
     52   1.9      scw #define ZSHARD_PRI	4
     53   1.1    chuck 
     54   1.1    chuck /*
     55   1.9      scw  * No delay needed when writing SCC registers.
     56   1.1    chuck  */
     57   1.9      scw #define ZS_DELAY()
     58   1.1    chuck 
     59   1.1    chuck /*
     60   1.8      scw  * XXX Make cnprobe a little easier.
     61   1.1    chuck  */
     62   1.9      scw #define NZSC	2
     63   1.1    chuck 
     64   1.9      scw /*
     65   1.9      scw  * The layout of this is hardware-dependent (padding, order).
     66   1.9      scw  */
     67   1.9      scw struct zschan {
     68   1.9      scw 	volatile u_char *zc_csr;	/* ctrl,status, and indirect access */
     69   1.9      scw 	volatile u_char *zc_data;	/* data */
     70   1.1    chuck };
     71   1.1    chuck 
     72   1.9      scw struct zsdevice {
     73   1.9      scw 	/* Yes, they are backwards. */
     74   1.9      scw 	struct	zschan zs_chan_b;
     75   1.9      scw 	struct	zschan zs_chan_a;
     76   1.1    chuck };
     77   1.1    chuck 
     78   1.1    chuck /* Globals exported from zs.c */
     79   1.9      scw extern	u_char zs_init_reg[];
     80   1.1    chuck 
     81   1.1    chuck /* Functions exported to ASIC-specific drivers. */
     82  1.11  tsutsui void	zs_config(struct zsc_softc *, struct zsdevice *, int, int);
     83  1.11  tsutsui void	zs_cnconfig(int, int, struct zsdevice *, int);
     84   1.9      scw #ifdef MVME147
     85  1.11  tsutsui int	zshard_shared(void *);
     86   1.9      scw #endif
     87  1.10      scw #if defined(MVME162) || defined(MVME172)
     88   1.9      scw int	zshard_unshared(void *);
     89   1.9      scw #endif
     90