Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys Add acpi_intr_mask() and acpi_intr_unmask() which, follo...
details: https://anonhg.NetBSD.org/src/rev/f48c380459c6
branches: trunk
changeset: 466451:f48c380459c6
user: thorpej <thorpej%NetBSD.org@localhost>
date: Sun Dec 22 15:57:06 2019 +0000
description:
Add acpi_intr_mask() and acpi_intr_unmask() which, following the pre-existing
ACPI software layering model, are wrappers around acpi_md_intr_mask() and
acpi_md_intr_unmask(), which in turn are wrappers around intr_mask() and
intr_unmask().
XXX ARM and IA64 implementations of acpi_md_intr_mask() and
acpi_md_intr_unmask() are just stubs for now.
diffstat:
sys/arch/arm/acpi/acpi_machdep.c | 18 ++++++++++++++++--
sys/arch/arm/include/acpi_machdep.h | 4 +++-
sys/arch/ia64/acpi/acpi_machdep.c | 18 ++++++++++++++++--
sys/arch/ia64/include/acpi_machdep.h | 4 +++-
sys/arch/x86/acpi/acpi_machdep.c | 16 ++++++++++++++--
sys/arch/x86/include/acpi_machdep.h | 4 +++-
sys/dev/acpi/acpi_intr.h | 10 +++++++++-
sys/dev/acpi/acpi_util.c | 20 ++++++++++++++++++--
8 files changed, 82 insertions(+), 12 deletions(-)
diffs (235 lines):
diff -r ef0a217ed68a -r f48c380459c6 sys/arch/arm/acpi/acpi_machdep.c
--- a/sys/arch/arm/acpi/acpi_machdep.c Sun Dec 22 15:15:20 2019 +0000
+++ b/sys/arch/arm/acpi/acpi_machdep.c Sun Dec 22 15:57:06 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_machdep.c,v 1.10 2019/08/12 15:37:26 skrll Exp $ */
+/* $NetBSD: acpi_machdep.c,v 1.11 2019/12/22 15:57:06 thorpej Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -32,7 +32,7 @@
#include "pci.h"
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_machdep.c,v 1.10 2019/08/12 15:37:26 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_machdep.c,v 1.11 2019/12/22 15:57:06 thorpej Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -257,6 +257,20 @@
}
void
+acpi_md_intr_mask(void *ih)
+{
+ /* XXX */
+ panic("acpi_md_intr_mask(%p): not implemented", ih);
+}
+
+void
+acpi_md_intr_unmask(void *ih)
+{
+ /* XXX */
+ panic("acpi_md_intr_unmask(%p): not implemented", ih);
+}
+
+void
acpi_md_intr_disestablish(void *ih)
{
intr_disestablish(ih);
diff -r ef0a217ed68a -r f48c380459c6 sys/arch/arm/include/acpi_machdep.h
--- a/sys/arch/arm/include/acpi_machdep.h Sun Dec 22 15:15:20 2019 +0000
+++ b/sys/arch/arm/include/acpi_machdep.h Sun Dec 22 15:57:06 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_machdep.h,v 1.2 2018/11/16 23:03:55 jmcneill Exp $ */
+/* $NetBSD: acpi_machdep.h,v 1.3 2019/12/22 15:57:06 thorpej Exp $ */
/*-
* Copyright (c) 2018 The NetBSD Foundation, Inc.
@@ -48,6 +48,8 @@
void acpi_md_OsDisableInterrupt(void);
void * acpi_md_intr_establish(uint32_t, int, int, int (*)(void *),
void *, bool, const char *);
+void acpi_md_intr_mask(void *);
+void acpi_md_intr_unmask(void *);
void acpi_md_intr_disestablish(void *);
int acpi_md_sleep(int);
uint32_t acpi_md_pdc(void);
diff -r ef0a217ed68a -r f48c380459c6 sys/arch/ia64/acpi/acpi_machdep.c
--- a/sys/arch/ia64/acpi/acpi_machdep.c Sun Dec 22 15:15:20 2019 +0000
+++ b/sys/arch/ia64/acpi/acpi_machdep.c Sun Dec 22 15:57:06 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_machdep.c,v 1.9 2018/11/17 20:53:35 scole Exp $ */
+/* $NetBSD: acpi_machdep.c,v 1.10 2019/12/22 15:57:06 thorpej Exp $ */
/*
* Copyright (c) 2009 KIYOHARA Takashi
* All rights reserved.
@@ -28,7 +28,7 @@
* Machine-dependent routines for ACPICA.
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_machdep.c,v 1.9 2018/11/17 20:53:35 scole Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_machdep.c,v 1.10 2019/12/22 15:57:06 thorpej Exp $");
#include <sys/param.h>
@@ -126,6 +126,20 @@
}
void
+acpi_md_intr_mask(void *ih)
+{
+ /* XXX */
+ panic("acpi_md_intr_mask(%p): not implemented", ih);
+}
+
+void
+acpi_md_intr_unmask(void *ih)
+{
+ /* XXX */
+ panic("acpi_md_intr_unmask(%p): not implemented", ih);
+}
+
+void
acpi_md_intr_disestablish(void *ih)
{
intr_disestablish(ih);
diff -r ef0a217ed68a -r f48c380459c6 sys/arch/ia64/include/acpi_machdep.h
--- a/sys/arch/ia64/include/acpi_machdep.h Sun Dec 22 15:15:20 2019 +0000
+++ b/sys/arch/ia64/include/acpi_machdep.h Sun Dec 22 15:57:06 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_machdep.h,v 1.8 2018/11/16 23:03:55 jmcneill Exp $ */
+/* $NetBSD: acpi_machdep.h,v 1.9 2019/12/22 15:57:07 thorpej Exp $ */
ACPI_STATUS acpi_md_OsInitialize(void);
ACPI_PHYSICAL_ADDRESS acpi_md_OsGetRootPointer(void);
@@ -27,6 +27,8 @@
void * acpi_md_intr_establish(uint32_t, int, int, int (*)(void *),
void *, bool, const char *);
+void acpi_md_intr_mask(void *);
+void acpi_md_intr_unmask(void *);
void acpi_md_intr_disestablish(void *);
int acpi_md_sleep(int);
diff -r ef0a217ed68a -r f48c380459c6 sys/arch/x86/acpi/acpi_machdep.c
--- a/sys/arch/x86/acpi/acpi_machdep.c Sun Dec 22 15:15:20 2019 +0000
+++ b/sys/arch/x86/acpi/acpi_machdep.c Sun Dec 22 15:57:06 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_machdep.c,v 1.28 2019/09/12 14:28:08 martin Exp $ */
+/* $NetBSD: acpi_machdep.c,v 1.29 2019/12/22 15:57:07 thorpej Exp $ */
/*
* Copyright 2001 Wasabi Systems, Inc.
@@ -40,7 +40,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_machdep.c,v 1.28 2019/09/12 14:28:08 martin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_machdep.c,v 1.29 2019/12/22 15:57:07 thorpej Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -353,6 +353,18 @@
}
void
+acpi_md_intr_mask(void *ih)
+{
+ intr_mask(ih);
+}
+
+void
+acpi_md_intr_unmask(void *ih)
+{
+ intr_unmask(ih);
+}
+
+void
acpi_md_intr_disestablish(void *ih)
{
intr_disestablish(ih);
diff -r ef0a217ed68a -r f48c380459c6 sys/arch/x86/include/acpi_machdep.h
--- a/sys/arch/x86/include/acpi_machdep.h Sun Dec 22 15:15:20 2019 +0000
+++ b/sys/arch/x86/include/acpi_machdep.h Sun Dec 22 15:57:06 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_machdep.h,v 1.13 2018/11/16 23:03:55 jmcneill Exp $ */
+/* $NetBSD: acpi_machdep.h,v 1.14 2019/12/22 15:57:07 thorpej Exp $ */
/*
* Copyright 2001 Wasabi Systems, Inc.
@@ -72,6 +72,8 @@
void * acpi_md_intr_establish(uint32_t, int, int, int (*)(void *),
void *, bool, const char *);
+void acpi_md_intr_mask(void *);
+void acpi_md_intr_unmask(void *);
void acpi_md_intr_disestablish(void *);
int acpi_md_sleep(int);
diff -r ef0a217ed68a -r f48c380459c6 sys/dev/acpi/acpi_intr.h
--- a/sys/dev/acpi/acpi_intr.h Sun Dec 22 15:15:20 2019 +0000
+++ b/sys/dev/acpi/acpi_intr.h Sun Dec 22 15:57:06 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_intr.h,v 1.3 2018/11/16 23:05:50 jmcneill Exp $ */
+/* $NetBSD: acpi_intr.h,v 1.4 2019/12/22 15:57:07 thorpej Exp $ */
/*-
* Copyright (c) 2017 The NetBSD Foundation, Inc.
@@ -28,7 +28,15 @@
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
+
+#ifndef _DEV_ACPI_ACPI_INTR_H_
+#define _DEV_ACPI_ACPI_INTR_H_
+
void * acpi_intr_establish(device_t, uint64_t, int, bool,
int (*intr)(void *), void *, const char *);
+void acpi_intr_mask(void *);
+void acpi_intr_unmask(void *);
void acpi_intr_disestablish(void *);
const char * acpi_intr_string(void *, char *, size_t len);
+
+#endif /* _DEV_ACPI_ACPI_INTR_H_ */
diff -r ef0a217ed68a -r f48c380459c6 sys/dev/acpi/acpi_util.c
--- a/sys/dev/acpi/acpi_util.c Sun Dec 22 15:15:20 2019 +0000
+++ b/sys/dev/acpi/acpi_util.c Sun Dec 22 15:57:06 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_util.c,v 1.15 2018/12/21 14:51:12 jmcneill Exp $ */
+/* $NetBSD: acpi_util.c,v 1.16 2019/12/22 15:57:07 thorpej Exp $ */
/*-
* Copyright (c) 2003, 2007 The NetBSD Foundation, Inc.
@@ -65,7 +65,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_util.c,v 1.15 2018/12/21 14:51:12 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_util.c,v 1.16 2019/12/22 15:57:07 thorpej Exp $");
#include <sys/param.h>
#include <sys/kmem.h>
@@ -591,6 +591,22 @@
}
void
+acpi_intr_mask(void *c)
+{
+ struct acpi_irq_handler * const aih = c;
+
+ acpi_md_intr_mask(aih->aih_ih);
+}
+
+void
+acpi_intr_unmask(void *c)
+{
+ struct acpi_irq_handler * const aih = c;
+
+ acpi_md_intr_unmask(aih->aih_ih);
+}
+
+void
acpi_intr_disestablish(void *c)
{
struct acpi_irq_handler *aih = c;
Home |
Main Index |
Thread Index |
Old Index