blob: e5db797790d3265c5418d749b7537c494ddeb250 [file] [log] [blame]
Catalin Marinas62479582013-03-21 16:28:47 +00001/*
2 * Based on arch/arm/lib/bitops.h
3 *
4 * Copyright (C) 2013 ARM Ltd.
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 */
18
19#include <linux/linkage.h>
20#include <asm/assembler.h>
21
22/*
23 * x0: bits 5:0 bit offset
Catalin Marinas420c158d2013-05-07 18:02:58 +010024 * bits 31:6 word offset
Catalin Marinas62479582013-03-21 16:28:47 +000025 * x1: address
26 */
27 .macro bitop, name, instr
28ENTRY( \name )
Catalin Marinas420c158d2013-05-07 18:02:58 +010029 and w3, w0, #63 // Get bit offset
30 eor w0, w0, w3 // Clear low bits
Catalin Marinas62479582013-03-21 16:28:47 +000031 mov x2, #1
32 add x1, x1, x0, lsr #3 // Get word offset
33 lsl x3, x2, x3 // Create mask
341: ldxr x2, [x1]
35 \instr x2, x2, x3
36 stxr w0, x2, [x1]
37 cbnz w0, 1b
38 ret
39ENDPROC(\name )
40 .endm
41
42 .macro testop, name, instr
43ENTRY( \name )
Catalin Marinas420c158d2013-05-07 18:02:58 +010044 and w3, w0, #63 // Get bit offset
45 eor w0, w0, w3 // Clear low bits
Catalin Marinas62479582013-03-21 16:28:47 +000046 mov x2, #1
47 add x1, x1, x0, lsr #3 // Get word offset
48 lsl x4, x2, x3 // Create mask
Catalin Marinas16c85a12013-04-30 15:58:37 +0100491: ldaxr x2, [x1]
Catalin Marinas62479582013-03-21 16:28:47 +000050 lsr x0, x2, x3 // Save old value of bit
51 \instr x2, x2, x4 // toggle bit
Catalin Marinas16c85a12013-04-30 15:58:37 +010052 stlxr w5, x2, [x1]
Mark Rutlandc47d6a02013-04-30 11:11:15 +010053 cbnz w5, 1b
Catalin Marinas62479582013-03-21 16:28:47 +000054 and x0, x0, #1
553: ret
56ENDPROC(\name )
57 .endm
58
59/*
60 * Atomic bit operations.
61 */
62 bitop change_bit, eor
63 bitop clear_bit, bic
64 bitop set_bit, orr
65
66 testop test_and_change_bit, eor
67 testop test_and_clear_bit, bic
68 testop test_and_set_bit, orr