Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(640)

Issue 1456783003: Add LSL (register, immediate) to ARM integrated assembler. (Closed)

Created:
5 years, 1 month ago by Karl
Modified:
5 years ago
Reviewers:
Jim Stichnoth, sehr, John
CC:
native-client-reviews_googlegroups.com
Base URL:
https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Target Ref:
refs/heads/master
Visibility:
Public.

Description

Add LSL (register, immediate) to ARM integrated assembler. Also does some clean up on emitType01 methods (making optional argument explicit, and moving rule checks to the lowest level). BUG= https://bugs.chromium.org/p/nativeclient/issues/detail?id=4334 R=jpp@chromium.org Committed: https://gerrit.chromium.org/gerrit/gitweb?p=native_client/pnacl-subzero.git;a=commit;h=f4d0a7a5819541ecb44ec7dafe151114981cdb88

Patch Set 1 #

Patch Set 2 : Fix nits. #

Patch Set 3 : Fix more nits. #

Total comments: 4
Unified diffs Side-by-side diffs Delta from patch set Stats (+168 lines, -59 lines) Patch
M src/DartARM32/assembler_arm.h View 4 chunks +6 lines, -3 lines 0 comments Download
M src/DartARM32/assembler_arm.cc View 1 2 2 chunks +4 lines, -2 lines 0 comments Download
M src/IceAssemblerARM32.h View 3 chunks +14 lines, -12 lines 0 comments Download
M src/IceAssemblerARM32.cpp View 19 chunks +97 lines, -21 lines 2 comments Download
M src/IceInstARM32.cpp View 1 chunk +7 lines, -0 lines 0 comments Download
A + tests_lit/assembler/arm32/lsl.ll View 3 chunks +40 lines, -21 lines 2 comments Download

Messages

Total messages: 7 (2 generated)
Karl
5 years, 1 month ago (2015-11-18 18:30:38 UTC) #3
John
lgtm
5 years, 1 month ago (2015-11-19 14:18:40 UTC) #4
Karl
Committed patchset #3 (id:40001) manually as f4d0a7a5819541ecb44ec7dafe151114981cdb88 (presubmit successful).
5 years, 1 month ago (2015-11-19 16:10:49 UTC) #5
Jim Stichnoth
otherwise necro lgtm https://codereview.chromium.org/1456783003/diff/40001/src/IceAssemblerARM32.cpp File src/IceAssemblerARM32.cpp (right): https://codereview.chromium.org/1456783003/diff/40001/src/IceAssemblerARM32.cpp#newcode452 src/IceAssemblerARM32.cpp:452: if (((Rd == RegARM32::Encoded_Reg_pc) && SetFlags)) ...
5 years, 1 month ago (2015-11-22 03:58:48 UTC) #6
Karl
5 years ago (2015-11-30 16:53:52 UTC) #7
Message was sent while issue was closed.
Fixed in CL https://codereview.chromium.org/1484023002.

https://codereview.chromium.org/1456783003/diff/40001/src/IceAssemblerARM32.cpp
File src/IceAssemblerARM32.cpp (right):

https://codereview.chromium.org/1456783003/diff/40001/src/IceAssemblerARM32.c...
src/IceAssemblerARM32.cpp:452: if (((Rd == RegARM32::Encoded_Reg_pc) &&
SetFlags))
On 2015/11/22 03:58:47, stichnot wrote:
> Maybe strip one level of parens?

Done.

https://codereview.chromium.org/1456783003/diff/40001/tests_lit/assembler/arm...
File tests_lit/assembler/arm32/lsl.ll (right):

https://codereview.chromium.org/1456783003/diff/40001/tests_lit/assembler/arm...
tests_lit/assembler/arm32/lsl.ll:23: define internal i32 @_Z8testUdivhh(i32 %a,
i32 %b) {
On 2015/11/22 03:58:47, stichnot wrote:
> What a lovely function name! :)  Of course it is actually the mangling of
> "testUdiv(unsigned char, unsigned char)".  Maybe the unmangled names could be
> used instead for the lit tests?
> 
> I'm actually puzzled as to how shifting gets involved in udiv, but I'm sure
> there's a good explanation.  Even so, surely there could be a more direct
> example than udiv?

Simplified.

Powered by Google App Engine
This is Rietveld 408576698