[llvm] r198916 - ARM IAS: support #:{lower, upper}16: for GNU compatibility
Jim Grosbach
grosbach at apple.com
Wed Aug 27 17:55:34 PDT 2014
Holy crap. Why did my mail client show this to me as a new email? Good grief. Sorry about that…..
> On Aug 27, 2014, at 5:54 PM, Jim Grosbach <grosbach at apple.com> wrote:
>
> Cool.
>
> Would it make sense to put the tests in one of the existing test files? The tests generally run faster with a few larger files than with lots of small ones.
>
> -Jim
>
>> On Jan 9, 2014, at 8:38 PM, Saleem Abdulrasool <compnerd at compnerd.org> wrote:
>>
>> Author: compnerd
>> Date: Thu Jan 9 22:38:40 2014
>> New Revision: 198916
>>
>> URL: http://llvm.org/viewvc/llvm-project?rev=198916&view=rev
>> Log:
>> ARM IAS: support #:{lower,upper}16: for GNU compatibility
>>
>> The GNU assembler supports prefixing the expression with a '#' to indiciate that
>> the value that is being moved is infact a constant. This improves the
>> compatibility of the integrated assembler's parser for this.
>>
>> Added:
>> llvm/trunk/test/MC/ARM/target-expressions.s
>> Modified:
>> llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp
>>
>> Modified: llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp
>> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp?rev=198916&r1=198915&r2=198916&view=diff
>> ==============================================================================
>> --- llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp (original)
>> +++ llvm/trunk/lib/Target/ARM/AsmParser/ARMAsmParser.cpp Thu Jan 9 22:38:40 2014
>> @@ -4813,6 +4813,10 @@ bool ARMAsmParser::parseOperand(SmallVec
>> bool ARMAsmParser::parsePrefix(ARMMCExpr::VariantKind &RefKind) {
>> RefKind = ARMMCExpr::VK_ARM_None;
>>
>> + // consume an optional '#' (GNU compatibility)
>> + if (getLexer().is(AsmToken::Hash))
>> + Parser.Lex();
>> +
>> // :lower16: and :upper16: modifiers
>> assert(getLexer().is(AsmToken::Colon) && "expected a :");
>> Parser.Lex(); // Eat ':'
>>
>> Added: llvm/trunk/test/MC/ARM/target-expressions.s
>> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/MC/ARM/target-expressions.s?rev=198916&view=auto
>> ==============================================================================
>> --- llvm/trunk/test/MC/ARM/target-expressions.s (added)
>> +++ llvm/trunk/test/MC/ARM/target-expressions.s Thu Jan 9 22:38:40 2014
>> @@ -0,0 +1,44 @@
>> +@ RUN: llvm-mc -triple armv7-eabi -filetype asm -o - %s | FileCheck %s
>> +
>> + .syntax unified
>> +
>> + .type function,%function
>> +function:
>> + bx lr
>> +
>> +.set deadbeat, 0xdeadbea7
>> +
>> + .type test,%function
>> +test:
>> + movw r0, :lower16:function
>> + movt r0, :upper16:function
>> +
>> + movw r1, #:lower16:function
>> + movt r1, #:upper16:function
>> +
>> + movw r2, :lower16:deadbeat
>> + movt r2, :upper16:deadbeat
>> +
>> + movw r3, #:lower16:deadbeat
>> + movt r3, #:upper16:deadbeat
>> +
>> + movw r4, :lower16:0xD1510D6E
>> + movt r4, :upper16:0xD1510D6E
>> +
>> + movw r5, #:lower16:0xD1510D6E
>> + movt r5, #:upper16:0xD1510D6E
>> +
>> +@ CHECK-LABEL: test:
>> +@ CHECK: movw r0, :lower16:function
>> +@ CHECK: movt r0, :upper16:function
>> +@ CHECK: movw r1, :lower16:function
>> +@ CHECK: movt r1, :upper16:function
>> +@ CHECK: movw r2, :lower16:(3735928487)
>> +@ CHECK: movt r2, :upper16:(3735928487)
>> +@ CHECK: movw r3, :lower16:(3735928487)
>> +@ CHECK: movt r3, :upper16:(3735928487)
>> +@ CHECK: movw r4, :lower16:(3511749998)
>> +@ CHECK: movt r4, :upper16:(3511749998)
>> +@ CHECK: movw r5, :lower16:(3511749998)
>> +@ CHECK: movt r5, :upper16:(3511749998)
>> +
>>
>>
>> _______________________________________________
>> llvm-commits mailing list
>> llvm-commits at cs.uiuc.edu
>> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
>
More information about the llvm-commits
mailing list