patch-1.3.44 linux/arch/sparc/kernel/probe.c
Next file: linux/arch/sparc/kernel/process.c
Previous file: linux/arch/sparc/kernel/mp.S
Back to the patch index
Back to the overall index
-  Lines: 666
-  Date:
Sat Nov 25 02:58:17 1995
-  Orig file: 
v1.3.43/linux/arch/sparc/kernel/probe.c
-  Orig date: 
Tue Jun 27 14:11:32 1995
diff -u --recursive --new-file v1.3.43/linux/arch/sparc/kernel/probe.c linux/arch/sparc/kernel/probe.c
@@ -1,4 +1,5 @@
-/* probe.c: Preliminary device tree probing routines...
+/* $Id: probe.c,v 1.38 1995/11/25 00:58:14 davem Exp $
+ * probe.c: Preliminary device tree probing routines...
  *
  * Copyright (C) 1995 David S. Miller (davem@caip.rutgers.edu)
  */
@@ -11,6 +12,7 @@
 #include <asm/oplib.h>
 #include <asm/vac-ops.h>
 #include <asm/idprom.h>
+#include <asm/machines.h>
 #include <asm/io.h>
 #include <asm/vaddrs.h>
 #include <asm/param.h>
@@ -24,12 +26,14 @@
 /* #define DEBUG_PROBING */
 
 /* XXX Grrr, this stuff should have it's own file, only generic stuff goes
- * XXX here.  Possibly clock.c and timer.c?
+ * XXX here.  Possibly clock.c and timer.c?  This file should get smaller
+ * XXX and smaller as time goes on...
  */
 enum sparc_clock_type sp_clock_typ;
 struct mostek48t02 *mstk48t02_regs;
 struct mostek48t08 *mstk48t08_regs;
 volatile unsigned int *master_l10_limit = 0;
+volatile unsigned int *master_l10_counter = 0;
 struct sun4m_timer_regs *sun4m_timers;
 
 static char node_str[128];
@@ -124,7 +128,7 @@
   { 7, 0, "Harvest VLSI Design Center, Inc. - unknown"},
   /* Gallium arsenide 200MHz, BOOOOGOOOOMIPS!!! */
   { 8, 0, "Systems and Processes Engineering Corporation (SPEC)"},
-  { 9, 0, "UNKNOWN CPU-VENDOR/TYPE"},
+  { 9, 0, "Fujitsu #3"},
   { 0xa, 0, "UNKNOWN CPU-VENDOR/TYPE"},
   { 0xb, 0, "UNKNOWN CPU-VENDOR/TYPE"},
   { 0xc, 0, "UNKNOWN CPU-VENDOR/TYPE"},
@@ -138,16 +142,6 @@
 char *sparc_cpu_type[NCPUS] = { "cpu-oops", "cpu-oops1", "cpu-oops2", "cpu-oops3" };
 char *sparc_fpu_type[NCPUS] = { "fpu-oops", "fpu-oops1", "fpu-oops2", "fpu-oops3" };
 
