1 /* 2 * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com) 3 * 4 * This program is free software; you can redistribute it and/or modify 5 * it under the terms of the GNU General Public License version 2 as 6 * published by the Free Software Foundation. 7 */ 8 9 #ifndef __ASM_LINKAGE_H 10 #define __ASM_LINKAGE_H 11 12 #ifdef __ASSEMBLY__ 13 14 #define ASM_NL ` /* use '`' to mark new line in macro */ 15 16 /* annotation for data we want in DCCM - if enabled in .config */ 17 .macro ARCFP_DATA nm 18 #ifdef CONFIG_ARC_HAS_DCCM 19 .section .data.arcfp 20 #else 21 .section .data 22 #endif 23 .global \nm 24 .endm 25 26 /* annotation for data we want in DCCM - if enabled in .config */ 27 .macro ARCFP_CODE 28 #ifdef CONFIG_ARC_HAS_ICCM 29 .section .text.arcfp, "ax",@progbits 30 #else 31 .section .text, "ax",@progbits 32 #endif 33 .endm 34 35 #else /* !__ASSEMBLY__ */ 36 37 #ifdef CONFIG_ARC_HAS_ICCM 38 #define __arcfp_code __attribute__((__section__(".text.arcfp"))) 39 #else 40 #define __arcfp_code __attribute__((__section__(".text"))) 41 #endif 42 43 #ifdef CONFIG_ARC_HAS_DCCM 44 #define __arcfp_data __attribute__((__section__(".data.arcfp"))) 45 #else 46 #define __arcfp_data __attribute__((__section__(".data"))) 47 #endif 48 49 #endif /* __ASSEMBLY__ */ 50 51 #endif 52