1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- /*
- * arch/sh/boards/saturn/smp.c
- *
- * SMP support for the Sega Saturn.
- *
- * Copyright (c) 2002 Paul Mundt
- *
- * Released under the terms of the GNU GPL v2.0.
- */
- #include <linux/kernel.h>
- #include <linux/init.h>
- #include <linux/smp.h>
- #include <asm/saturn/smpc.h>
- extern void start_secondary(void);
- void __smp_send_ipi(unsigned int cpu, unsigned int action)
- {
- /* Nothing here yet .. */
- }
- unsigned int __smp_probe_cpus(void)
- {
- /*
- * This is just a straightforward master/slave configuration,
- * and probing isn't really supported..
- */
- return 2;
- }
- /*
- * We're only allowed to do byte-access to SMPC registers. In
- * addition to which, we treat them as write-only, since
- * reading from them will return undefined data.
- */
- static inline void smpc_slave_stop(unsigned int cpu)
- {
- smpc_barrier();
- ctrl_outb(1, SMPC_STATUS);
- ctrl_outb(SMPC_CMD_SSHOFF, SMPC_COMMAND);
- smpc_barrier();
- }
- static inline void smpc_slave_start(unsigned int cpu)
- {
- ctrl_outb(1, SMPC_STATUS);
- ctrl_outb(SMPC_CMD_SSHON, SMPC_COMMAND);
- smpc_barrier();
- }
- void __smp_slave_init(unsigned int cpu)
- {
- register unsigned long vbr;
- void **entry;
- __asm__ __volatile__ ("stc vbr, %0\n\t" : "=r" (vbr));
- entry = (void **)(vbr + 0x310 + 0x94);
- smpc_slave_stop(cpu);
- *(void **)entry = (void *)start_secondary;
- smpc_slave_start(cpu);
- }
|