-/* various Virtual Address Cache parameters we find at boot time... */
-
-extern int vac_size, vac_linesize, vac_do_hw_vac_flushes;
-extern int vac_entries_per_context, vac_entries_per_segment;
-extern int vac_entries_per_page;
-
-extern int find_vac_size(void);
-extern int find_vac_linesize(void);
-extern int find_vac_hwflushes(void);
-
 static inline int find_mmu_num_contexts(int cpu)
 {
 	return prom_getintdefault(cpu, "mmu-nctx", 0x8);
@@ -158,99 +152,126 @@
 void
 probe_cpu(void)
 {
-  int psr_impl, psr_vers, fpu_vers;
-  int i, cpuid;
+	int psr_impl, psr_vers, fpu_vers;
+	int i, cpuid;
+
+	cpuid = get_cpuid();
 
-  cpuid = get_cpuid();
+	psr_impl = ((get_psr()>>28)&0xf);
+	psr_vers = ((get_psr()>>24)&0xf);
 
-  psr_impl = ((get_psr()>>28)&0xf);
-  psr_vers = ((get_psr()>>24)&0xf);
+	fpu_vers = ((get_fsr()>>17)&0x7);
 
-  fpu_vers = ((get_fsr()>>17)&0x7);
-
-  for(i = 0; i<NSPARCCHIPS; i++)
-    {
-      if(linux_sparc_chips[i].psr_impl == psr_impl)
-	if(linux_sparc_chips[i].psr_vers == psr_vers)
-	  {
-	    sparc_cpu_type[cpuid] = linux_sparc_chips[i].cpu_name;
-	    break;
-	  }
-    }
-
-  if(i==NSPARCCHIPS)
-    {
-      printk("No CPU type! You lose\n");
-      printk("DEBUG: psr.impl = 0x%x   psr.vers = 0x%x\n", psr_impl, 
-	     psr_vers);
-      printk("Send this information and the type of SUN and CPU/FPU type you have\n");
-      printk("to davem@caip.rutgers.edu so that this can be fixed.\n");
-      printk("halting...\n\r\n");
-      /* If I don't know about this CPU, I don't want people running on it
-       * until I do.....
-       */
-      halt();
-    }
-
-  for(i = 0; i<NSPARCFPU; i++)
-    {
-      if(linux_sparc_fpu[i].psr_impl == psr_impl)
-	if(linux_sparc_fpu[i].fp_vers == fpu_vers)
-	  {
-	    sparc_fpu_type[cpuid] = linux_sparc_fpu[i].fp_name;
-	    break;
-	  }
-    }
-
-  if(i == NSPARCFPU)
-    {
-      printk("No FPU type! You don't completely lose though...\n");
-      printk("DEBUG: psr.impl = 0x%x  fsr.vers = 0x%x\n", psr_impl, fpu_vers);
-      printk("Send this information and the type of SUN and CPU/FPU type you have\n");
-      printk("to davem@caip.rutgers.edu so that this can be fixed.\n");
-      sparc_fpu_type[cpuid] = linux_sparc_fpu[31].fp_name;
-    }
+	for(i = 0; i<NSPARCCHIPS; i++) {
+		if(linux_sparc_chips[i].psr_impl == psr_impl)
+			if(linux_sparc_chips[i].psr_vers == psr_vers) {
+				sparc_cpu_type[cpuid] = linux_sparc_chips[i].cpu_name;
+				break;
+			}
+	}
 
-  printk("cpu%d CPU: %s \n", cpuid, sparc_cpu_type[cpuid]);
-  printk("cpu%d FPU: %s \n", cpuid, sparc_fpu_type[cpuid]);
+	if(i==NSPARCCHIPS)
+		printk("DEBUG: psr.impl = 0x%x   psr.vers = 0x%x\n", psr_impl, 
+			    psr_vers);
+
+	for(i = 0; i<NSPARCFPU; i++) {
+		if(linux_sparc_fpu[i].psr_impl == psr_impl)
+			if(linux_sparc_fpu[i].fp_vers == fpu_vers) {
+				sparc_fpu_type[cpuid] = linux_sparc_fpu[i].fp_name;
+				break;
+			}
+	}
 
-  return;
+	if(i == NSPARCFPU) {
+		printk("DEBUG: psr.impl = 0x%x  fsr.vers = 0x%x\n", psr_impl,
+			    fpu_vers);
+		sparc_fpu_type[cpuid] = linux_sparc_fpu[31].fp_name;
+	}
+
+	printk("cpu%d CPU: %s \n", cpuid, sparc_cpu_type[cpuid]);
+	printk("cpu%d FPU: %s \n", cpuid, sparc_fpu_type[cpuid]);
 }
 
 void
 probe_vac(void)
 {
-	unsigned int x,y;
+	int propval;
+
+	sun4c_disable_vac();
+	sun4c_vacinfo.num_bytes = prom_getintdefault(prom_root_node,
+						     "vac-size", 65536);
+	sun4c_vacinfo.linesize = prom_getintdefault(prom_root_node,
+						    "vac-linesize", 16);
+	sun4c_vacinfo.num_lines =
+		(sun4c_vacinfo.num_bytes / sun4c_vacinfo.linesize);
+	switch(sun4c_vacinfo.linesize) {
+	case 16:
+		sun4c_vacinfo.log2lsize = 4;
+		break;
+	case 32:
+		sun4c_vacinfo.log2lsize = 5;
+		break;
+	default:
+		printk("probe_vac: Didn't expect vac-linesize of %d, halting\n",
+			    sun4c_vacinfo.linesize);
+	};
 
-	vac_size = find_vac_size();
-	vac_linesize = find_vac_linesize();
-	vac_do_hw_vac_flushes = find_vac_hwflushes();
+	propval = prom_getintdefault(prom_root_node, "vac_hwflush", -1);
+	sun4c_vacinfo.do_hwflushes = (propval == -1 ?
+				      prom_getintdefault(prom_root_node,
+							 "vac-hwflush", 0) :
+				      propval);
+
+	printk("SUN4C: VAC size %d line size %d using %s flushes ",
+	       sun4c_vacinfo.num_bytes, sun4c_vacinfo.linesize,
+	       (sun4c_vacinfo.do_hwflushes ? "hardware" : "software"));
+	if(sun4c_vacinfo.num_bytes != 65536) {
+		printk("WEIRD Sun4C VAC cache size, tell davem");
+		prom_halt();
+	}
 
-	/* Calculate various constants that make the cache-flushing code
-	 * mode speedy.
-	 */
+	/* setup the low-level assembly routine ptrs */
+	if(sun4c_vacinfo.do_hwflushes) {
+		if(sun4c_vacinfo.linesize == 16) {
+			sun4c_ctxflush = (unsigned long)sun4c_ctxflush_hw64KB16B;
+			sun4c_segflush = (unsigned long)sun4c_segflush_hw64KB16B;
+			sun4c_pgflush = (unsigned long)sun4c_pgflush_hw64KB16B;
+		} else if(sun4c_vacinfo.linesize == 32) {
+			sun4c_ctxflush = (unsigned long)sun4c_ctxflush_hw64KB32B;
+			sun4c_segflush = (unsigned long)sun4c_segflush_hw64KB32B;
+			sun4c_pgflush = (unsigned long)sun4c_pgflush_hw64KB32B;
+		} else {
+			printk("WEIRD Sun4C VAC cache line size, tell davem\n");
+			prom_halt();
+		}
+	} else {
+		if(sun4c_vacinfo.linesize == 16) {
+			sun4c_ctxflush = (unsigned long)sun4c_ctxflush_sw64KB16B;
+			sun4c_segflush = (unsigned long)sun4c_segflush_sw64KB16B;
+			sun4c_pgflush = (unsigned long)sun4c_pgflush_sw64KB16B;
+		} else if(sun4c_vacinfo.linesize == 32) {
+			sun4c_ctxflush = (unsigned long)sun4c_ctxflush_sw64KB32B;
+			sun4c_segflush = (unsigned long)sun4c_segflush_sw64KB32B;
+			sun4c_pgflush = (unsigned long)sun4c_pgflush_sw64KB32B;
+		} else {
+			printk("WEIRD Sun4C VAC cache line size, tell davem\n");
+			prom_halt();
+		}
+	}
 
-	vac_entries_per_segment = vac_entries_per_context = vac_size >> 12;
-	for(x=0,y=vac_linesize; ((1<<x)<y); x++);
-	if((1<<x) != vac_linesize) printk("Warning BOGUS VAC linesize 0x%x",
-					  vac_size);
-	vac_entries_per_page = x;
 
-	/* Here we want to 'invalidate' all the software VAC "tags"
-	 * just in case there is garbage in there. Then we enable it.
-	 */
+	sun4c_flush_all();
+	sun4c_enable_vac();
+	printk("enabled\n");
 
-	/* flush flush flush */
-	for(x=AC_CACHETAGS; x<(AC_CACHETAGS+vac_size); x+=vac_linesize)
-		__asm__("sta %%g0, [%0] %1" : : "r" (x), "i" (0x2));
-	x=enable_vac();
 	return;
 }
 
 extern int num_segmaps, num_contexts;
 
+/* XXX Only called on sun4c XXX */
 void
-probe_mmu(int prom_node_cpu)
+probe_mmu(void)
 {
 	int cpuid;
 
@@ -258,177 +279,146 @@
 	cpuid = get_cpuid();
 	switch(sparc_cpu_model) {
 	case sun4:
-		break;
 	case sun4c:
-		/* A sun4, sun4c. */
-		num_segmaps = prom_getintdefault(prom_node_cpu, "mmu-npmg", 128);
-		num_contexts = find_mmu_num_contexts(prom_node_cpu);
+	case sun4e:
+		/* A sun4, sun4c or sun4e. */
+		num_segmaps = prom_getintdefault(prom_root_node, "mmu-npmg", 128);
+		num_contexts = find_mmu_num_contexts(prom_root_node);
 
 		printk("cpu%d MMU segmaps: %d     MMU contexts: %d\n", cpuid,
-		       num_segmaps, num_contexts);
-		break;
-	case sun4m:
-	case sun4d:
-	case sun4e:
-		/* Any Reference MMU derivate should be handled here, hopefuly. */
-		num_segmaps = 0;
-		num_contexts = find_mmu_num_contexts(prom_node_cpu);
-		vac_linesize = prom_getint(prom_node_cpu, "cache-line-size");
-		vac_size = (prom_getint(prom_node_cpu, "cache-nlines")*vac_linesize);
-		printk("cpu%d MMU contexts: %d\n", cpuid, num_contexts);
-		printk("cpu%d CACHE linesize %d total size %d\n", cpuid, vac_linesize,
-		       vac_size);
+			    num_segmaps, num_contexts);
 		break;
 	default:
 		printk("cpu%d probe_mmu: sparc_cpu_model botch\n", cpuid);
 		break;
 	};
-
-	return;
 }
 
 /* Clock probing, we probe the timers here also. */
