Index: kernel/arch/sparc64/src/smc.c
===================================================================
--- kernel/arch/sparc64/src/smc.c	(revision 78de83de52a9115dc77b09bb7029403dad8c2fb0)
+++ kernel/arch/sparc64/src/smc.c	(revision 78de83de52a9115dc77b09bb7029403dad8c2fb0)
@@ -0,0 +1,60 @@
+/*
+ * Copyright (c) 2005 Jakub Jermar
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ * - Redistributions of source code must retain the above copyright
+ *   notice, this list of conditions and the following disclaimer.
+ * - 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.
+ * - The name of the author may not be used to endorse or promote products
+ *   derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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.
+ */
+
+#include <barrier.h>
+#include <arch/barrier.h>
+
+#if defined(US)
+
+#define FLUSH_INVAL_MIN  4
+
+void smc_coherence(void *a, size_t l)
+{
+	asm volatile ("membar #StoreStore\n" ::: "memory");
+
+	for (size_t i = 0; i < l; i += FLUSH_INVAL_MIN) {
+		asm volatile (
+		    "flush %[reg]\n"
+		    :: [reg] "r" (a + i)
+		    : "memory"
+		);
+	}
+}
+
+#elif defined (US3)
+
+
+void smc_coherence(void *a, size_t l)
+{
+	asm volatile ("membar #StoreStore\n" ::: "memory");
+
+	flush_pipeline();
+}
+
+#endif  /* defined(US3) */
+
Index: kernel/arch/sparc64/src/smp/sun4u/ipi.c
===================================================================
--- kernel/arch/sparc64/src/smp/sun4u/ipi.c	(revision 7f7d64298fbfdc2ce850eb86156d829a4def23e6)
+++ kernel/arch/sparc64/src/smp/sun4u/ipi.c	(revision 78de83de52a9115dc77b09bb7029403dad8c2fb0)
@@ -34,4 +34,5 @@
 
 #include <smp/ipi.h>
+#include <arch/barrier.h>
 #include <arch/smp/sun4u/ipi.h>
 #include <assert.h>
Index: kernel/arch/sparc64/src/trap/sun4u/interrupt.c
===================================================================
--- kernel/arch/sparc64/src/trap/sun4u/interrupt.c	(revision 7f7d64298fbfdc2ce850eb86156d829a4def23e6)
+++ kernel/arch/sparc64/src/trap/sun4u/interrupt.c	(revision 78de83de52a9115dc77b09bb7029403dad8c2fb0)
@@ -33,4 +33,5 @@
  */
 
+#include <arch/barrier.h>
 #include <arch/interrupt.h>
 #include <arch/sparc64.h>
