blob: 2c3b952be63ebbc536d767798eb21dfba153d25b [file] [log] [blame]
Catalin Marinas0becb082009-07-24 12:32:53 +01001/*
2 * include/asm-arm/unified.h - Unified Assembler Syntax helper macros
3 *
4 * Copyright (C) 2008 ARM Limited
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, write to the Free Software
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 */
19
20#ifndef __ASM_UNIFIED_H
21#define __ASM_UNIFIED_H
22
Nicolas Pitre75fea302017-11-29 07:52:52 +010023#if defined(__ASSEMBLY__)
Catalin Marinas0becb082009-07-24 12:32:53 +010024 .syntax unified
Nicolas Pitre75fea302017-11-29 07:52:52 +010025#else
26__asm__(".syntax unified");
Catalin Marinas0becb082009-07-24 12:32:53 +010027#endif
28
Joachim Eastwoodc20611d2015-03-25 08:47:18 +010029#ifdef CONFIG_CPU_V7M
30#define AR_CLASS(x...)
31#define M_CLASS(x...) x
32#else
33#define AR_CLASS(x...) x
34#define M_CLASS(x...)
35#endif
36
Catalin Marinas0becb082009-07-24 12:32:53 +010037#ifdef CONFIG_THUMB2_KERNEL
38
39#if __GNUC__ < 4
40#error Thumb-2 kernel requires gcc >= 4
41#endif
42
43/* The CPSR bit describing the instruction set (Thumb) */
44#define PSR_ISETSTATE PSR_T_BIT
45
46#define ARM(x...)
47#define THUMB(x...) x
Alexey Dobriyan74109b82009-09-18 15:09:33 +010048#ifdef __ASSEMBLY__
Catalin Marinas0becb082009-07-24 12:32:53 +010049#define W(instr) instr.w
Will Deacon27a84792013-07-02 12:10:42 +010050#else
51#define WASM(instr) #instr ".w"
Rob Herringefb963d2012-01-09 15:43:20 -060052#endif
Catalin Marinas0becb082009-07-24 12:32:53 +010053
54#else /* !CONFIG_THUMB2_KERNEL */
55
56/* The CPSR bit describing the instruction set (ARM) */
57#define PSR_ISETSTATE 0
58
59#define ARM(x...) x
60#define THUMB(x...)
Alexey Dobriyan74109b82009-09-18 15:09:33 +010061#ifdef __ASSEMBLY__
Catalin Marinas0becb082009-07-24 12:32:53 +010062#define W(instr) instr
Will Deacon27a84792013-07-02 12:10:42 +010063#else
64#define WASM(instr) #instr
Rob Herringefb963d2012-01-09 15:43:20 -060065#endif
Catalin Marinas0becb082009-07-24 12:32:53 +010066
67#endif /* CONFIG_THUMB2_KERNEL */
68
Catalin Marinas0becb082009-07-24 12:32:53 +010069#endif /* !__ASM_UNIFIED_H */