17c478bd9Sstevel@tonic-gate /* 27c478bd9Sstevel@tonic-gate * CDDL HEADER START 37c478bd9Sstevel@tonic-gate * 47c478bd9Sstevel@tonic-gate * The contents of this file are subject to the terms of the 5*c35aa225Smarx * Common Development and Distribution License (the "License"). 6*c35aa225Smarx * You may not use this file except in compliance with the License. 77c478bd9Sstevel@tonic-gate * 87c478bd9Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 97c478bd9Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 107c478bd9Sstevel@tonic-gate * See the License for the specific language governing permissions 117c478bd9Sstevel@tonic-gate * and limitations under the License. 127c478bd9Sstevel@tonic-gate * 137c478bd9Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 147c478bd9Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 157c478bd9Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 167c478bd9Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 177c478bd9Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 187c478bd9Sstevel@tonic-gate * 197c478bd9Sstevel@tonic-gate * CDDL HEADER END 207c478bd9Sstevel@tonic-gate */ 217c478bd9Sstevel@tonic-gate /* Copyright (c) 1990, 1991 UNIX System Laboratories, Inc. */ 227c478bd9Sstevel@tonic-gate /* Copyright (c) 1984, 1986, 1987, 1988, 1989, 1990 AT&T */ 237c478bd9Sstevel@tonic-gate /* All Rights Reserved */ 247c478bd9Sstevel@tonic-gate 257c478bd9Sstevel@tonic-gate /* 26*c35aa225Smarx * Copyright 2007 Sun Microsystems, Inc. All rights reserved. 277c478bd9Sstevel@tonic-gate * Use is subject to license terms. 287c478bd9Sstevel@tonic-gate */ 297c478bd9Sstevel@tonic-gate 307c478bd9Sstevel@tonic-gate #ifndef _SYS_PIT_H 317c478bd9Sstevel@tonic-gate #define _SYS_PIT_H 327c478bd9Sstevel@tonic-gate 337c478bd9Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" 347c478bd9Sstevel@tonic-gate 357c478bd9Sstevel@tonic-gate #ifdef __cplusplus 367c478bd9Sstevel@tonic-gate extern "C" { 377c478bd9Sstevel@tonic-gate #endif 387c478bd9Sstevel@tonic-gate 397c478bd9Sstevel@tonic-gate /* Definitions for 8254 Programmable Interrupt Timer ports on AT 386 */ 407c478bd9Sstevel@tonic-gate #define PITCTR0_PORT 0x40 /* counter 0 port */ 417c478bd9Sstevel@tonic-gate #define PITCTR1_PORT 0x41 /* counter 1 port */ 427c478bd9Sstevel@tonic-gate #define PITCTR2_PORT 0x42 /* counter 2 port */ 437c478bd9Sstevel@tonic-gate #define PITCTL_PORT 0x43 /* PIT control port */ 447c478bd9Sstevel@tonic-gate #define PITAUX_PORT 0x61 /* PIT auxiliary port */ 457c478bd9Sstevel@tonic-gate #define SANITY_CTR0 0x48 /* sanity timer counter */ 467c478bd9Sstevel@tonic-gate #define SANITY_CTL 0x4B /* sanity control word */ 477c478bd9Sstevel@tonic-gate #define SANITY_CHECK 0x461 /* bit 7 set if sanity timer went off */ 487c478bd9Sstevel@tonic-gate #define FAILSAFE_NMI 0x80 /* to test if sanity timer went off */ 497c478bd9Sstevel@tonic-gate #define ENABLE_SANITY 0x04 /* Enables sanity clock NMI ints */ 507c478bd9Sstevel@tonic-gate #define RESET_SANITY 0x00 /* resets sanity NMI interrupt */ 517c478bd9Sstevel@tonic-gate 527c478bd9Sstevel@tonic-gate /* PIT Status Byte */ 537c478bd9Sstevel@tonic-gate 547c478bd9Sstevel@tonic-gate #define PITSTAT_OUTPUT 7 /* OUTPUT status bit */ 557c478bd9Sstevel@tonic-gate #define PITSTAT_NULLCNT 6 /* NULL COUNT status bit */ 567c478bd9Sstevel@tonic-gate 577c478bd9Sstevel@tonic-gate /* Definitions for 8254 commands */ 587c478bd9Sstevel@tonic-gate 597c478bd9Sstevel@tonic-gate #define PIT_READBACK 0xc0 /* read-back command */ 607c478bd9Sstevel@tonic-gate #define PIT_READBACKC0 0x02 /* enable read-back for counter 0 */ 617c478bd9Sstevel@tonic-gate 627c478bd9Sstevel@tonic-gate /* Following are used for Timer 0 */ 637c478bd9Sstevel@tonic-gate #define PIT_C0 0x00 /* select counter 0 */ 647c478bd9Sstevel@tonic-gate #define PIT_LOADMODE 0x30 /* load least significant byte */ 657c478bd9Sstevel@tonic-gate /* followed by most significant byte */ 667c478bd9Sstevel@tonic-gate #define PIT_NDIVMODE 0x04 /* divide by N counter */ 677c478bd9Sstevel@tonic-gate #define PIT_SQUAREMODE 0x06 /* square-wave mode */ 687c478bd9Sstevel@tonic-gate #define PIT_ENDSIGMODE 0x00 /* assert OUT at end-of-count mode */ 697c478bd9Sstevel@tonic-gate 707c478bd9Sstevel@tonic-gate /* Used for Timer 1. Used for delay calculations in countdown mode */ 717c478bd9Sstevel@tonic-gate #define PIT_C1 0x40 /* select counter 1 */ 727c478bd9Sstevel@tonic-gate #define PIT_READMODE 0x30 /* read or load least significant */ 737c478bd9Sstevel@tonic-gate /* byte followed by most significant */ 747c478bd9Sstevel@tonic-gate #define PIT_RATEMODE 0x06 /* square-wave mode for USART */ 757c478bd9Sstevel@tonic-gate 76*c35aa225Smarx #define PIT_C2 0x80 /* select counter 2 */ 777c478bd9Sstevel@tonic-gate 787c478bd9Sstevel@tonic-gate #define SANITY_NUM 0xFFFF /* Sanity timer fires every .2 secs */ 797c478bd9Sstevel@tonic-gate /* bits used in auxiliary control port for timer 2 */ 807c478bd9Sstevel@tonic-gate #define PITAUX_GATE2 0x01 /* aux port, PIT gate 2 input */ 817c478bd9Sstevel@tonic-gate #define PITAUX_OUT2 0x02 /* aux port, PIT clock out 2 enable */ 827c478bd9Sstevel@tonic-gate #define PIT_HZ 1193182 /* 8254's cycles per second */ 837c478bd9Sstevel@tonic-gate 847c478bd9Sstevel@tonic-gate #ifdef __cplusplus 857c478bd9Sstevel@tonic-gate } 867c478bd9Sstevel@tonic-gate #endif 877c478bd9Sstevel@tonic-gate 887c478bd9Sstevel@tonic-gate #endif /* _SYS_PIT_H */ 89