/[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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 62 - (show annotations)
Sat Oct 13 12:51:47 2007 UTC (16 years, 6 months ago) by dpavlin
File MIME type: text/plain
File size: 3631 byte(s)
experiment a bit more how to implement OpenPIC
1 /*
2 * Copyright (C) 2005-2007 Anders Gavare. All rights reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are met:
6 *
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 * 3. The name of the author may not be used to endorse or promote products
13 * derived from this software without specific prior written permission.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25 * SUCH DAMAGE.
26 *
27 *
28 * $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>
34 #include <stdlib.h>
35 #include <string.h>
36
37 #include "bus_pci.h"
38 #include "cpu.h"
39 #include "device.h"
40 #include "devices.h"
41 #include "machine.h"
42 #include "memory.h"
43 #include "misc.h"
44
45
46
47 MACHINE_SETUP(sandpoint)
48 {
49 struct pci_data *pci_data;
50 // char tmpstr[300];
51
52 /*
53 * NetBSD/sandpoint (http://www.netbsd.org/ports/sandpoint/)
54 */
55 machine->machine_name = "Sandpoint D-Link DSM-G600 PPC board";
56
57 /* Bogus default speed = 133 MHz */
58 if (machine->emulated_hz == 0)
59 machine->emulated_hz = 133000000;
60
61 /* Sandpoint PPC specific motherboard registers: */
62 device_add(machine, "sandpoint");
63
64 // OpenPIC FIXME
65 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
89 31-25 = 6 for the rest of us. */
90 snprintf(tmpstr, sizeof(tmpstr), "%s.cpu[%i].mpc10x.%i",
91 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
98 }
99
100
101 MACHINE_DEFAULT_CPU(sandpoint)
102 {
103 machine->cpu_name = strdup("PPC603e");
104 }
105
106
107 MACHINE_REGISTER(sandpoint)
108 {
109 MR_DEFAULT(sandpoint, "Sandpoint D-Link DSM-G600 PPC board", ARCH_PPC, MACHINE_SANDPOINT);
110
111 machine_entry_add_alias(me, "sandpoint");
112 }
113

  ViewVC Help
Powered by ViewVC 1.1.26