-/* #define DEBUG_PROBE_CLOCK */
 volatile unsigned int foo_limit;
 
 void
 probe_clock(int fchild)
 {
-  register int node, type;
-  struct linux_prom_registers clk_reg[2];
+	register int node, type;
+	struct linux_prom_registers clk_reg[2];
 
-  /* This will basically traverse the node-tree of the prom to see
-   * which timer chip is on this machine.
-   */
-
-  node = 0;
-  if(sparc_cpu_model == sun4) {
-	  printk("probe_clock: No SUN4 Clock/Timer support yet...\n");
-	  return;
-  }
-  if(sparc_cpu_model == sun4c) node=prom_getchild(prom_root_node);
-  else
-	  if(sparc_cpu_model == sun4m)
-		  node=prom_getchild(prom_searchsiblings(prom_getchild(prom_root_node), "obio"));
-  type = 0;
-  sp_clock_typ = MSTK_INVALID;
-  for(;;) {
-	  prom_getstring(node, "model", node_str, sizeof(node_str));
-	  if(strcmp(node_str, "mk48t02") == 0) {
-		  sp_clock_typ = MSTK48T02;
-		  if(prom_getproperty(node, "reg", (char *) clk_reg, sizeof(clk_reg)) == -1) {
-			  printk("probe_clock: FAILED!\n");
-			  halt();
-		  }
-		  prom_apply_obio_ranges(clk_reg, 1);
-		  /* Map the clock register io area read-only */
-		  mstk48t02_regs = (struct mostek48t02 *) 
-			  sparc_alloc_io((void *) clk_reg[0].phys_addr,
-					 (void *) 0, sizeof(*mstk48t02_regs),
-					 "clock", 0x0, 0x1);
-		  mstk48t08_regs = 0;  /* To catch weirdness */
-		  break;
-	  }
-
-	  if(strcmp(node_str, "mk48t08") == 0) {
-		  sp_clock_typ = MSTK48T08;
-		  if(prom_getproperty(node, "reg", (char *) clk_reg,
-				      sizeof(clk_reg)) == -1) {
-			  printk("probe_clock: FAILED!\n");
-			  halt();
-		  }
-		  prom_apply_obio_ranges(clk_reg, 1);
-		  /* Map the clock register io area read-only */
-		  mstk48t08_regs = (struct mostek48t08 *)
-			  sparc_alloc_io((void *) clk_reg[0].phys_addr,
-					 (void *) 0, sizeof(*mstk48t08_regs),
-					 "clock", 0x0, 0x1);
-
-		  mstk48t02_regs = &mstk48t08_regs->regs;
-		  break;
-	  }
-
-	  node = prom_getsibling(node);
-	  if(node == 0) {
-		  printk("Aieee, could not find timer chip type\n");
-		  return;
-	  }
-  }
-
-  if(sparc_cpu_model == sun4c) {
-
-  /* Map the Timer chip, this is implemented in hardware inside
-   * the cache chip on the sun4c.
-   */
-  sparc_alloc_io ((void *) SUN4C_TIMER_PHYSADDR, (void *) TIMER_VADDR,
-		  sizeof (*SUN4C_TIMER_STRUCT), "timer", 0x0, 0x0);
-
-  /* Have the level 10 timer tick at 100HZ.  We don't touch the
-   * level 14 timer limit since we are letting the prom handle
-   * them until we have a real console driver so L1-A works.
-   */
-  SUN4C_TIMER_STRUCT->timer_limit10 = (((1000000/HZ) + 1) << 10);
-  master_l10_limit = &(SUN4C_TIMER_STRUCT->timer_limit10);
-
-  } else {
-	  int reg_count;
-	  struct linux_prom_registers cnt_regs[PROMREG_MAX];
-	  int obio_node, cnt_node;
-
-	  cnt_node = 0;
-	  if((obio_node =
-	      prom_searchsiblings (prom_getchild(prom_root_node), "obio")) == 0 ||
-	     (obio_node = prom_getchild (obio_node)) == 0 ||
-	     (cnt_node = prom_searchsiblings (obio_node, "counter")) == 0) {
-		  printk ("Cannot find /obio/counter node\n");
-		  prom_halt ();
-	  }
-	  reg_count = prom_getproperty(cnt_node, "reg",
-				       (void *) cnt_regs, sizeof(cnt_regs));
-
-	  reg_count = (reg_count/sizeof(struct linux_prom_registers));
-
-	  /* Apply the obio ranges to the timer registers. */
-	  prom_apply_obio_ranges(cnt_regs, reg_count);
-
-	  /* Map the per-cpu Counter registers. */
-	  sparc_alloc_io(cnt_regs[0].phys_addr, (void *) TIMER_VADDR,
-			 PAGE_SIZE*NCPUS, "counters_percpu", cnt_regs[0].which_io, 0x0);
-
-	  /* Map the system Counter register. */
-	  sparc_alloc_io(cnt_regs[reg_count-1].phys_addr,
-			 (void *) TIMER_VADDR+(NCPUS*PAGE_SIZE),
-			 cnt_regs[reg_count-1].reg_size,
-			 "counters_system", cnt_regs[reg_count-1].which_io, 0x0);
-
-
-	  sun4m_timers = (struct sun4m_timer_regs *) TIMER_VADDR;
-
-	  foo_limit = (volatile) sun4m_timers->l10_timer_limit;
-
-/*	  printk("Timer register dump:\n"); */
-#if 0
-	  printk("cpu0: l14limit %08x l14curcount %08x\n",
-		 sun4m_timers->cpu_timers[0].l14_timer_limit,
-		 sun4m_timers->cpu_timers[0].l14_cur_count);
-#endif
-#if 0
-	  printk("sys: l10limit %08x l10curcount %08x\n",
-		 sun4m_timers->l10_timer_limit,
-		 sun4m_timers->l10_cur_count);
-#endif
-
-	  /* Must set the master pointer first or we will lose badly. */
-	  master_l10_limit =
-		  &(((struct sun4m_timer_regs *)TIMER_VADDR)->l10_timer_limit);
+	/* This will basically traverse the node-tree of the prom to see
+	 * which timer chip is on this machine.
+	 */
 
-          ((struct sun4m_timer_regs *)TIMER_VADDR)->l10_timer_limit =
-		  (((1000000/HZ) + 1) << 10);   /* 0x9c4000 */
+	node = 0;
+	if(sparc_cpu_model == sun4) {
+		printk("probe_clock: No SUN4 Clock/Timer support yet...\n");
+		return;
+	}
+	if(sparc_cpu_model == sun4c) node=prom_getchild(prom_root_node);
+	else
+		if(sparc_cpu_model == sun4m)
+			node=prom_getchild(prom_searchsiblings(prom_getchild(prom_root_node), "obio"));
+	type = 0;
+	sp_clock_typ = MSTK_INVALID;
+	for(;;) {
+		prom_getstring(node, "model", node_str, sizeof(node_str));
+		if(strcmp(node_str, "mk48t02") == 0) {
+			sp_clock_typ = MSTK48T02;
+			if(prom_getproperty(node, "reg", (char *) clk_reg, sizeof(clk_reg)) == -1) {
+				printk("probe_clock: FAILED!\n");
+				halt();
+			}
+			prom_apply_obio_ranges(clk_reg, 1);
+			/* Map the clock register io area read-only */
+			mstk48t02_regs = (struct mostek48t02 *) 
+				sparc_alloc_io((void *) clk_reg[0].phys_addr,
+					       (void *) 0, sizeof(*mstk48t02_regs),
+					       "clock", 0x0, 0x1);
+			mstk48t08_regs = 0;  /* To catch weirdness */
+			break;
+		}
 
-	  /* We should be getting level 10 interrupts now. */
-  }
+		if(strcmp(node_str, "mk48t08") == 0) {
+			sp_clock_typ = MSTK48T08;
+			if(prom_getproperty(node, "reg", (char *) clk_reg,
+					    sizeof(clk_reg)) == -1) {
+				printk("probe_clock: FAILED!\n");
+				halt();
+			}
+			prom_apply_obio_ranges(clk_reg, 1);
+			/* Map the clock register io area read-only */
+			mstk48t08_regs = (struct mostek48t08 *)
+				sparc_alloc_io((void *) clk_reg[0].phys_addr,
+					       (void *) 0, sizeof(*mstk48t08_regs),
+					       "clock", 0x0, 0x1);
 
-  return;
+			mstk48t02_regs = &mstk48t08_regs->regs;
+			break;
+		}
+
+		node = prom_getsibling(node);
+		if(node == 0) {
+			printk("Aieee, could not find timer chip type\n");
+			return;
+		}
+	}
+
+	if(sparc_cpu_model == sun4c) {
+		/* Map the Timer chip, this is implemented in hardware inside
+		 * the cache chip on the sun4c.
+		 */
+		sparc_alloc_io ((void *) SUN4C_TIMER_PHYSADDR, (void *) TIMER_VADDR,
+				sizeof (*SUN4C_TIMER_STRUCT), "timer", 0x0, 0x0);
+
+		/* Have the level 10 timer tick at 100HZ.  We don't touch the
+		 * level 14 timer limit since we are letting the prom handle
+		 * them until we have a real console driver so L1-A works.
+		 */
+		SUN4C_TIMER_STRUCT->timer_limit10 = (((1000000/HZ) + 1) << 10);
+		master_l10_limit = &(SUN4C_TIMER_STRUCT->timer_limit10);
+		master_l10_counter = &(SUN4C_TIMER_STRUCT->cur_count10);
+	} else {
+		int reg_count;
+		struct linux_prom_registers cnt_regs[PROMREG_MAX];
+		int obio_node, cnt_node;
+
+		cnt_node = 0;
+		if((obio_node =
+		    prom_searchsiblings (prom_getchild(prom_root_node), "obio")) == 0 ||
+		   (obio_node = prom_getchild (obio_node)) == 0 ||
+		   (cnt_node = prom_searchsiblings (obio_node, "counter")) == 0) {
+			printk ("Cannot find /obio/counter node\n");
+			prom_halt ();
+		}
+		reg_count = prom_getproperty(cnt_node, "reg",
+					     (void *) cnt_regs, sizeof(cnt_regs));
+		reg_count = (reg_count/sizeof(struct linux_prom_registers));
+
+		/* Apply the obio ranges to the timer registers. */
+		prom_apply_obio_ranges(cnt_regs, reg_count);
+
+		/* Map the per-cpu Counter registers. */
+		sparc_alloc_io(cnt_regs[0].phys_addr, (void *) TIMER_VADDR,
+			       PAGE_SIZE*NCPUS, "counters_percpu",
+			       cnt_regs[0].which_io, 0x0);
+
+		/* Map the system Counter register. */
+		sparc_alloc_io(cnt_regs[reg_count-1].phys_addr,
+			       (void *) TIMER_VADDR+(NCPUS*PAGE_SIZE),
+			       cnt_regs[reg_count-1].reg_size,
+			       "counters_system", cnt_regs[reg_count-1].which_io, 0x0);
+		sun4m_timers = (struct sun4m_timer_regs *) TIMER_VADDR;
+
+		/* Avoid interrupt bombs... */
+		foo_limit = (volatile) sun4m_timers->l10_timer_limit;
+
+		/* Must set the master pointer first or we will lose badly. */
+		master_l10_limit =
+			&(((struct sun4m_timer_regs *)TIMER_VADDR)->l10_timer_limit);
+		master_l10_counter =
+			&(((struct sun4m_timer_regs *)TIMER_VADDR)->l10_cur_count);
+
+		((struct sun4m_timer_regs *)TIMER_VADDR)->l10_timer_limit =
+			(((1000000/HZ) + 1) << 10);
+	}
 }
 
 /* Probe and map in the Auxiliaary I/O register */
