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

Issue 21014003: Optionally use 31-bits SMI value for 64-bit system (Closed)

Created:
7 years, 4 months ago by haitao.feng
Modified:
5 years ago
CC:
v8-dev
Visibility:
Public.

Description

Optionally use 31-bits SMI value for 64-bit system

Patch Set 1 #

Total comments: 16

Patch Set 2 : Addressed high-level feedback #

Patch Set 3 : Refined temp register usage for NumberTagI #

Patch Set 4 : Use (kSmiValueSize == 31) or (kSmiValueSize == 32) for SMI functions in macro assembler" #

Total comments: 21

Patch Set 5 : Refined SmiShiftLeft, SmiLogicalShiftRight and BinaryOpStub_GenerateFloatingPointCode #

Patch Set 6 : Addressed danno's comments #

Patch Set 7 : Introduce SmiFunctionInvoker to abstract the difference between FullCodeGen and LCodeGen #

Total comments: 25

Patch Set 8 : Addressed danno's comments #

Patch Set 9 : Addressed danno's comments #

Total comments: 23
Unified diffs Side-by-side diffs Delta from patch set Stats (+1427 lines, -441 lines) Patch
M Makefile View 1 2 3 4 5 6 1 chunk +4 lines, -0 lines 0 comments Download
M build/features.gypi View 1 2 chunks +5 lines, -0 lines 0 comments Download
M include/v8.h View 1 2 3 4 5 6 7 1 chunk +8 lines, -0 lines 0 comments Download
M src/hydrogen-instructions.h View 1 2 3 4 5 6 7 1 chunk +1 line, -1 line 0 comments Download
M src/hydrogen-instructions.cc View 1 2 3 4 5 6 7 1 chunk +1 line, -1 line 0 comments Download
M src/ic.cc View 1 2 3 4 5 6 7 3 chunks +3 lines, -3 lines 0 comments Download
M src/x64/assembler-x64.h View 1 1 chunk +1 line, -0 lines 0 comments Download
M src/x64/assembler-x64.cc View 1 1 chunk +9 lines, -0 lines 0 comments Download
M src/x64/code-stubs-x64.cc View 1 2 3 4 5 6 7 16 chunks +159 lines, -62 lines 0 comments Download
M src/x64/debug-x64.cc View 1 2 3 4 5 2 chunks +2 lines, -12 lines 0 comments Download
M src/x64/deoptimizer-x64.cc View 1 1 chunk +6 lines, -0 lines 0 comments Download
M src/x64/disasm-x64.cc View 1 1 chunk +3 lines, -0 lines 0 comments Download
M src/x64/full-codegen-x64.cc View 1 2 3 4 5 6 7 2 chunks +17 lines, -4 lines 2 comments Download
M src/x64/lithium-codegen-x64.h View 1 2 3 4 5 6 7 4 chunks +4 lines, -1 line 0 comments Download
M src/x64/lithium-codegen-x64.cc View 1 2 3 4 5 6 7 17 chunks +209 lines, -37 lines 0 comments Download
M src/x64/lithium-x64.h View 1 2 3 4 5 6 1 chunk +4 lines, -2 lines 0 comments Download
M src/x64/lithium-x64.cc View 1 2 3 4 5 6 7 7 chunks +29 lines, -7 lines 0 comments Download
M src/x64/macro-assembler-x64.h View 1 2 3 4 5 6 7 10 chunks +69 lines, -25 lines 10 comments Download
M src/x64/macro-assembler-x64.cc View 1 2 3 4 5 6 7 39 chunks +760 lines, -223 lines 11 comments Download
M src/x64/stub-cache-x64.cc View 1 2 3 4 5 6 7 2 chunks +10 lines, -7 lines 0 comments Download
M test/cctest/test-log-stack-tracer.cc View 1 2 chunks +22 lines, -4 lines 0 comments Download
M test/cctest/test-macro-assembler-x64.cc View 1 2 3 4 5 6 7 15 chunks +101 lines, -52 lines 0 comments Download

