The CLANG assembler does not support the legacy, non-unified assembler syntax, i.e., it does not support the reordering of the condition suffixes with the increment/decrement before/after or byte/word suffixes, and it does not recognize the 'empty descending' (ED) suffix at all. So move to the unified syntax, and replace 'empty descending' with 'decrement after' or 'increment before' as appropriate. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Reviewed-by: Leif Lindholm <leif.lindholm@linaro.org> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@19280 6f19259b-4bc3-4df7-8a09-765794883524
33 lines
889 B
ArmAsm
33 lines
889 B
ArmAsm
#/** @file
|
|
# Compiler intrinsic for ARM compiler
|
|
#
|
|
# Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR>
|
|
# This program and the accompanying materials
|
|
# are licensed and made available under the terms and conditions of the BSD License
|
|
# which accompanies this distribution. The full text of the license may be found at
|
|
# http://opensource.org/licenses/bsd-license.php
|
|
#
|
|
# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.;
|
|
#
|
|
#**/
|
|
#
|
|
|
|
.text
|
|
.syntax unified
|
|
.p2align 2
|
|
|
|
GCC_ASM_EXPORT(__switch16)
|
|
|
|
ASM_PFX(__switch16):
|
|
ldrh ip, [lr, #-1]
|
|
cmp r0, ip
|
|
add r0, lr, r0, lsl #1
|
|
ldrshcc r0, [r0, #1]
|
|
add ip, lr, ip, lsl #1
|
|
ldrshcs r0, [ip, #1]
|
|
add ip, lr, r0, lsl #1
|
|
bx ip
|
|
|
|
|