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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 62 - (hide annotations)
Sat Oct 13 12:51:47 2007 UTC (16 years, 7 months ago) by dpavlin
File MIME type: text/plain
File size: 3631 byte(s)
experiment a bit more how to implement OpenPIC
1 dpavlin 22 /*
2 dpavlin 34 * Copyright (C) 2005-2007 Anders Gavare. All rights reserved.
3 dpavlin 22 *
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 dpavlin 49 * $Id: machine_sandpoint.c,v 1.12 2007/06/15 18:08:10 debug Exp $
29 dpavlin 42 *
30 dpavlin 49 * COMMENT: Sandpoint PPC board implemented as D-Link DSM-G600
31 dpavlin 22 */
32    
33     #include <stdio.h>
34 dpavlin 34 #include <stdlib.h>
35 dpavlin 22 #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 dpavlin 49 MACHINE_SETUP(sandpoint)
48 dpavlin 22 {
49 dpavlin 34 struct pci_data *pci_data;
50 dpavlin 62 // char tmpstr[300];
51 dpavlin 34
52 dpavlin 22 /*
53 dpavlin 49 * NetBSD/sandpoint (http://www.netbsd.org/ports/sandpoint/)
54 dpavlin 22 */
55 dpavlin 49 machine->machine_name = "Sandpoint D-Link DSM-G600 PPC board";
56 dpavlin 34
57 dpavlin 46 /* Bogus default speed = 133 MHz */
58 dpavlin 22 if (machine->emulated_hz == 0)
59 dpavlin 46 machine->emulated_hz = 133000000;
60 dpavlin 22
61 dpavlin 49 /* Sandpoint PPC specific motherboard registers: */
62     device_add(machine, "sandpoint");
63 dpavlin 22
64 dpavlin 62 // 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 dpavlin 61 /* PCI and Interrupt controller (hostbus) */
74     pci_data = dev_mpc10x_init(machine, machine->memory, 0xfe000000,
75 dpavlin 62 64 /* isa irq base */, 128 /* pci irq: TODO */);
76 dpavlin 22
77 dpavlin 61 /* serial port */
78    
79     machine->main_console_handle = (size_t)
80     device_add(machine, "ns16550 addr=0xfc004500");
81 dpavlin 49 #if 0
82 dpavlin 61 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 dpavlin 22 /* RTC at "ext int 5" = "int 25" in IBM jargon, int
89     31-25 = 6 for the rest of us. */
90 dpavlin 53 snprintf(tmpstr, sizeof(tmpstr), "%s.cpu[%i].mpc10x.%i",
91 dpavlin 34 machine->path, machine->bootstrap_cpu, 31-25);
92     dev_mc146818_init(machine, machine->memory, 0x7ff00000, tmpstr,
93 dpavlin 49 MC146818_SANDPOINT, 1);
94 dpavlin 22
95 dpavlin 34 bus_pci_add(machine, pci_data, machine->memory, 0, 8, 0, "dec21143");
96 dpavlin 49 #endif
97 dpavlin 62
98 dpavlin 22 }
99    
100    
101 dpavlin 49 MACHINE_DEFAULT_CPU(sandpoint)
102 dpavlin 22 {
103 dpavlin 54 machine->cpu_name = strdup("PPC603e");
104 dpavlin 22 }
105    
106    
107 dpavlin 49 MACHINE_REGISTER(sandpoint)
108 dpavlin 22 {
109 dpavlin 49 MR_DEFAULT(sandpoint, "Sandpoint D-Link DSM-G600 PPC board", ARCH_PPC, MACHINE_SANDPOINT);
110 dpavlin 26
111 dpavlin 49 machine_entry_add_alias(me, "sandpoint");
112 dpavlin 22 }
113    

  ViewVC Help
Powered by ViewVC 1.1.26