blob: 982c3fe73c4a45b45eeeff08e8d8446a47151c16 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * linux/arch/m68k/mac/config.c
3 *
4 * This file is subject to the terms and conditions of the GNU General Public
5 * License. See the file COPYING in the main directory of this archive
6 * for more details.
7 */
8
9/*
10 * Miscellaneous linux stuff
11 */
12
Linus Torvalds1da177e2005-04-16 15:20:36 -070013#include <linux/module.h>
14#include <linux/types.h>
15#include <linux/mm.h>
16#include <linux/tty.h>
17#include <linux/console.h>
18#include <linux/interrupt.h>
19/* keyb */
20#include <linux/random.h>
21#include <linux/delay.h>
22/* keyb */
23#include <linux/init.h>
24#include <linux/vt_kern.h>
Laurent Vivier8852ecd2008-11-15 16:10:10 +010025#include <linux/platform_device.h>
Finn Thain18814ee2009-11-17 20:03:05 +110026#include <linux/adb.h>
27#include <linux/cuda.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070028
Linus Torvalds1da177e2005-04-16 15:20:36 -070029#include <asm/setup.h>
30#include <asm/bootinfo.h>
Geert Uytterhoeven4c3c5222013-10-02 11:37:33 +020031#include <asm/bootinfo-mac.h>
Geert Uytterhoevenabe48102013-10-04 11:41:24 +020032#include <asm/byteorder.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070033
Linus Torvalds1da177e2005-04-16 15:20:36 -070034#include <asm/io.h>
35#include <asm/irq.h>
36#include <asm/pgtable.h>
37#include <asm/rtc.h>
38#include <asm/machdep.h>
39
40#include <asm/macintosh.h>
41#include <asm/macints.h>
42#include <asm/machw.h>
43
44#include <asm/mac_iop.h>
45#include <asm/mac_via.h>
46#include <asm/mac_oss.h>
47#include <asm/mac_psc.h>
48
49/* Mac bootinfo struct */
Linus Torvalds1da177e2005-04-16 15:20:36 -070050struct mac_booter_data mac_bi_data;
Linus Torvalds1da177e2005-04-16 15:20:36 -070051
Linus Torvalds1da177e2005-04-16 15:20:36 -070052/* The phys. video addr. - might be bogus on some machines */
Adrian Bunk8dfbdf42008-07-17 21:16:25 +020053static unsigned long mac_orig_videoaddr;
Linus Torvalds1da177e2005-04-16 15:20:36 -070054
55/* Mac specific timer functions */
Stephen Warrenc8d5ba12012-11-08 11:34:55 -070056extern u32 mac_gettimeoffset(void);
Roman Zippel6ff58012007-05-01 22:32:43 +020057extern int mac_hwclk(int, struct rtc_time *);
58extern int mac_set_clock_mmss(unsigned long);
Linus Torvalds1da177e2005-04-16 15:20:36 -070059extern void iop_preinit(void);
60extern void iop_init(void);
61extern void via_init(void);
David Howells40220c12006-10-09 12:19:47 +010062extern void via_init_clock(irq_handler_t func);
Linus Torvalds1da177e2005-04-16 15:20:36 -070063extern void via_flush_cache(void);
64extern void oss_init(void);
65extern void psc_init(void);
66extern void baboon_init(void);
67
68extern void mac_mksound(unsigned int, unsigned int);
69
Linus Torvalds1da177e2005-04-16 15:20:36 -070070static void mac_get_model(char *str);
Adrian Bunk8dfbdf42008-07-17 21:16:25 +020071static void mac_identify(void);
72static void mac_report_hardware(void);
Linus Torvalds1da177e2005-04-16 15:20:36 -070073
Finn Thain93edd022011-10-24 01:11:12 +110074#ifdef CONFIG_EARLY_PRINTK
75asmlinkage void __init mac_early_print(const char *s, unsigned n);
76
77static void __init mac_early_cons_write(struct console *con,
78 const char *s, unsigned n)
79{
80 mac_early_print(s, n);
81}
82
83static struct console __initdata mac_early_cons = {
84 .name = "early",
85 .write = mac_early_cons_write,
86 .flags = CON_PRINTBUFFER | CON_BOOT,
87 .index = -1
88};
89
90int __init mac_unregister_early_cons(void)
91{
92 /* mac_early_print can't be used after init sections are discarded */
93 return unregister_console(&mac_early_cons);
94}
95
96late_initcall(mac_unregister_early_cons);
97#endif
98
Al Viro66a3f822007-07-20 04:33:28 +010099static void __init mac_sched_init(irq_handler_t vector)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700100{
101 via_init_clock(vector);
102}
103
Linus Torvalds1da177e2005-04-16 15:20:36 -0700104/*
105 * Parse a Macintosh-specific record in the bootinfo
106 */
107
108int __init mac_parse_bootinfo(const struct bi_record *record)
109{
Roman Zippel6ff58012007-05-01 22:32:43 +0200110 int unknown = 0;
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200111 const void *data = record->data;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700112
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200113 switch (be16_to_cpu(record->tag)) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700114 case BI_MAC_MODEL:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200115 mac_bi_data.id = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200116 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700117 case BI_MAC_VADDR:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200118 mac_bi_data.videoaddr = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200119 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700120 case BI_MAC_VDEPTH:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200121 mac_bi_data.videodepth = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200122 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700123 case BI_MAC_VROW:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200124 mac_bi_data.videorow = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200125 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700126 case BI_MAC_VDIM:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200127 mac_bi_data.dimensions = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200128 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700129 case BI_MAC_VLOGICAL:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200130 mac_orig_videoaddr = be32_to_cpup(data);
131 mac_bi_data.videological =
132 VIDEOMEMBASE + (mac_orig_videoaddr & ~VIDEOMEMMASK);
Roman Zippel6ff58012007-05-01 22:32:43 +0200133 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700134 case BI_MAC_SCCBASE:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200135 mac_bi_data.sccbase = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200136 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700137 case BI_MAC_BTIME:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200138 mac_bi_data.boottime = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200139 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700140 case BI_MAC_GMTBIAS:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200141 mac_bi_data.gmtbias = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200142 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700143 case BI_MAC_MEMSIZE:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200144 mac_bi_data.memsize = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200145 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700146 case BI_MAC_CPUID:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200147 mac_bi_data.cpuid = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200148 break;
149 case BI_MAC_ROMBASE:
Geert Uytterhoevenabe48102013-10-04 11:41:24 +0200150 mac_bi_data.rombase = be32_to_cpup(data);
Roman Zippel6ff58012007-05-01 22:32:43 +0200151 break;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700152 default:
Roman Zippel6ff58012007-05-01 22:32:43 +0200153 unknown = 1;
154 break;
155 }
156 return unknown;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700157}
158
159/*
160 * Flip into 24bit mode for an instant - flushes the L2 cache card. We
161 * have to disable interrupts for this. Our IRQ handlers will crap
162 * themselves if they take an IRQ in 24bit mode!
163 */
164
165static void mac_cache_card_flush(int writeback)
166{
167 unsigned long flags;
Roman Zippel6ff58012007-05-01 22:32:43 +0200168
Linus Torvalds1da177e2005-04-16 15:20:36 -0700169 local_irq_save(flags);
170 via_flush_cache();
171 local_irq_restore(flags);
172}
173
174void __init config_mac(void)
175{
Roman Zippel6ff58012007-05-01 22:32:43 +0200176 if (!MACH_IS_MAC)
Frans Popb9b0d8b2010-02-06 18:47:11 +0100177 printk(KERN_ERR "ERROR: no Mac, but config_mac() called!!\n");
Linus Torvalds1da177e2005-04-16 15:20:36 -0700178
Roman Zippel6ff58012007-05-01 22:32:43 +0200179 mach_sched_init = mac_sched_init;
180 mach_init_IRQ = mac_init_IRQ;
181 mach_get_model = mac_get_model;
Stephen Warrenc8d5ba12012-11-08 11:34:55 -0700182 arch_gettimeoffset = mac_gettimeoffset;
Roman Zippel6ff58012007-05-01 22:32:43 +0200183 mach_hwclk = mac_hwclk;
Roman Zippel6ff58012007-05-01 22:32:43 +0200184 mach_set_clock_mmss = mac_set_clock_mmss;
185 mach_reset = mac_reset;
186 mach_halt = mac_poweroff;
187 mach_power_off = mac_poweroff;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700188 mach_max_dma_address = 0xffffffff;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700189#if defined(CONFIG_INPUT_M68K_BEEP) || defined(CONFIG_INPUT_M68K_BEEP_MODULE)
Roman Zippel6ff58012007-05-01 22:32:43 +0200190 mach_beep = mac_mksound;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700191#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -0700192
Finn Thain93edd022011-10-24 01:11:12 +1100193#ifdef CONFIG_EARLY_PRINTK
194 register_console(&mac_early_cons);
195#endif
196
Linus Torvalds1da177e2005-04-16 15:20:36 -0700197 /*
198 * Determine hardware present
199 */
200
201 mac_identify();
202 mac_report_hardware();
203
Roman Zippel6ff58012007-05-01 22:32:43 +0200204 /*
205 * AFAIK only the IIci takes a cache card. The IIfx has onboard
206 * cache ... someone needs to figure out how to tell if it's on or
207 * not.
208 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700209
210 if (macintosh_config->ident == MAC_MODEL_IICI
Roman Zippel6ff58012007-05-01 22:32:43 +0200211 || macintosh_config->ident == MAC_MODEL_IIFX)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700212 mach_l2_flush = mac_cache_card_flush;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700213}
214
215
216/*
Finn Thain53aac0a2009-11-04 00:39:09 +1100217 * Macintosh Table: hardcoded model configuration data.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700218 *
Finn Thain53aac0a2009-11-04 00:39:09 +1100219 * Much of this was defined by Alan, based on who knows what docs.
220 * I've added a lot more, and some of that was pure guesswork based
221 * on hardware pages present on the Mac web site. Possibly wildly
222 * inaccurate, so look here if a new Mac model won't run. Example: if
223 * a Mac crashes immediately after the VIA1 registers have been dumped
224 * to the screen, it probably died attempting to read DirB on a RBV.
Finn Thain608e287b02011-10-24 01:11:22 +1100225 * Meaning it should have MAC_VIA_IICI here :-)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700226 */
227
228struct mac_model *macintosh_config;
229EXPORT_SYMBOL(macintosh_config);
230
Roman Zippel6ff58012007-05-01 22:32:43 +0200231static struct mac_model mac_data_table[] = {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700232 /*
Finn Thain53aac0a2009-11-04 00:39:09 +1100233 * We'll pretend to be a Macintosh II, that's pretty safe.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700234 */
235
236 {
237 .ident = MAC_MODEL_II,
238 .name = "Unknown",
239 .adb_type = MAC_ADB_II,
240 .via_type = MAC_VIA_II,
241 .scsi_type = MAC_SCSI_OLD,
242 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100243 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100244 .floppy_type = MAC_FLOPPY_IWM,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700245 },
246
247 /*
Finn Thain53aac0a2009-11-04 00:39:09 +1100248 * Original Mac II hardware
Linus Torvalds1da177e2005-04-16 15:20:36 -0700249 */
250
251 {
252 .ident = MAC_MODEL_II,
253 .name = "II",
254 .adb_type = MAC_ADB_II,
255 .via_type = MAC_VIA_II,
256 .scsi_type = MAC_SCSI_OLD,
257 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100258 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100259 .floppy_type = MAC_FLOPPY_IWM,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700260 }, {
261 .ident = MAC_MODEL_IIX,
262 .name = "IIx",
263 .adb_type = MAC_ADB_II,
264 .via_type = MAC_VIA_II,
265 .scsi_type = MAC_SCSI_OLD,
266 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100267 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100268 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700269 }, {
270 .ident = MAC_MODEL_IICX,
271 .name = "IIcx",
272 .adb_type = MAC_ADB_II,
273 .via_type = MAC_VIA_II,
274 .scsi_type = MAC_SCSI_OLD,
275 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100276 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100277 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700278 }, {
279 .ident = MAC_MODEL_SE30,
280 .name = "SE/30",
281 .adb_type = MAC_ADB_II,
282 .via_type = MAC_VIA_II,
283 .scsi_type = MAC_SCSI_OLD,
284 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100285 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100286 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700287 },
288
289 /*
Finn Thain53aac0a2009-11-04 00:39:09 +1100290 * Weirdified Mac II hardware - all subtly different. Gee thanks
291 * Apple. All these boxes seem to have VIA2 in a different place to
292 * the Mac II (+1A000 rather than +4000)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700293 * CSA: see http://developer.apple.com/technotes/hw/hw_09.html
294 */
295
296 {
297 .ident = MAC_MODEL_IICI,
298 .name = "IIci",
299 .adb_type = MAC_ADB_II,
Finn Thain608e287b02011-10-24 01:11:22 +1100300 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700301 .scsi_type = MAC_SCSI_OLD,
302 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100303 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100304 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700305 }, {
306 .ident = MAC_MODEL_IIFX,
307 .name = "IIfx",
308 .adb_type = MAC_ADB_IOP,
Finn Thain608e287b02011-10-24 01:11:22 +1100309 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700310 .scsi_type = MAC_SCSI_OLD,
311 .scc_type = MAC_SCC_IOP,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100312 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100313 .floppy_type = MAC_FLOPPY_SWIM_IOP,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700314 }, {
315 .ident = MAC_MODEL_IISI,
316 .name = "IIsi",
317 .adb_type = MAC_ADB_IISI,
Finn Thain608e287b02011-10-24 01:11:22 +1100318 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700319 .scsi_type = MAC_SCSI_OLD,
320 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100321 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100322 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700323 }, {
324 .ident = MAC_MODEL_IIVI,
325 .name = "IIvi",
326 .adb_type = MAC_ADB_IISI,
Finn Thain608e287b02011-10-24 01:11:22 +1100327 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700328 .scsi_type = MAC_SCSI_OLD,
329 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100330 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100331 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700332 }, {
333 .ident = MAC_MODEL_IIVX,
334 .name = "IIvx",
335 .adb_type = MAC_ADB_IISI,
Finn Thain608e287b02011-10-24 01:11:22 +1100336 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700337 .scsi_type = MAC_SCSI_OLD,
338 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100339 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100340 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700341 },
342
343 /*
Finn Thain53aac0a2009-11-04 00:39:09 +1100344 * Classic models (guessing: similar to SE/30? Nope, similar to LC...)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700345 */
346
347 {
348 .ident = MAC_MODEL_CLII,
349 .name = "Classic II",
350 .adb_type = MAC_ADB_IISI,
Finn Thain608e287b02011-10-24 01:11:22 +1100351 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700352 .scsi_type = MAC_SCSI_OLD,
353 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100354 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100355 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700356 }, {
357 .ident = MAC_MODEL_CCL,
358 .name = "Color Classic",
359 .adb_type = MAC_ADB_CUDA,
Finn Thain608e287b02011-10-24 01:11:22 +1100360 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700361 .scsi_type = MAC_SCSI_OLD,
362 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100363 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100364 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Finn Thain1b460102010-05-29 03:27:18 +1000365 }, {
366 .ident = MAC_MODEL_CCLII,
367 .name = "Color Classic II",
368 .adb_type = MAC_ADB_CUDA,
Finn Thain608e287b02011-10-24 01:11:22 +1100369 .via_type = MAC_VIA_IICI,
Finn Thain1b460102010-05-29 03:27:18 +1000370 .scsi_type = MAC_SCSI_OLD,
371 .scc_type = MAC_SCC_II,
372 .nubus_type = MAC_NUBUS,
373 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100374 },
Linus Torvalds1da177e2005-04-16 15:20:36 -0700375
376 /*
Finn Thain53aac0a2009-11-04 00:39:09 +1100377 * Some Mac LC machines. Basically the same as the IIci, ADB like IIsi
Linus Torvalds1da177e2005-04-16 15:20:36 -0700378 */
379
380 {
381 .ident = MAC_MODEL_LC,
382 .name = "LC",
383 .adb_type = MAC_ADB_IISI,
Finn Thain608e287b02011-10-24 01:11:22 +1100384 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700385 .scsi_type = MAC_SCSI_OLD,
386 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100387 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100388 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700389 }, {
390 .ident = MAC_MODEL_LCII,
391 .name = "LC II",
392 .adb_type = MAC_ADB_IISI,
Finn Thain608e287b02011-10-24 01:11:22 +1100393 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700394 .scsi_type = MAC_SCSI_OLD,
395 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100396 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100397 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700398 }, {
399 .ident = MAC_MODEL_LCIII,
400 .name = "LC III",
401 .adb_type = MAC_ADB_IISI,
Finn Thain608e287b02011-10-24 01:11:22 +1100402 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700403 .scsi_type = MAC_SCSI_OLD,
404 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100405 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100406 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700407 },
408
409 /*
Finn Thain53aac0a2009-11-04 00:39:09 +1100410 * Quadra. Video is at 0xF9000000, via is like a MacII. We label it
411 * differently as some of the stuff connected to VIA2 seems different.
412 * Better SCSI chip and onboard ethernet using a NatSemi SONIC except
413 * the 660AV and 840AV which use an AMD 79C940 (MACE).
414 * The 700, 900 and 950 have some I/O chips in the wrong place to
415 * confuse us. The 840AV has a SCSI location of its own (same as
416 * the 660AV).
Linus Torvalds1da177e2005-04-16 15:20:36 -0700417 */
418
419 {
420 .ident = MAC_MODEL_Q605,
421 .name = "Quadra 605",
422 .adb_type = MAC_ADB_CUDA,
423 .via_type = MAC_VIA_QUADRA,
424 .scsi_type = MAC_SCSI_QUADRA,
425 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100426 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100427 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700428 }, {
429 .ident = MAC_MODEL_Q605_ACC,
430 .name = "Quadra 605",
431 .adb_type = MAC_ADB_CUDA,
432 .via_type = MAC_VIA_QUADRA,
433 .scsi_type = MAC_SCSI_QUADRA,
434 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100435 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100436 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700437 }, {
438 .ident = MAC_MODEL_Q610,
439 .name = "Quadra 610",
440 .adb_type = MAC_ADB_II,
441 .via_type = MAC_VIA_QUADRA,
442 .scsi_type = MAC_SCSI_QUADRA,
443 .scc_type = MAC_SCC_QUADRA,
444 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100445 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100446 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700447 }, {
448 .ident = MAC_MODEL_Q630,
449 .name = "Quadra 630",
450 .adb_type = MAC_ADB_CUDA,
451 .via_type = MAC_VIA_QUADRA,
452 .scsi_type = MAC_SCSI_QUADRA,
453 .ide_type = MAC_IDE_QUADRA,
454 .scc_type = MAC_SCC_QUADRA,
455 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100456 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100457 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700458 }, {
459 .ident = MAC_MODEL_Q650,
460 .name = "Quadra 650",
461 .adb_type = MAC_ADB_II,
462 .via_type = MAC_VIA_QUADRA,
463 .scsi_type = MAC_SCSI_QUADRA,
464 .scc_type = MAC_SCC_QUADRA,
465 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100466 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100467 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700468 },
Finn Thain53aac0a2009-11-04 00:39:09 +1100469 /* The Q700 does have a NS Sonic */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700470 {
471 .ident = MAC_MODEL_Q700,
472 .name = "Quadra 700",
473 .adb_type = MAC_ADB_II,
474 .via_type = MAC_VIA_QUADRA,
475 .scsi_type = MAC_SCSI_QUADRA2,
476 .scc_type = MAC_SCC_QUADRA,
477 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100478 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100479 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700480 }, {
481 .ident = MAC_MODEL_Q800,
482 .name = "Quadra 800",
483 .adb_type = MAC_ADB_II,
484 .via_type = MAC_VIA_QUADRA,
485 .scsi_type = MAC_SCSI_QUADRA,
486 .scc_type = MAC_SCC_QUADRA,
487 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100488 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100489 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700490 }, {
491 .ident = MAC_MODEL_Q840,
492 .name = "Quadra 840AV",
493 .adb_type = MAC_ADB_CUDA,
494 .via_type = MAC_VIA_QUADRA,
495 .scsi_type = MAC_SCSI_QUADRA3,
496 .scc_type = MAC_SCC_PSC,
497 .ether_type = MAC_ETHER_MACE,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100498 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100499 .floppy_type = MAC_FLOPPY_AV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700500 }, {
501 .ident = MAC_MODEL_Q900,
502 .name = "Quadra 900",
503 .adb_type = MAC_ADB_IOP,
504 .via_type = MAC_VIA_QUADRA,
505 .scsi_type = MAC_SCSI_QUADRA2,
506 .scc_type = MAC_SCC_IOP,
507 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100508 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100509 .floppy_type = MAC_FLOPPY_SWIM_IOP,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700510 }, {
511 .ident = MAC_MODEL_Q950,
512 .name = "Quadra 950",
513 .adb_type = MAC_ADB_IOP,
514 .via_type = MAC_VIA_QUADRA,
515 .scsi_type = MAC_SCSI_QUADRA2,
516 .scc_type = MAC_SCC_IOP,
517 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100518 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100519 .floppy_type = MAC_FLOPPY_SWIM_IOP,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700520 },
521
522 /*
Finn Thain53aac0a2009-11-04 00:39:09 +1100523 * Performa - more LC type machines
Linus Torvalds1da177e2005-04-16 15:20:36 -0700524 */
525
526 {
527 .ident = MAC_MODEL_P460,
Finn Thain53aac0a2009-11-04 00:39:09 +1100528 .name = "Performa 460",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700529 .adb_type = MAC_ADB_IISI,
Finn Thain608e287b02011-10-24 01:11:22 +1100530 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700531 .scsi_type = MAC_SCSI_OLD,
532 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100533 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100534 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700535 }, {
536 .ident = MAC_MODEL_P475,
Finn Thain53aac0a2009-11-04 00:39:09 +1100537 .name = "Performa 475",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700538 .adb_type = MAC_ADB_CUDA,
539 .via_type = MAC_VIA_QUADRA,
540 .scsi_type = MAC_SCSI_QUADRA,
541 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100542 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100543 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700544 }, {
545 .ident = MAC_MODEL_P475F,
Finn Thain53aac0a2009-11-04 00:39:09 +1100546 .name = "Performa 475",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700547 .adb_type = MAC_ADB_CUDA,
548 .via_type = MAC_VIA_QUADRA,
549 .scsi_type = MAC_SCSI_QUADRA,
550 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100551 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100552 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700553 }, {
554 .ident = MAC_MODEL_P520,
Finn Thain53aac0a2009-11-04 00:39:09 +1100555 .name = "Performa 520",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700556 .adb_type = MAC_ADB_CUDA,
Finn Thain608e287b02011-10-24 01:11:22 +1100557 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700558 .scsi_type = MAC_SCSI_OLD,
559 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100560 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100561 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700562 }, {
563 .ident = MAC_MODEL_P550,
Finn Thain53aac0a2009-11-04 00:39:09 +1100564 .name = "Performa 550",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700565 .adb_type = MAC_ADB_CUDA,
Finn Thain608e287b02011-10-24 01:11:22 +1100566 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700567 .scsi_type = MAC_SCSI_OLD,
568 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100569 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100570 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700571 },
Finn Thain53aac0a2009-11-04 00:39:09 +1100572 /* These have the comm slot, and therefore possibly SONIC ethernet */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700573 {
574 .ident = MAC_MODEL_P575,
575 .name = "Performa 575",
576 .adb_type = MAC_ADB_CUDA,
577 .via_type = MAC_VIA_QUADRA,
578 .scsi_type = MAC_SCSI_QUADRA,
579 .scc_type = MAC_SCC_II,
580 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100581 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100582 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700583 }, {
584 .ident = MAC_MODEL_P588,
585 .name = "Performa 588",
586 .adb_type = MAC_ADB_CUDA,
587 .via_type = MAC_VIA_QUADRA,
588 .scsi_type = MAC_SCSI_QUADRA,
589 .ide_type = MAC_IDE_QUADRA,
590 .scc_type = MAC_SCC_II,
591 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100592 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100593 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700594 }, {
595 .ident = MAC_MODEL_TV,
596 .name = "TV",
597 .adb_type = MAC_ADB_CUDA,
Finn Thain608e287b02011-10-24 01:11:22 +1100598 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700599 .scsi_type = MAC_SCSI_OLD,
600 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100601 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100602 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700603 }, {
604 .ident = MAC_MODEL_P600,
605 .name = "Performa 600",
606 .adb_type = MAC_ADB_IISI,
Finn Thain608e287b02011-10-24 01:11:22 +1100607 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700608 .scsi_type = MAC_SCSI_OLD,
609 .scc_type = MAC_SCC_II,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100610 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100611 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700612 },
613
614 /*
Finn Thain53aac0a2009-11-04 00:39:09 +1100615 * Centris - just guessing again; maybe like Quadra.
616 * The C610 may or may not have SONIC. We probe to make sure.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700617 */
618
Linus Torvalds1da177e2005-04-16 15:20:36 -0700619 {
620 .ident = MAC_MODEL_C610,
621 .name = "Centris 610",
622 .adb_type = MAC_ADB_II,
623 .via_type = MAC_VIA_QUADRA,
624 .scsi_type = MAC_SCSI_QUADRA,
625 .scc_type = MAC_SCC_QUADRA,
626 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100627 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100628 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700629 }, {
630 .ident = MAC_MODEL_C650,
631 .name = "Centris 650",
632 .adb_type = MAC_ADB_II,
633 .via_type = MAC_VIA_QUADRA,
634 .scsi_type = MAC_SCSI_QUADRA,
635 .scc_type = MAC_SCC_QUADRA,
636 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100637 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100638 .floppy_type = MAC_FLOPPY_SWIM_ADDR1,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700639 }, {
640 .ident = MAC_MODEL_C660,
641 .name = "Centris 660AV",
642 .adb_type = MAC_ADB_CUDA,
643 .via_type = MAC_VIA_QUADRA,
644 .scsi_type = MAC_SCSI_QUADRA3,
645 .scc_type = MAC_SCC_PSC,
646 .ether_type = MAC_ETHER_MACE,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100647 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100648 .floppy_type = MAC_FLOPPY_AV,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700649 },
650
651 /*
652 * The PowerBooks all the same "Combo" custom IC for SCSI and SCC
653 * and a PMU (in two variations?) for ADB. Most of them use the
654 * Quadra-style VIAs. A few models also have IDE from hell.
655 */
656
657 {
658 .ident = MAC_MODEL_PB140,
659 .name = "PowerBook 140",
660 .adb_type = MAC_ADB_PB1,
661 .via_type = MAC_VIA_QUADRA,
662 .scsi_type = MAC_SCSI_OLD,
663 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100664 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100665 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700666 }, {
667 .ident = MAC_MODEL_PB145,
668 .name = "PowerBook 145",
669 .adb_type = MAC_ADB_PB1,
670 .via_type = MAC_VIA_QUADRA,
671 .scsi_type = MAC_SCSI_OLD,
672 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100673 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100674 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700675 }, {
676 .ident = MAC_MODEL_PB150,
677 .name = "PowerBook 150",
Finn Thain4107c452011-10-24 01:11:20 +1100678 .adb_type = MAC_ADB_PB2,
Finn Thain608e287b02011-10-24 01:11:22 +1100679 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700680 .scsi_type = MAC_SCSI_OLD,
681 .ide_type = MAC_IDE_PB,
682 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100683 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100684 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700685 }, {
686 .ident = MAC_MODEL_PB160,
687 .name = "PowerBook 160",
688 .adb_type = MAC_ADB_PB1,
689 .via_type = MAC_VIA_QUADRA,
690 .scsi_type = MAC_SCSI_OLD,
691 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100692 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100693 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700694 }, {
695 .ident = MAC_MODEL_PB165,
696 .name = "PowerBook 165",
697 .adb_type = MAC_ADB_PB1,
698 .via_type = MAC_VIA_QUADRA,
699 .scsi_type = MAC_SCSI_OLD,
700 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100701 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100702 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700703 }, {
704 .ident = MAC_MODEL_PB165C,
705 .name = "PowerBook 165c",
706 .adb_type = MAC_ADB_PB1,
707 .via_type = MAC_VIA_QUADRA,
708 .scsi_type = MAC_SCSI_OLD,
709 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100710 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100711 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700712 }, {
713 .ident = MAC_MODEL_PB170,
714 .name = "PowerBook 170",
715 .adb_type = MAC_ADB_PB1,
716 .via_type = MAC_VIA_QUADRA,
717 .scsi_type = MAC_SCSI_OLD,
718 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100719 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100720 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700721 }, {
722 .ident = MAC_MODEL_PB180,
723 .name = "PowerBook 180",
724 .adb_type = MAC_ADB_PB1,
725 .via_type = MAC_VIA_QUADRA,
726 .scsi_type = MAC_SCSI_OLD,
727 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100728 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100729 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700730 }, {
731 .ident = MAC_MODEL_PB180C,
732 .name = "PowerBook 180c",
733 .adb_type = MAC_ADB_PB1,
734 .via_type = MAC_VIA_QUADRA,
735 .scsi_type = MAC_SCSI_OLD,
736 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100737 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100738 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700739 }, {
740 .ident = MAC_MODEL_PB190,
741 .name = "PowerBook 190",
742 .adb_type = MAC_ADB_PB2,
743 .via_type = MAC_VIA_QUADRA,
744 .scsi_type = MAC_SCSI_OLD,
745 .ide_type = MAC_IDE_BABOON,
746 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100747 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100748 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700749 }, {
750 .ident = MAC_MODEL_PB520,
751 .name = "PowerBook 520",
752 .adb_type = MAC_ADB_PB2,
753 .via_type = MAC_VIA_QUADRA,
754 .scsi_type = MAC_SCSI_OLD,
755 .scc_type = MAC_SCC_QUADRA,
756 .ether_type = MAC_ETHER_SONIC,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100757 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100758 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700759 },
760
761 /*
762 * PowerBook Duos are pretty much like normal PowerBooks
763 * All of these probably have onboard SONIC in the Dock which
764 * means we'll have to probe for it eventually.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700765 */
766
767 {
768 .ident = MAC_MODEL_PB210,
769 .name = "PowerBook Duo 210",
770 .adb_type = MAC_ADB_PB2,
Finn Thain608e287b02011-10-24 01:11:22 +1100771 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700772 .scsi_type = MAC_SCSI_OLD,
773 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100774 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100775 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700776 }, {
777 .ident = MAC_MODEL_PB230,
778 .name = "PowerBook Duo 230",
779 .adb_type = MAC_ADB_PB2,
Finn Thain608e287b02011-10-24 01:11:22 +1100780 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700781 .scsi_type = MAC_SCSI_OLD,
782 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100783 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100784 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700785 }, {
786 .ident = MAC_MODEL_PB250,
787 .name = "PowerBook Duo 250",
788 .adb_type = MAC_ADB_PB2,
Finn Thain608e287b02011-10-24 01:11:22 +1100789 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700790 .scsi_type = MAC_SCSI_OLD,
791 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100792 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100793 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700794 }, {
795 .ident = MAC_MODEL_PB270C,
796 .name = "PowerBook Duo 270c",
797 .adb_type = MAC_ADB_PB2,
Finn Thain608e287b02011-10-24 01:11:22 +1100798 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700799 .scsi_type = MAC_SCSI_OLD,
800 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100801 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100802 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700803 }, {
804 .ident = MAC_MODEL_PB280,
805 .name = "PowerBook Duo 280",
806 .adb_type = MAC_ADB_PB2,
Finn Thain608e287b02011-10-24 01:11:22 +1100807 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700808 .scsi_type = MAC_SCSI_OLD,
809 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100810 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100811 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700812 }, {
813 .ident = MAC_MODEL_PB280C,
814 .name = "PowerBook Duo 280c",
815 .adb_type = MAC_ADB_PB2,
Finn Thain608e287b02011-10-24 01:11:22 +1100816 .via_type = MAC_VIA_IICI,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700817 .scsi_type = MAC_SCSI_OLD,
818 .scc_type = MAC_SCC_QUADRA,
Laurent Vivier7ad93b42008-11-06 20:57:41 +0100819 .nubus_type = MAC_NUBUS,
Finn Thain53aac0a2009-11-04 00:39:09 +1100820 .floppy_type = MAC_FLOPPY_SWIM_ADDR2,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700821 },
822
823 /*
Finn Thain53aac0a2009-11-04 00:39:09 +1100824 * Other stuff?
Linus Torvalds1da177e2005-04-16 15:20:36 -0700825 */
Finn Thain53aac0a2009-11-04 00:39:09 +1100826
Linus Torvalds1da177e2005-04-16 15:20:36 -0700827 {
828 .ident = -1
829 }
830};
831
Finn Thain80614e52009-11-17 20:06:48 +1100832static struct resource scc_a_rsrcs[] = {
833 { .flags = IORESOURCE_MEM },
834 { .flags = IORESOURCE_IRQ },
835};
836
837static struct resource scc_b_rsrcs[] = {
838 { .flags = IORESOURCE_MEM },
839 { .flags = IORESOURCE_IRQ },
840};
841
842struct platform_device scc_a_pdev = {
843 .name = "scc",
844 .id = 0,
845 .num_resources = ARRAY_SIZE(scc_a_rsrcs),
846 .resource = scc_a_rsrcs,
847};
848EXPORT_SYMBOL(scc_a_pdev);
849
850struct platform_device scc_b_pdev = {
851 .name = "scc",
852 .id = 1,
853 .num_resources = ARRAY_SIZE(scc_b_rsrcs),
854 .resource = scc_b_rsrcs,
855};
856EXPORT_SYMBOL(scc_b_pdev);
857
Adrian Bunk8dfbdf42008-07-17 21:16:25 +0200858static void __init mac_identify(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700859{
860 struct mac_model *m;
861
862 /* Penguin data useful? */
863 int model = mac_bi_data.id;
864 if (!model) {
865 /* no bootinfo model id -> NetBSD booter was used! */
866 /* XXX FIXME: breaks for model > 31 */
Roman Zippel6ff58012007-05-01 22:32:43 +0200867 model = (mac_bi_data.cpuid >> 2) & 63;
Finn Thain53aac0a2009-11-04 00:39:09 +1100868 printk(KERN_WARNING "No bootinfo model ID, using cpuid instead "
869 "(obsolete bootloader?)\n");
Linus Torvalds1da177e2005-04-16 15:20:36 -0700870 }
871
872 macintosh_config = mac_data_table;
Roman Zippel6ff58012007-05-01 22:32:43 +0200873 for (m = macintosh_config; m->ident != -1; m++) {
Linus Torvalds1da177e2005-04-16 15:20:36 -0700874 if (m->ident == model) {
875 macintosh_config = m;
876 break;
877 }
878 }
879
Finn Thain80614e52009-11-17 20:06:48 +1100880 /* Set up serial port resources for the console initcall. */
881
882 scc_a_rsrcs[0].start = (resource_size_t) mac_bi_data.sccbase + 2;
883 scc_a_rsrcs[0].end = scc_a_rsrcs[0].start;
884 scc_b_rsrcs[0].start = (resource_size_t) mac_bi_data.sccbase;
885 scc_b_rsrcs[0].end = scc_b_rsrcs[0].start;
886
887 switch (macintosh_config->scc_type) {
888 case MAC_SCC_PSC:
889 scc_a_rsrcs[1].start = scc_a_rsrcs[1].end = IRQ_MAC_SCC_A;
890 scc_b_rsrcs[1].start = scc_b_rsrcs[1].end = IRQ_MAC_SCC_B;
891 break;
892 default:
Finn Thainda3fb3c2011-10-24 01:11:18 +1100893 /* On non-PSC machines, the serial ports share an IRQ. */
894 if (macintosh_config->ident == MAC_MODEL_IIFX) {
895 scc_a_rsrcs[1].start = scc_a_rsrcs[1].end = IRQ_MAC_SCC;
896 scc_b_rsrcs[1].start = scc_b_rsrcs[1].end = IRQ_MAC_SCC;
897 } else {
898 scc_a_rsrcs[1].start = scc_a_rsrcs[1].end = IRQ_AUTO_4;
899 scc_b_rsrcs[1].start = scc_b_rsrcs[1].end = IRQ_AUTO_4;
900 }
Finn Thain80614e52009-11-17 20:06:48 +1100901 break;
902 }
903
Finn Thain53aac0a2009-11-04 00:39:09 +1100904 /*
905 * We need to pre-init the IOPs, if any. Otherwise
906 * the serial console won't work if the user had
907 * the serial ports set to "Faster" mode in MacOS.
908 */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700909 iop_preinit();
Linus Torvalds1da177e2005-04-16 15:20:36 -0700910
Frans Popb9b0d8b2010-02-06 18:47:11 +0100911 printk(KERN_INFO "Detected Macintosh model: %d\n", model);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700912
913 /*
914 * Report booter data:
915 */
Roman Zippel6ff58012007-05-01 22:32:43 +0200916 printk(KERN_DEBUG " Penguin bootinfo data:\n");
Finn Thain53aac0a2009-11-04 00:39:09 +1100917 printk(KERN_DEBUG " Video: addr 0x%lx "
918 "row 0x%lx depth %lx dimensions %ld x %ld\n",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700919 mac_bi_data.videoaddr, mac_bi_data.videorow,
920 mac_bi_data.videodepth, mac_bi_data.dimensions & 0xFFFF,
921 mac_bi_data.dimensions >> 16);
Frans Popb9b0d8b2010-02-06 18:47:11 +0100922 printk(KERN_DEBUG " Videological 0x%lx phys. 0x%lx, SCC at 0x%lx\n",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700923 mac_bi_data.videological, mac_orig_videoaddr,
924 mac_bi_data.sccbase);
Frans Popb9b0d8b2010-02-06 18:47:11 +0100925 printk(KERN_DEBUG " Boottime: 0x%lx GMTBias: 0x%lx\n",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700926 mac_bi_data.boottime, mac_bi_data.gmtbias);
Frans Popb9b0d8b2010-02-06 18:47:11 +0100927 printk(KERN_DEBUG " Machine ID: %ld CPUid: 0x%lx memory size: 0x%lx\n",
Linus Torvalds1da177e2005-04-16 15:20:36 -0700928 mac_bi_data.id, mac_bi_data.cpuid, mac_bi_data.memsize);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700929
Linus Torvalds1da177e2005-04-16 15:20:36 -0700930 iop_init();
931 via_init();
932 oss_init();
933 psc_init();
934 baboon_init();
Finn Thain18814ee2009-11-17 20:03:05 +1100935
936#ifdef CONFIG_ADB_CUDA
937 find_via_cuda();
938#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -0700939}
940
Adrian Bunk8dfbdf42008-07-17 21:16:25 +0200941static void __init mac_report_hardware(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700942{
943 printk(KERN_INFO "Apple Macintosh %s\n", macintosh_config->name);
944}
945
946static void mac_get_model(char *str)
947{
Roman Zippel6ff58012007-05-01 22:32:43 +0200948 strcpy(str, "Macintosh ");
Linus Torvalds1da177e2005-04-16 15:20:36 -0700949 strcat(str, macintosh_config->name);
950}
Laurent Vivier8852ecd2008-11-15 16:10:10 +0100951
Finn Thain2724daf2009-11-04 00:39:56 +1100952static struct resource swim_rsrc = { .flags = IORESOURCE_MEM };
Laurent Vivier8852ecd2008-11-15 16:10:10 +0100953
Finn Thain2724daf2009-11-04 00:39:56 +1100954static struct platform_device swim_pdev = {
Laurent Vivier8852ecd2008-11-15 16:10:10 +0100955 .name = "swim",
956 .id = -1,
Finn Thain2724daf2009-11-04 00:39:56 +1100957 .num_resources = 1,
958 .resource = &swim_rsrc,
Laurent Vivier8852ecd2008-11-15 16:10:10 +0100959};
960
Finn Thaincff75f12009-11-04 00:41:35 +1100961static struct platform_device esp_0_pdev = {
962 .name = "mac_esp",
963 .id = 0,
964};
965
966static struct platform_device esp_1_pdev = {
967 .name = "mac_esp",
968 .id = 1,
969};
970
Finn Thaineeb9c182009-11-04 00:42:02 +1100971static struct platform_device sonic_pdev = {
972 .name = "macsonic",
973 .id = -1,
974};
975
976static struct platform_device mace_pdev = {
977 .name = "macmace",
978 .id = -1,
979};
980
Laurent Vivier8852ecd2008-11-15 16:10:10 +0100981int __init mac_platform_init(void)
982{
983 u8 *swim_base;
984
Geert Uytterhoeven6cfeba52012-03-18 13:21:38 +0100985 if (!MACH_IS_MAC)
986 return -ENODEV;
987
Finn Thain2724daf2009-11-04 00:39:56 +1100988 /*
Finn Thain80614e52009-11-17 20:06:48 +1100989 * Serial devices
990 */
991
992 platform_device_register(&scc_a_pdev);
993 platform_device_register(&scc_b_pdev);
994
995 /*
Finn Thain2724daf2009-11-04 00:39:56 +1100996 * Floppy device
997 */
998
Laurent Vivier8852ecd2008-11-15 16:10:10 +0100999 switch (macintosh_config->floppy_type) {
1000 case MAC_FLOPPY_SWIM_ADDR1:
1001 swim_base = (u8 *)(VIA1_BASE + 0x1E000);
1002 break;
1003 case MAC_FLOPPY_SWIM_ADDR2:
1004 swim_base = (u8 *)(VIA1_BASE + 0x16000);
1005 break;
1006 default:
Finn Thain2724daf2009-11-04 00:39:56 +11001007 swim_base = NULL;
1008 break;
Laurent Vivier8852ecd2008-11-15 16:10:10 +01001009 }
1010
Finn Thain2724daf2009-11-04 00:39:56 +11001011 if (swim_base) {
1012 swim_rsrc.start = (resource_size_t) swim_base,
1013 swim_rsrc.end = (resource_size_t) swim_base + 0x2000,
1014 platform_device_register(&swim_pdev);
1015 }
Laurent Vivier8852ecd2008-11-15 16:10:10 +01001016
Finn Thaincff75f12009-11-04 00:41:35 +11001017 /*
1018 * SCSI device(s)
1019 */
1020
1021 switch (macintosh_config->scsi_type) {
1022 case MAC_SCSI_QUADRA:
1023 case MAC_SCSI_QUADRA3:
1024 platform_device_register(&esp_0_pdev);
1025 break;
1026 case MAC_SCSI_QUADRA2:
1027 platform_device_register(&esp_0_pdev);
1028 if ((macintosh_config->ident == MAC_MODEL_Q900) ||
1029 (macintosh_config->ident == MAC_MODEL_Q950))
1030 platform_device_register(&esp_1_pdev);
1031 break;
1032 }
1033
Finn Thaineeb9c182009-11-04 00:42:02 +11001034 /*
1035 * Ethernet device
1036 */
1037
1038 switch (macintosh_config->ether_type) {
1039 case MAC_ETHER_SONIC:
1040 platform_device_register(&sonic_pdev);
1041 break;
1042 case MAC_ETHER_MACE:
1043 platform_device_register(&mace_pdev);
1044 break;
1045 }
1046
Finn Thain2724daf2009-11-04 00:39:56 +11001047 return 0;
Laurent Vivier8852ecd2008-11-15 16:10:10 +01001048}
1049
1050arch_initcall(mac_platform_init);