ArmPkg/Library/CompilerIntrinsicsLib: Enable VS2017/ARM builds

Introduce CRT assembly replacements for __rt_sdiv, __rt_udiv,
__rt_udiv64, __rt_sdiv64, __rt_srsh (by reusing the RVCT code)
as well as memcpy and memset.
For MSFT compatibility, some of the code needs to be explicitly
forced to ARM, and the /oldit assembly flag needs to be added.
Also, while RVCT_ASM_EXPORT macro invocations have been removed,
the replacement code is designed to be as close as possible to
the one that would have been generated if using the macros.

Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Pete Batard <pete@akeo.ie>
Reviewed-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
This commit is contained in:
Pete Batard 2018-01-12 21:33:29 +08:00 committed by Liming Gao
parent 30939ff2bc
commit e58427e396
7 changed files with 185 additions and 32 deletions

View File

@ -1,6 +1,7 @@
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
// //
// Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR> // Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR>
// Copyright (c) 2018, Pete Batard. All rights reserved.<BR>
// //
// This program and the accompanying materials // This program and the accompanying materials
// are licensed and made available under the terms and conditions of the BSD License // are licensed and made available under the terms and conditions of the BSD License
@ -17,18 +18,19 @@
EXPORT __aeabi_uidivmod EXPORT __aeabi_uidivmod
EXPORT __aeabi_idiv EXPORT __aeabi_idiv
EXPORT __aeabi_idivmod EXPORT __aeabi_idivmod
EXPORT __rt_udiv
EXPORT __rt_sdiv
AREA Math, CODE, READONLY AREA Math, CODE, READONLY
; ;
;UINT32 ;UINT32
;EFIAPI ;EFIAPI
;__aeabi_uidivmode ( ;__aeabi_uidivmod (
; IN UINT32 Dividen ; IN UINT32 Dividend
; IN UINT32 Divisor ; IN UINT32 Divisor
; ); ; );
; ;
__aeabi_uidiv __aeabi_uidiv
__aeabi_uidivmod __aeabi_uidivmod
RSBS r12, r1, r0, LSR #4 RSBS r12, r1, r0, LSR #4
@ -39,11 +41,41 @@ __aeabi_uidivmod
MOV r3, #0 MOV r3, #0
B __arm_div_large B __arm_div_large
;
;UINT64
;EFIAPI
;__rt_udiv (
; IN UINT32 Divisor,
; IN UINT32 Dividend
; );
;
__rt_udiv
; Swap R0 and R1
MOV r12, r0
MOV r0, r1
MOV r1, r12
B __aeabi_uidivmod
;
;UINT64
;EFIAPI
;__rt_sdiv (
; IN INT32 Divisor,
; IN INT32 Dividend
; );
;
__rt_sdiv
; Swap R0 and R1
MOV r12, r0
MOV r0, r1
MOV r1, r12
B __aeabi_idivmod
; ;
;INT32 ;INT32
;EFIAPI ;EFIAPI
;__aeabi_idivmode ( ;__aeabi_idivmod (
; IN INT32 Dividen ; IN INT32 Dividend
; IN INT32 Divisor ; IN INT32 Divisor
; ); ; );
; ;
@ -152,4 +184,3 @@ __aeabi_idiv0
BX r14 BX r14
END END

View File

@ -1,6 +1,7 @@
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
// //
// Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR> // Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR>
// Copyright (c) 2018, Pete Batard. All rights reserved.<BR>
// //
// This program and the accompanying materials // This program and the accompanying materials
// are licensed and made available under the terms and conditions of the BSD License // are licensed and made available under the terms and conditions of the BSD License
@ -13,20 +14,41 @@
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
EXTERN __aeabi_uldivmod IMPORT __aeabi_uldivmod
EXPORT __aeabi_ldivmod
EXPORT __rt_sdiv64
INCLUDE AsmMacroExport.inc AREA s___aeabi_ldivmod, CODE, READONLY, ARM
ARM
; ;
;UINT32 ;INT64
;EFIAPI ;EFIAPI
;__aeabi_uidivmode ( ;__rt_sdiv64 (
; IN UINT32 Dividen ; IN INT64 Divisor
; IN UINT32 Divisor ; IN INT64 Dividend
; ); ; );
; ;
__rt_sdiv64
; Swap r0-r1 and r2-r3
MOV r12, r0
MOV r0, r2
MOV r2, r12
MOV r12, r1
MOV r1, r3
MOV r3, r12
B __aeabi_ldivmod
RVCT_ASM_EXPORT __aeabi_ldivmod ;
;INT64
;EFIAPI
;__aeabi_ldivmod (
; IN INT64 Dividend
; IN INT64 Divisor
; );
;
__aeabi_ldivmod
PUSH {r4,lr} PUSH {r4,lr}
ASRS r4,r1,#1 ASRS r4,r1,#1
EOR r4,r4,r3,LSR #1 EOR r4,r4,r3,LSR #1
@ -39,7 +61,7 @@ L_Test1
RSBS r2,r2,#0 RSBS r2,r2,#0
RSC r3,r3,#0 RSC r3,r3,#0
L_Test2 L_Test2
BL __aeabi_uldivmod ; BL __aeabi_uldivmod
TST r4,#0x40000000 TST r4,#0x40000000
BEQ L_Test3 BEQ L_Test3
RSBS r0,r0,#0 RSBS r0,r0,#0
@ -53,5 +75,3 @@ L_Exit
POP {r4,pc} POP {r4,pc}
END END

View File