Messages

Total messages: 13 (0 generated)
haitao.feng
I'd like to get your high-level feedback on this CL. The original purpose is to ...
7 years, 4 months ago (2013-07-29 07:44:37 UTC) #1
danno
Thanks for the patch. Although I don't have a fundamental problem with supporting both 31-bit ...
7 years, 4 months ago (2013-07-29 13:02:23 UTC) #2
haitao.feng
danno, thanks a lot for the review. It is much cleaner than patchset 1. https://codereview.chromium.org/21014003/diff/1/build/features.gypi ...
7 years, 4 months ago (2013-07-30 08:56:43 UTC) #3
haitao.feng
danno, thanks a lot for your review and recommendations. I think this CL is ready ...
7 years, 4 months ago (2013-08-01 03:38:04 UTC) #4
danno
This seems to be heading in the right direction, but there is a lot more ...
7 years, 4 months ago (2013-08-01 16:45:40 UTC) #5
haitao.feng
danno, thanks a lot for your review. I am glad to see I have anticipated ...
7 years, 4 months ago (2013-08-02 09:35:51 UTC) #6
haitao.feng
I rebased with master and ported the Shl for 31-bit-SMI. I introduced a class SmiFunctionInvoker ...
7 years, 4 months ago (2013-08-06 07:58:56 UTC) #7
danno
I like the fundamental concept of the SmiFunctionInvoker, but I think you can simplify it ...
7 years, 4 months ago (2013-08-07 18:41:26 UTC) #8
haitao.feng
danno, thanks a lot for the review. All the comments are addressed. Please take another ...
7 years, 4 months ago (2013-08-12 09:54:24 UTC) #9
danno
Thank you for the next patch, sorry it took so long to respond to it, ...
7 years, 4 months ago (2013-08-19 21:47:44 UTC) #10
haitao.feng
danno, thanks a lot for the review. I appreciate it. I know you are quite ...
7 years, 4 months ago (2013-08-20 15:09:30 UTC) #11
danno
Hi Haitao, Thanks for your continued iteration on this CL. I know it's a lot ...
7 years, 4 months ago (2013-08-20 15:58:14 UTC) #12
haitao.feng
7 years, 4 months ago (2013-08-21 13:18:03 UTC) #13
Hi Danno,

Thanks a lot for your comments, recommendations and guidance. I am glad that the
direction of this CL is clear after you reviewed all the codes in this CL
(including the macro assembler instruction definition and usage). I will work
incrementally to get it reviewed/committed as you have recommended.

Thanks
-Haitao

https://chromiumcodereview.appspot.com/21014003/diff/45001/src/x64/macro-asse...
File src/x64/macro-assembler-x64.cc (right):

https://chromiumcodereview.appspot.com/21014003/diff/45001/src/x64/macro-asse...
src/x64/macro-assembler-x64.cc:990: static inline Immediate SmiToImmediate(Smi*
src) {
I will use the constructor with an assertion in the future CL. A comment on the
"if" statement: it could be optimized away by gcc at static time, so there is no
additional runtime overhead for "SmiValuesAre32Bits" and "SmiValuesAre31Bits".

https://chromiumcodereview.appspot.com/21014003/diff/45001/src/x64/macro-asse...
File src/x64/macro-assembler-x64.h (right):

https://chromiumcodereview.appspot.com/21014003/diff/45001/src/x64/macro-asse...
src/x64/macro-assembler-x64.h:383: virtual bool NeedsCheckMinusZero() const = 0;
We will handle this when https://codereview.chromium.org/22600005/ is landed.
Currently the difference between Lithium and FullCodeGen/Stub when calling SMI
macro instruction is:
  1) dst and src1 are same from Lithium, and we do not need to keep src1 intact.
  2) overflow check could be omitted.
  3) minusZero check could be omitted. 

I will think about your recommendations to abstract those difference.

Powered by Google App Engine
This is Rietveld 408576698