@@ -455,15 +445,13 @@
 	sparc_alloc_io(auxregs[0].phys_addr, (void *) AUXIO_VADDR,
 		       auxregs[0].reg_size, "auxilliaryIO", auxregs[0].which_io, 0x0);
 	printk("Mapped AUXIO at paddr %08lx vaddr %08lx\n",
-	       (unsigned long) auxregs[0].phys_addr,
-	       (unsigned long) AUXIO_VADDR);
-	return;
+		    (unsigned long) auxregs[0].phys_addr,
+		    (unsigned long) AUXIO_VADDR);
 }
 
 extern unsigned long probe_memory(void);
 extern struct sparc_phys_banks sp_banks[SPARC_PHYS_BANKS];
 unsigned int phys_bytes_of_ram, end_of_phys_memory;
-extern unsigned long probe_sbus(int, unsigned long);
 extern void probe_mbus(void);
 
 /* #define DEBUG_PROBE_DEVICES */
@@ -473,54 +461,46 @@
 unsigned long
 probe_devices(unsigned long mem_start)
 {
-  int nd, i, prom_node_cpu, thismid;
-  int cpu_nds[NCPUS];  /* One node for each cpu */
-  int cpu_ctr = 0;
-
-  prom_getstring(prom_root_node, "device_type", node_str, sizeof(node_str));
-  if(strcmp(node_str, "cpu") == 0) {
-    cpu_nds[0] = prom_root_node;
-    cpu_ctr++;
-  } else {
-    int scan;
-    scan = prom_getchild(prom_root_node);
-    nd = 0;
-    while((scan = prom_getsibling(scan)) != 0) {
-      prom_getstring(scan, "device_type", node_str, sizeof(node_str));
-      if(strcmp(node_str, "cpu") == 0) {
-	      cpu_nds[cpu_ctr] = scan;
-	      linux_cpus[cpu_ctr].prom_node = scan;
-	      prom_getproperty(scan, "mid", (char *) &thismid, sizeof(thismid));
-	      linux_cpus[cpu_ctr].mid = thismid;
-	      cpu_ctr++;
-      }
-    };
-    if(cpu_ctr == 0) {
-      printk("No CPU nodes found, cannot continue.\n");
-      /* Probably a sun4d or sun4e, Sun is trying to trick us ;-) */
-      halt();
-    }
-    printk("Found %d CPU prom device tree node(s).\n", cpu_ctr);
-  };
-  prom_node_cpu = cpu_nds[0];
-
-  linux_num_cpus = cpu_ctr;
-  for(i=0; i<cpu_ctr; i++) {
-	  prom_getstring(cpu_nds[i], "name", node_str, sizeof(node_str));
-	  printk("cpu%d: %s \n", i, node_str);
-  }
-
-/* Ok, here will go a call to each specific device probe. We can
- * call these now that we have the 'root' node and the child of
- * this node to send to the routines. ORDER IS IMPORTANT!
- */
+	int nd, i, prom_node_cpu, thismid;
+	int cpu_nds[NCPUS];  /* One node for each cpu */
+	int cpu_ctr = 0;
+
+	prom_getstring(prom_root_node, "device_type", node_str, sizeof(node_str));
+	if(strcmp(node_str, "cpu") == 0) {
+		cpu_nds[0] = prom_root_node;
+		cpu_ctr++;
+	} else {
+		int scan;
+		scan = prom_getchild(prom_root_node);
+		nd = 0;
+		while((scan = prom_getsibling(scan)) != 0) {
+			prom_getstring(scan, "device_type", node_str, sizeof(node_str));
+			if(strcmp(node_str, "cpu") == 0) {
+				cpu_nds[cpu_ctr] = scan;
+				linux_cpus[cpu_ctr].prom_node = scan;
+				prom_getproperty(scan, "mid", (char *) &thismid, sizeof(thismid));
+				linux_cpus[cpu_ctr].mid = thismid;
+				cpu_ctr++;
+			}
+		};
+		if(cpu_ctr == 0) {
+			printk("No CPU nodes found, cannot continue.\n");
+			/* Probably a sun4d or sun4e, Sun is trying to trick us ;-) */
+			halt();
+		}
+		printk("Found %d CPU prom device tree node(s).\n", cpu_ctr);
+	};
+	prom_node_cpu = cpu_nds[0];
 
-  probe_cpu();
-  probe_auxio();
-  if(sparc_cpu_model == sun4c) probe_vac();
-  if(sparc_cpu_model != sun4c) probe_mbus(); /* Are MBUS's relevant on sun4c's? */
+	linux_num_cpus = cpu_ctr;
+	for(i=0; i<cpu_ctr; i++) {
+		prom_getstring(cpu_nds[i], "name", node_str, sizeof(node_str));
+		printk("cpu%d: %s \n", i, node_str);
+	}
 
-  mem_start = probe_sbus(prom_getchild(prom_root_node), mem_start);
+	probe_cpu();
+	probe_auxio();
+	if(sparc_cpu_model != sun4c) probe_mbus();
 
-  return mem_start;
+	return mem_start;
 }
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen, slshen@lbl.gov
with Sam's (original) version of this