/[gxemul]/trunk/src/machines/machine_sandpoint.c
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/src/machines/machine_sandpoint.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

trunk/src/machines/machine_pmppc.c revision 22 by dpavlin, Mon Oct 8 16:19:37 2007 UTC trunk/src/machines/machine_sandpoint.c revision 62 by dpavlin, Sat Oct 13 12:51:47 2007 UTC
# Line 1  Line 1 
1  /*  /*
2   *  Copyright (C) 2005-2006  Anders Gavare.  All rights reserved.   *  Copyright (C) 2005-2007  Anders Gavare.  All rights reserved.
3   *   *
4   *  Redistribution and use in source and binary forms, with or without   *  Redistribution and use in source and binary forms, with or without
5   *  modification, are permitted provided that the following conditions are met:   *  modification, are permitted provided that the following conditions are met:
# Line 25  Line 25 
25   *  SUCH DAMAGE.   *  SUCH DAMAGE.
26   *     *  
27   *   *
28   *  $Id: machine_pmppc.c,v 1.2 2006/01/11 05:56:02 debug Exp $   *  $Id: machine_sandpoint.c,v 1.12 2007/06/15 18:08:10 debug Exp $
29     *
30     *  COMMENT: Sandpoint PPC board implemented as D-Link DSM-G600
31   */   */
32    
33  #include <stdio.h>  #include <stdio.h>
34    #include <stdlib.h>
35  #include <string.h>  #include <string.h>
36    
37  #include "bus_pci.h"  #include "bus_pci.h"
# Line 36  Line 39 
39  #include "device.h"  #include "device.h"
40  #include "devices.h"  #include "devices.h"
41  #include "machine.h"  #include "machine.h"
 #include "machine_interrupts.h"  
42  #include "memory.h"  #include "memory.h"
43  #include "misc.h"  #include "misc.h"
44    
45    
46    
47  MACHINE_SETUP(pmppc)  MACHINE_SETUP(sandpoint)
48  {  {
49            struct pci_data *pci_data;
50    //      char tmpstr[300];
51    
52          /*          /*
53           *  NetBSD/pmppc (http://www.netbsd.org/Ports/pmppc/)           *  NetBSD/sandpoint (http://www.netbsd.org/ports/sandpoint/)
54           */           */
55          machine->machine_name = "Artesyn's PM/PPC board";          machine->machine_name = "Sandpoint D-Link DSM-G600 PPC board";
56    
57            /*  Bogus default speed = 133 MHz  */
58          if (machine->emulated_hz == 0)          if (machine->emulated_hz == 0)
59                  machine->emulated_hz = 10000000;                  machine->emulated_hz = 133000000;
60    
61          dev_pmppc_init(machine->memory);          /*  Sandpoint PPC specific motherboard registers:  */
62            device_add(machine, "sandpoint");
63    
64          machine->md_int.cpc700_data = dev_cpc700_init(machine, machine->memory);          // OpenPIC FIXME
65          machine->md_interrupt = cpc700_interrupt;          device_add(machine, "gc addr=0xfc041000");
66    
67    #if 0
68            snprintf(tmpstr, sizeof(tmpstr), "prep irq=%s.cpu[%i]",
69                machine->path, machine->bootstrap_cpu);
70            device_add(machine, tmpstr);
71    #endif
72    
73            /*  PCI and Interrupt controller (hostbus)  */
74            pci_data = dev_mpc10x_init(machine, machine->memory, 0xfe000000,
75                64 /*  isa irq base */, 128 /*  pci irq: TODO */);
76    
77            /*  serial port  */
78    
79            machine->main_console_handle = (size_t)
80                    device_add(machine, "ns16550 addr=0xfc004500");
81    #if 0
82            snprintf(tmp, sizeof(tmp), "ns16550 irq=%s.mpc10x.%i addr=0x%llx "
83                "name2=tty1", devinit->interrupt_path, 31 - MPC_IB_UART_1,
84                (long long)fc004600);
85            device_add(devinit->machine, tmp);
86    #endif
87    #if 0
88          /*  RTC at "ext int 5" = "int 25" in IBM jargon, int          /*  RTC at "ext int 5" = "int 25" in IBM jargon, int
89              31-25 = 6 for the rest of us.  */              31-25 = 6 for the rest of us.  */
90          dev_mc146818_init(machine, machine->memory, 0x7ff00000, 31-25,          snprintf(tmpstr, sizeof(tmpstr), "%s.cpu[%i].mpc10x.%i",
91              MC146818_PMPPC, 1);              machine->path, machine->bootstrap_cpu, 31-25);
92            dev_mc146818_init(machine, machine->memory, 0x7ff00000, tmpstr,
93                MC146818_SANDPOINT, 1);
94    
95            bus_pci_add(machine, pci_data, machine->memory, 0, 8, 0, "dec21143");
96    #endif
97    
         bus_pci_add(machine, machine->md_int.cpc700_data->pci_data,  
             machine->memory, 0, 8, 0, "dec21143");  
98  }  }
99    
100    
101  MACHINE_DEFAULT_CPU(pmppc)  MACHINE_DEFAULT_CPU(sandpoint)
102  {  {
103          machine->cpu_name = strdup("PPC750");          machine->cpu_name = strdup("PPC603e");
104  }  }
105    
106    
107  MACHINE_REGISTER(pmppc)  MACHINE_REGISTER(sandpoint)
108  {  {
109          MR_DEFAULT(pmppc, "Artesyn's PM/PPC board", ARCH_PPC,          MR_DEFAULT(sandpoint, "Sandpoint D-Link DSM-G600 PPC board", ARCH_PPC, MACHINE_SANDPOINT);
110              MACHINE_PMPPC, 1, 0);  
111          me->aliases[0] = "pmppc";          machine_entry_add_alias(me, "sandpoint");
         machine_entry_add(me, ARCH_PPC);  
112  }  }
113    

Legend:
Removed from v.22  
changed lines
  Added in v.62

  ViewVC Help
Powered by ViewVC 1.1.26