Root/target/linux/ubicom32/files/arch/ubicom32/include/asm/smp.h

1/*
2 * arch/ubicom32/include/asm/smp.h
3 * SMP definitions for Ubicom32 architecture.
4 *
5 * (C) Copyright 2009, Ubicom, Inc.
6 *
7 * This file is part of the Ubicom32 Linux Kernel Port.
8 *
9 * The Ubicom32 Linux Kernel Port is free software: you can redistribute
10 * it and/or modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation, either version 2 of the
12 * License, or (at your option) any later version.
13 *
14 * The Ubicom32 Linux Kernel Port is distributed in the hope that it
15 * will be useful, but WITHOUT ANY WARRANTY; without even the implied
16 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
17 * the GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with the Ubicom32 Linux Kernel Port. If not,
21 * see <http://www.gnu.org/licenses/>.
22 *
23 * Ubicom32 implementation derived from (with many thanks):
24 * arch/m68knommu
25 * arch/blackfin
26 * arch/parisc
27 */
28#ifndef _ASM_UBICOM32_SMP_H
29#define _ASM_UBICOM32_SMP_H
30
31#ifndef CONFIG_SMP
32#error you should not include smp.h if smp is off
33#endif
34
35#ifndef ASSEMBLY
36#include <linux/bitops.h>
37#include <linux/threads.h>
38#include <linux/cpumask.h>
39#include <asm/ip5000.h>
40
41typedef unsigned long address_t;
42extern unsigned int smp_ipi_irq;
43
44/*
45 * This magic constant controls our willingness to transfer
46 * a process across CPUs.
47 *
48 * Such a transfer incurs cache and tlb
49 * misses. The current value is inherited from i386. Still needs
50 * to be tuned for parisc.
51 */
52#define PROC_CHANGE_PENALTY 15 /* Schedule penalty */
53#define NO_PROC_ID 0xFF /* No processor magic marker */
54#define ANY_PROC_ID 0xFF /* Any processor magic marker */
55
56#ifdef CONFIG_SMP
57#define raw_smp_processor_id() (current_thread_info()->cpu)
58#endif /* CONFIG_SMP */
59
60static inline int __cpu_disable (void)
61{
62  return 0;
63}
64
65static inline void __cpu_die (unsigned int cpu)
66{
67    while(1) {
68    };
69}
70
71extern int __cpu_up(unsigned int cpu);
72extern void smp_send_timer_all(void);
73extern void smp_timer_broadcast(const struct cpumask *mask);
74extern void smp_set_affinity(unsigned int irq, const struct cpumask *dest);
75extern void arch_send_call_function_single_ipi(int cpu);
76#define arch_send_call_function_ipi_mask arch_send_call_function_ipi_mask
77extern void arch_send_call_function_ipi_mask(const struct cpumask *mask);
78
79/*
80 * TODO: Once these are fully tested, we should turn them into
81 * inline macros for performance.
82 */
83extern unsigned long smp_get_affinity(unsigned int irq, int *all);
84extern void smp_reset_ipi(unsigned long mask);
85
86#endif /* !ASSEMBLY */
87#endif /* _ASM_UBICOM32_SMP_H */
88

Archive Download this file



interactive