summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/pci/amdpm.c64
-rw-r--r--sys/dev/pci/amdpmreg.h114
2 files changed, 63 insertions, 115 deletions
diff --git a/sys/dev/pci/amdpm.c b/sys/dev/pci/amdpm.c
index 0dbe57de5d9..a1263748efd 100644
--- a/sys/dev/pci/amdpm.c
+++ b/sys/dev/pci/amdpm.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: amdpm.c,v 1.15 2006/03/08 09:58:44 dlg Exp $ */
+/* $OpenBSD: amdpm.c,v 1.16 2006/03/08 22:59:14 dlg Exp $ */
/*
* Copyright (c) 2006 Alexander Yurchenko <grange@openbsd.org>
@@ -90,6 +90,68 @@ u_int amdpm_get_timecount(struct timecounter *tc);
#define AMDPM_FREQUENCY 3579545
#endif
+
+#define AMDPM_CONFREG 0x40
+
+/* 0x40: General Configuration 1 Register */
+#define AMDPM_RNGEN 0x00000080 /* random number generator enable */
+#define AMDPM_STOPTMR 0x00000040 /* stop free-running timer */
+
+/* 0x41: General Configuration 2 Register */
+#define AMDPM_PMIOEN 0x00008000 /* system management IO space enable */
+#define AMDPM_TMRRST 0x00004000 /* reset free-running timer */
+#define AMDPM_TMR32 0x00000800 /* extended (32 bit) timer enable */
+
+/* 0x42: SCI Interrupt Configuration Register */
+/* 0x43: Previous Power State Register */
+
+#define AMDPM_PMPTR 0x58 /* PMxx System Management IO space
+ Pointer */
+#define NFPM_PMPTR 0x14 /* nForce System Management IO space
+ POinter */
+#define AMDPM_PMBASE(x) ((x) & 0xff00) /* PMxx base address */
+#define AMDPM_PMSIZE 256 /* PMxx space size */
+
+/* Registers in PMxx space */
+#define AMDPM_TMR 0x08 /* 24/32 bit timer register */
+
+#define AMDPM_RNGDATA 0xf0 /* 32 bit random data register */
+#define AMDPM_RNGSTAT 0xf4 /* RNG status register */
+#define AMDPM_RNGDONE 0x00000001 /* Random number generation complete */
+
+#define AMDPM_SMB_REGS 0xe0 /* offset of SMB register space */
+#define AMDPM_SMB_SIZE 0xf /* size of SMB register space */
+#define AMDPM_SMBSTAT 0x0 /* SMBus status */
+#define AMDPM_SMBSTAT_ABRT (1 << 0) /* transfer abort */
+#define AMDPM_SMBSTAT_COL (1 << 1) /* collision */
+#define AMDPM_SMBSTAT_PRERR (1 << 2) /* protocol error */
+#define AMDPM_SMBSTAT_HBSY (1 << 3) /* host controller busy */
+#define AMDPM_SMBSTAT_CYC (1 << 4) /* cycle complete */
+#define AMDPM_SMBSTAT_TO (1 << 5) /* timeout */
+#define AMDPM_SMBSTAT_SNP (1 << 8) /* snoop address match */
+#define AMDPM_SMBSTAT_SLV (1 << 9) /* slave address match */
+#define AMDPM_SMBSTAT_SMBA (1 << 10) /* SMBALERT# asserted */
+#define AMDPM_SMBSTAT_BSY (1 << 11) /* bus busy */
+#define AMDPM_SMBSTAT_BITS "\020\001ABRT\002COL\003PRERR\004HBSY\005CYC\006TO\011SNP\012SLV\013SMBA\014BSY"
+#define AMDPM_SMBCTL 0x2 /* SMBus control */
+#define AMDPM_SMBCTL_CMD_QUICK 0 /* QUICK command */
+#define AMDPM_SMBCTL_CMD_BYTE 1 /* BYTE command */
+#define AMDPM_SMBCTL_CMD_BDATA 2 /* BYTE DATA command */
+#define AMDPM_SMBCTL_CMD_WDATA 3 /* WORD DATA command */
+#define AMDPM_SMBCTL_CMD_PCALL 4 /* PROCESS CALL command */
+#define AMDPM_SMBCTL_CMD_BLOCK 5 /* BLOCK command */
+#define AMDPM_SMBCTL_START (1 << 3) /* start transfer */
+#define AMDPM_SMBCTL_CYCEN (1 << 4) /* intr on cycle complete */
+#define AMDPM_SMBCTL_ABORT (1 << 5) /* abort transfer */
+#define AMDPM_SMBCTL_SNPEN (1 << 8) /* intr on snoop addr match */
+#define AMDPM_SMBCTL_SLVEN (1 << 9) /* intr on slave addr match */
+#define AMDPM_SMBCTL_SMBAEN (1 << 10) /* intr on SMBALERT# */
+#define AMDPM_SMBADDR 0x4 /* SMBus address */
+#define AMDPM_SMBADDR_READ (1 << 0) /* read direction */
+#define AMDPM_SMBADDR_ADDR(x) (((x) & 0x7f) << 1) /* 7-bit address */
+#define AMDPM_SMBDATA 0x6 /* SMBus data */
+#define AMDPM_SMBCMD 0x8 /* SMBus command */
+
static struct timecounter amdpm_timecounter = {
amdpm_get_timecount, /* get_timecount */
0, /* no poll_pps */
diff --git a/sys/dev/pci/amdpmreg.h b/sys/dev/pci/amdpmreg.h
deleted file mode 100644
index 6b5d861ef3e..00000000000
--- a/sys/dev/pci/amdpmreg.h
+++ /dev/null
@@ -1,114 +0,0 @@
-/* $OpenBSD: amdpmreg.h,v 1.7 2006/03/08 09:21:14 dlg Exp $ */
-
-/*
- * Copyright (c) 2006 Alexander Yurchenko <grange@openbsd.org>
- *
- * Permission to use, copy, modify, and distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
-
-/*-
- * Copyright (c) 2002 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Enami Tsugutomo.
- *
- * 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 by the NetBSD
- * Foundation, Inc. and its contributors.
- * 4. Neither the name of The NetBSD Foundation nor the names of its
- * contributors may be used to endorse or promote products derived
- * from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 THE FOUNDATION OR CONTRIBUTORS
- * 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.
- */
-
-#define AMDPM_CONFREG 0x40
-
-/* 0x40: General Configuration 1 Register */
-#define AMDPM_RNGEN 0x00000080 /* random number generator enable */
-#define AMDPM_STOPTMR 0x00000040 /* stop free-running timer */
-
-/* 0x41: General Configuration 2 Register */
-#define AMDPM_PMIOEN 0x00008000 /* system management IO space enable */
-#define AMDPM_TMRRST 0x00004000 /* reset free-running timer */
-#define AMDPM_TMR32 0x00000800 /* extended (32 bit) timer enable */
-
-/* 0x42: SCI Interrupt Configuration Register */
-/* 0x43: Previous Power State Register */
-
-#define AMDPM_PMPTR 0x58 /* PMxx System Management IO space
- Pointer */
-#define NFPM_PMPTR 0x14 /* nForce System Management IO space
- POinter */
-#define AMDPM_PMBASE(x) ((x) & 0xff00) /* PMxx base address */
-#define AMDPM_PMSIZE 256 /* PMxx space size */
-
-/* Registers in PMxx space */
-#define AMDPM_TMR 0x08 /* 24/32 bit timer register */
-
-#define AMDPM_RNGDATA 0xf0 /* 32 bit random data register */
-#define AMDPM_RNGSTAT 0xf4 /* RNG status register */
-#define AMDPM_RNGDONE 0x00000001 /* Random number generation complete */
-
-#define AMDPM_SMB_REGS 0xe0 /* offset of SMB register space */
-#define AMDPM_SMB_SIZE 0xf /* size of SMB register space */
-#define AMDPM_SMBSTAT 0x0 /* SMBus status */
-#define AMDPM_SMBSTAT_ABRT (1 << 0) /* transfer abort */
-#define AMDPM_SMBSTAT_COL (1 << 1) /* collision */
-#define AMDPM_SMBSTAT_PRERR (1 << 2) /* protocol error */
-#define AMDPM_SMBSTAT_HBSY (1 << 3) /* host controller busy */
-#define AMDPM_SMBSTAT_CYC (1 << 4) /* cycle complete */
-#define AMDPM_SMBSTAT_TO (1 << 5) /* timeout */
-#define AMDPM_SMBSTAT_SNP (1 << 8) /* snoop address match */
-#define AMDPM_SMBSTAT_SLV (1 << 9) /* slave address match */
-#define AMDPM_SMBSTAT_SMBA (1 << 10) /* SMBALERT# asserted */
-#define AMDPM_SMBSTAT_BSY (1 << 11) /* bus busy */
-#define AMDPM_SMBSTAT_BITS "\020\001ABRT\002COL\003PRERR\004HBSY\005CYC\006TO\011SNP\012SLV\013SMBA\014BSY"
-#define AMDPM_SMBCTL 0x2 /* SMBus control */
-#define AMDPM_SMBCTL_CMD_QUICK 0 /* QUICK command */
-#define AMDPM_SMBCTL_CMD_BYTE 1 /* BYTE command */
-#define AMDPM_SMBCTL_CMD_BDATA 2 /* BYTE DATA command */
-#define AMDPM_SMBCTL_CMD_WDATA 3 /* WORD DATA command */
-#define AMDPM_SMBCTL_CMD_PCALL 4 /* PROCESS CALL command */
-#define AMDPM_SMBCTL_CMD_BLOCK 5 /* BLOCK command */
-#define AMDPM_SMBCTL_START (1 << 3) /* start transfer */
-#define AMDPM_SMBCTL_CYCEN (1 << 4) /* intr on cycle complete */
-#define AMDPM_SMBCTL_ABORT (1 << 5) /* abort transfer */
-#define AMDPM_SMBCTL_SNPEN (1 << 8) /* intr on snoop addr match */
-#define AMDPM_SMBCTL_SLVEN (1 << 9) /* intr on slave addr match */
-#define AMDPM_SMBCTL_SMBAEN (1 << 10) /* intr on SMBALERT# */
-#define AMDPM_SMBADDR 0x4 /* SMBus address */
-#define AMDPM_SMBADDR_READ (1 << 0) /* read direction */
-#define AMDPM_SMBADDR_ADDR(x) (((x) & 0x7f) << 1) /* 7-bit address */
-#define AMDPM_SMBDATA 0x6 /* SMBus data */
-#define AMDPM_SMBCMD 0x8 /* SMBus command */