Module Name:    src
Committed By:   matt
Date:           Sun Feb 28 03:26:25 UTC 2010

Modified Files:
        src/sys/arch/mips/include [matt-nb5-mips64]: intr.h

Log Message:
Now that we use stubs for the spl* calls, we no longer need to export
struct splsw or struct ipl_sr_map to the world.  So we protect those with
__INTR_PRIVATE.


To generate a diff of this commit:
cvs rdiff -u -r1.3.96.5 -r1.3.96.6 src/sys/arch/mips/include/intr.h

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/arch/mips/include/intr.h
diff -u src/sys/arch/mips/include/intr.h:1.3.96.5 src/sys/arch/mips/include/intr.h:1.3.96.6
--- src/sys/arch/mips/include/intr.h:1.3.96.5	Tue Feb 23 20:24:36 2010
+++ src/sys/arch/mips/include/intr.h	Sun Feb 28 03:26:25 2010
@@ -1,4 +1,4 @@
-/* $NetBSD: intr.h,v 1.3.96.5 2010/02/23 20:24:36 matt Exp $ */
+/* $NetBSD: intr.h,v 1.3.96.6 2010/02/28 03:26:25 matt Exp $ */
 /*-
  * Copyright (c) 2009, 2010 The NetBSD Foundation, Inc.
  * All rights reserved.
@@ -61,6 +61,7 @@
 #define	IPI_ISYNC	__BIT(4)	/* sync icache for pages */
 #define	IPI_KPREEMPT	__BIT(5)	/* schedule a kernel preemption */
 
+#ifdef __INTR_PRIVATE
 struct splsw {
 	int	(*splsw_splhigh)(void);
 	int	(*splsw_splsched)(void);
@@ -74,108 +75,52 @@
 	void	(*splsw_splx)(int);
 	int	(*splsw_splhigh_noprof)(void);
 	void	(*splsw_splx_noprof)(int);
-	void	(*splsw_setsoftintr)(uint32_t);
-	void	(*splsw_clrsoftintr)(uint32_t);
+	void	(*splsw__setsoftintr)(uint32_t);
+	void	(*splsw__clrsoftintr)(uint32_t);
 	int	(*splsw_splintr)(uint32_t *);
 	void	(*splsw_splcheck)(void);
 };
 
+struct ipl_sr_map {
+	uint32_t sr_bits[_IPL_N];
+};
+#endif /* __INTR_PRIVATE */
+
 typedef int ipl_t;
 typedef struct {
         ipl_t _spl;
 } ipl_cookie_t;
 
-struct ipl_sr_map {
-	uint32_t sr_bits[_IPL_N];
-};
-
 #ifdef _KERNEL
 #ifdef MULTIPROCESSOR
 #define __HAVE_PREEMPTION
 #define SOFTINT_KPREEMPT	(SOFTINT_COUNT+0)
 #endif
 
+#ifdef __INTR_PRIVATE
 extern	struct splsw	mips_splsw;
 extern	struct ipl_sr_map ipl_sr_map;
+#endif /* __INTR_PRIVATE */
 
-static inline int
-splhigh(void)
-{
-	return (*mips_splsw.splsw_splhigh)();
-}
-
-static inline int
-splhigh_noprof(void)
-{
-	return (*mips_splsw.splsw_splhigh_noprof)();
-}
-
-static inline int
-splsched(void)
-{
-	return (*mips_splsw.splsw_splsched)();
-}
-
-static inline int
-splvm(void)
-{
-	return (*mips_splsw.splsw_splvm)();
-}
-
-static inline int
-splsoftserial(void)
-{
-	return (*mips_splsw.splsw_splsoftserial)();
-}
-
-static inline int
-splsoftnet(void)
-{
-	return (*mips_splsw.splsw_splsoftnet)();
-}
-
-static inline int
-splsoftbio(void)
-{
-	return (*mips_splsw.splsw_splsoftbio)();
-}
-
-static inline int
-splsoftclock(void)
-{
-	return (*mips_splsw.splsw_splsoftclock)();
-}
-
-static inline void
-spl0(void)
-{
-	(*mips_splsw.splsw_spl0)();
-}
-
-static inline void
-splx(int s)
-{
-	(*mips_splsw.splsw_splx)(s);
-}
-
-static inline void
-splx_noprof(int s)
-{
-	(*mips_splsw.splsw_splx_noprof)(s);
-}
-
-static inline void
-_setsoftintr(uint32_t m)
-{
-	(*mips_splsw.splsw_setsoftintr)(m);
-}
-
-static inline void
-_clrsoftintr(uint32_t m)
-{
-	(*mips_splsw.splsw_clrsoftintr)(m);
-}
+int	splhigh(void);
+int	splhigh_noprof(void);
+int	splsched(void);
+int	splvm(void);
+int	splsoftserial(void);
+int	splsoftnet(void);
+int	splsoftbio(void);
+int	splsoftclock(void);
+int	splraise(int);
+void	splx(int);
+void	splx_noprof(int);
+void	spl0(void);
+int	splintr(uint32_t *);
+void	_setsoftintr(uint32_t);
+void	_clrsoftintr(uint32_t);
 
+/*
+ * These make no sense *NOT* to be inlined.
+ */
 static inline ipl_cookie_t
 makeiplcookie(ipl_t s)
 {
@@ -183,22 +128,10 @@
 }
 
 static inline int
-splraise(int s)
-{
-        return (*mips_splsw.splsw_splraise)(s);
-}
-
-static inline int
 splraiseipl(ipl_cookie_t icookie)
 {
 	return splraise(icookie._spl);
 }
 
-static inline int
-splintr(uint32_t *p)
-{
-	return (*mips_splsw.splsw_splintr)(p);
-}
-
 #endif /* _KERNEL */
 #endif /* _MIPS_INTR_H_ */

Reply via email to