@ -1,6 +1,7 @@
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
// //
// Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR> // Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR>
// Copyright (c) 2018, Pete Batard. All rights reserved.<BR>
// //
// This program and the accompanying materials // This program and the accompanying materials
// are licensed and made available under the terms and conditions of the BSD License // are licensed and made available under the terms and conditions of the BSD License
@ -12,32 +13,33 @@
// //
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
EXPORT __aeabi_llsr
EXPORT __rt_srsh
AREA s___aeabi_llsr, CODE, READONLY, ARM
INCLUDE AsmMacroExport.inc ARM
; ;
;VOID ;VOID
;EFIAPI ;EFIAPI
;__aeabi_llsr ( ;__aeabi_llsr (
; IN VOID *Destination, ; IN UINT64 Value,
; IN VOID *Source, ; IN UINT32 Shift
; IN UINT32 Size ;)
; );
; ;
RVCT_ASM_EXPORT __aeabi_llsr __aeabi_llsr
__rt_srsh
SUBS r3,r2,#0x20 SUBS r3,r2,#0x20
BPL {pc} + 0x18 ; 0x1c BPL __aeabi_llsr_label1
RSB r3,r2,#0x20 RSB r3,r2,#0x20
LSR r0,r0,r2 LSR r0,r0,r2
ORR r0,r0,r1,LSL r3 ORR r0,r0,r1,LSL r3
LSR r1,r1,r2 LSR r1,r1,r2
BX lr BX lr
__aeabi_llsr_label1
LSR r0,r1,r3 LSR r0,r1,r3
MOV r1,#0 MOV r1,#0
BX lr BX lr
END END

View File

@ -1,6 +1,7 @@
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
// //
// Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR> // Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR>
// Copyright (c) 2018, Pete Batard. All rights reserved.<BR>
// //
// This program and the accompanying materials // This program and the accompanying materials
// are licensed and made available under the terms and conditions of the BSD License // are licensed and made available under the terms and conditions of the BSD License
@ -13,9 +14,30 @@
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
EXPORT __aeabi_uldivmod
EXPORT __rt_udiv64
AREA s___aeabi_uldivmod, CODE, READONLY, ARM
INCLUDE AsmMacroExport.inc ARM
;
;UINT64
;EFIAPI
;__rt_udiv64 (
; IN UINT64 Divisor
; IN UINT64 Dividend
; )
;
__rt_udiv64
; Swap r0-r1 and r2-r3
mov r12, r0
mov r0, r2
mov r2, r12
mov r12, r1
mov r1, r3
mov r3, r12
b __aeabi_uldivmod
; ;
;UINT64 ;UINT64
@ -25,7 +47,7 @@
; IN UINT64 Divisor ; IN UINT64 Divisor
; ) ; )
; ;
RVCT_ASM_EXPORT __aeabi_uldivmod __aeabi_uldivmod
stmdb sp!, {r4, r5, r6, lr} stmdb sp!, {r4, r5, r6, lr}
mov r4, r1 mov r4, r1
mov r5, r0 mov r5, r0
@ -261,7 +283,6 @@ _ll_div0
b __aeabi_ldiv0 b __aeabi_ldiv0
__aeabi_ldiv0 __aeabi_ldiv0
BX r14 bx r14
END END

View File

@ -23,8 +23,12 @@
LIBRARY_CLASS = CompilerIntrinsicsLib LIBRARY_CLASS = CompilerIntrinsicsLib
[Sources] [Sources]
memcpy.c memcpy.c | RVCT
memset.c memcpy.c | GCC
memcpy_ms.c | MSFT
memset.c | RVCT
memset.c | GCC
memset_ms.c | MSFT
[Sources.ARM] [Sources.ARM]
Arm/mullu.asm | RVCT Arm/mullu.asm | RVCT
@ -94,6 +98,10 @@
Arm/llsr.S | GCC Arm/llsr.S | GCC
Arm/llsl.S | GCC Arm/llsl.S | GCC
Arm/div.asm | MSFT
Arm/uldiv.asm | MSFT
Arm/ldivmod.asm | MSFT
Arm/llsr.asm | MSFT
[Packages] [Packages]
MdePkg/MdePkg.dec MdePkg/MdePkg.dec
@ -101,3 +109,7 @@
[LibraryClasses] [LibraryClasses]
[BuildOptions]
MSFT:*_*_ARM_CC_FLAGS = /GL-
MSFT:*_*_ARM_ASM_FLAGS = /oldit
MSFT:*_*_AARCH64_CC_FLAGS = /GL-

View File

@ -0,0 +1,34 @@
//------------------------------------------------------------------------------
//
// Copyright (c) 2017, Pete Batard. 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.
//
//------------------------------------------------------------------------------
#if defined(_M_ARM64)
typedef unsigned __int64 size_t;
#else
typedef unsigned __int32 size_t;
#endif
void* memcpy(void *, const void *, size_t);
#pragma intrinsic(memcpy)
#pragma function(memcpy)
void* memcpy(void *dest, const void *src, size_t n)
{
unsigned char *d = dest;
unsigned char const *s = src;
while (n--)
*d++ = *s++;
return dest;
}

View File

@ -0,0 +1,33 @@
//------------------------------------------------------------------------------
//
// Copyright (c) 2017, Pete Batard. 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.
//
//------------------------------------------------------------------------------
#if defined(_M_ARM64)
typedef unsigned __int64 size_t;
#else
typedef unsigned __int32 size_t;
#endif
void* memset(void *, int, size_t);
#pragma intrinsic(memset)
#pragma function(memset)
void *memset(void *s, int c, size_t n)
{
unsigned char *d = s;
while (n--)
*d++ = (unsigned char)c;
return s;
}