diff options
| -rw-r--r-- | arch/blackfin/mach-common/smp.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/arch/blackfin/mach-common/smp.c b/arch/blackfin/mach-common/smp.c index 961d8392e5e3..b5f9ed7d4856 100644 --- a/arch/blackfin/mach-common/smp.c +++ b/arch/blackfin/mach-common/smp.c | |||
| @@ -147,7 +147,7 @@ static irqreturn_t ipi_handler_int1(int irq, void *dev_instance) | |||
| 147 | platform_clear_ipi(cpu, IRQ_SUPPLE_1); | 147 | platform_clear_ipi(cpu, IRQ_SUPPLE_1); |
| 148 | 148 | ||
| 149 | bfin_ipi_data = &__get_cpu_var(bfin_ipi); | 149 | bfin_ipi_data = &__get_cpu_var(bfin_ipi); |
| 150 | while ((pending = xchg(&bfin_ipi_data->bits, 0)) != 0) { | 150 | while ((pending = atomic_xchg(&bfin_ipi_data->bits, 0)) != 0) { |
| 151 | msg = 0; | 151 | msg = 0; |
| 152 | do { | 152 | do { |
| 153 | msg = find_next_bit(&pending, BITS_PER_LONG, msg + 1); | 153 | msg = find_next_bit(&pending, BITS_PER_LONG, msg + 1); |
| @@ -182,8 +182,8 @@ static void bfin_ipi_init(void) | |||
| 182 | struct ipi_data *bfin_ipi_data; | 182 | struct ipi_data *bfin_ipi_data; |
| 183 | for_each_possible_cpu(cpu) { | 183 | for_each_possible_cpu(cpu) { |
| 184 | bfin_ipi_data = &per_cpu(bfin_ipi, cpu); | 184 | bfin_ipi_data = &per_cpu(bfin_ipi, cpu); |
| 185 | bfin_ipi_data->bits = 0; | 185 | atomic_set(&bfin_ipi_data->bits, 0); |
| 186 | bfin_ipi_data->count = 0; | 186 | atomic_set(&bfin_ipi_data->count, 0); |
| 187 | } | 187 | } |
| 188 | } | 188 | } |
| 189 | 189 | ||
