Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

/*	$NetBSD: gtbrgreg.h,v 1.3 2016/01/15 12:09:15 joerg Exp $	*/

/*
 * Copyright (c) 2002 Allegro Networks, Inc., Wasabi Systems, Inc.
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 * 3. All advertising materials mentioning features or use of this software
 *    must display the following acknowledgement:
 *      This product includes software developed for the NetBSD Project by
 *      Allegro Networks, Inc., and Wasabi Systems, Inc.
 * 4. The name of Allegro Networks, Inc. may not be used to endorse
 *    or promote products derived from this software without specific prior
 *    written permission.
 * 5. The name of Wasabi Systems, Inc. may not be used to endorse
 *    or promote products derived from this software without specific prior
 *    written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY ALLEGRO NETWORKS, INC. AND
 * WASABI SYSTEMS, INC. ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
 * IN NO EVENT SHALL EITHER ALLEGRO NETWORKS, INC. OR WASABI SYSTEMS, INC.
 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */

/*
 * gtbrgreg.h - register defines for GT-64260 Baud Rate Generator
 *
 * creation	Thu Apr 12 21:47:54 PDT 2001	cliff
 */

#ifndef _GTBRGREG_H
#define _GTBRGREG_H

#define GTBRG_NCHAN	3               /* Number of MPSC channels */

/*******************************************************************************
 *
 * BRG register address offsets relative to the base mapping
 */
#define BRG_BCR(c)	(0xb200 + ((c) << 3))	/* Baud Config Register */
#define BRG_BTR(c)	(0xb204 + ((c) << 3))	/* Baud Tuning Register */
#define BRG_CAUSE	0xb834			/* BRG Cause Register */
#define BRG_MASK	0xb8b4			/* BRG Cause Register */

/*******************************************************************************
 *
 * BRG register values & bit defines
 */
/*
 * BRG Configuration Register bits
 */
#define BRG_BCR_CDV		__BITS(15,0)	/* Count Down Value */
#define BRG_BCR_EN		__BIT(16)	/* Enable BRG */
#define BRG_BCR_RST		__BIT(17)	/* Reset BRG */
#define BRG_BCR_CLKS_MASK	__BITS(22,18)	/* Clock Source */
#define BRG_BCR_CLKS_BCLKIN	(0 << 18)	/* from MPP */
#define BRG_BCR_CLKS_SCLK0	(2 << 18)	/* from S0 port */
#define BRG_BCR_CLKS_TSCLK0	(3 << 18)	/* from S0 port */
#define BRG_BCR_CLKS_SCLK1	(6 << 18)	/* from S1 port */
#define BRG_BCR_CLKS_TSCLK1	(7 << 18)	/* from S1 port */
#define BRG_BCR_CLKS_TCLK	(8 << 18)	/* "Tclk" ??? */
						/* all other values resvd. */
#define BRG_BCR_RES		__BITS(31,23)
/*
 * BRG Baud Tuning Register bits
 */
#define BRG_BTR_CUV		__BITS(15,0)	/* Count Up Value */
#define BRG_BTR_RES		__BITS(31,16)
/*
 * BRG Cause and Mask interrupt Register bits
 */
#define BRG_INTR_BTR0		__BIT(0)	/* Baud Tuning 0 irpt. */
#define BRG_INTR_BTR1		__BIT(1)	/* Baud Tuning 1 irpt. */
#define BRG_INTR_BTR2		__BIT(2)	/* Baud Tuning 2 irpt. */
#define BRG_INTR_RES		__BITS(31,3)

#endif	/* _GTBRGREG_H */