1. 25 Nov, 2019 14 commits
  2. 24 Nov, 2019 1 commit
  3. 23 Nov, 2019 1 commit
  4. 22 Nov, 2019 21 commits
  5. 21 Nov, 2019 3 commits
    • Ng Zhi An's avatar
      [liftoff] Convert callers to use offset · aaf5c124
      Ng Zhi An authored
      This patch changes many callers of GetStackOffsetFromIndex to directly
      use the offset that is stored in the VarState (and other structures).
      
      The tricky part here is that in all archs, GetStackSlotOffset no longer
      relies on kFirstStackSlotOffset, because the offset stored in VarState
      is relative to the constant space (instance offset), and not offset of
      the first stack slot.
      
      For example, for slot 0, the offset was also 0, because it was relative
      to the first stack slot offset (which in x64 is fp-24). With this
      change, the offset of slot 0 is now 8, but since GetStackSlotOffset is
      relative to fp-16, it ends up being fp-24 still.
      
      Because of this change, callers of GetStackOffsetFromIndex need to add
      1 to whatever index they were passing. Instead of doing that, we change
      GetStackOffsetFromIndex to add 1 inside the body.
      
      After this change, the only callers of GetStackOffsetFromIndex will be
      inside of FillStackSlotsWithZero, because they still rely on index to
      keep track of how many params were processed, and also how many locals
      there are in order to zero those slots, and these is relied on by
      RecordUsedSpillSlot to allocate sufficient stack space.
      
      Bug: v8:9909
      Change-Id: I52aa4572950565a39e9395192706a9934ac296d4
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1925524
      Commit-Queue: Zhi An Ng <zhin@chromium.org>
      Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#65109}
      aaf5c124
    • Tobias Tebbi's avatar
      [torque] shape: define in-object properties properly · cfab6505
      Tobias Tebbi authored
      This introduces a new keyword "shape" in addition to "class",
      which allows the definition of a type that extends a JSObject
      subclass and specifies one or several maps with statically
      known in-object properties.
      Differences compared to normal classes:
      - Shapes are transient since they specify maps instead of
        instance types.
      - Shapes have a known size.
      - Fields of shapes are always in-object properties. In particular,
        this means that their offset is after kHeaderSize.
      - It's forbidden to inherited from shapes.
      - Since shapes usually specify NativeContext-dependent maps, it's
        not possible to write runtime type-checks for them. Thus this CL
        avoids mapping them to their own TNode type, as the CAST macro
        won't work properly. We had runtime-checks for some of them
        nevertheless, some of them scarily confusing like
        IsJSSloppyArgumentsObject, that actually just checked the instance
        type.
      
      Drive-by cleanups and simplifications:
      - Allow subclassing from non-abstract classes and remove
        @dirtyInstantiatedAbstractClass. This attribute stems from a mis-
        conception of how instance types work, and with this change it
        ceases to have semantic influence.
      - Replace the existing JSArgumentsObject subclasses into two shapes.
        JSArgumentsObjectWithLength had to be removed since shapes don't
        support subclassing.
      - Place kHeaderSize correctly for objects with indexed fields.
      
      Design doc:
      https://docs.google.com/document/d/1zPy2ZYfNFjeEuw6Mz3YJA-GaPGbdcSYam3SrS7ETzRU
      
      Bug: v8:8944
      
      Change-Id: Iabf185ccd27d0900e0890539a7fe9eaa8bf2d50e
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1917140
      Commit-Queue: Tobias Tebbi <tebbi@chromium.org>
      Reviewed-by: 's avatarNico Hartmann <nicohartmann@chromium.org>
      Reviewed-by: 's avatarJakob Gruber <jgruber@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#65108}
      cfab6505
    • Ng Zhi An's avatar
      Reland "[liftoff] Use stack slot offsets instead of indices" · d3cd2702
      Ng Zhi An authored
      This is a reland of 20727725
      
      The fix is in liftoff-assembler-arm64.h in FillStackSlotsWithZero,
      in the else case for bigger counts to fill, the argument passed to Sub
      was incorrect. We were passing offset relative to first slot, but it
      should be offset relative to instance, so there is an off by 1 slot error
      when zeroing, and ended up zeroing the stack slot holding instance.
      
      Original change's description:
      > [liftoff] Use stack slot offsets instead of indices
      >
      > Spill/fill now take offsets instead of indices. We provide a
      > helper, GetStackOffsetFromIndex, for callers. This is currently only
      > useful while slot sizes are still fixed to 8 bytes.
      >
      > StackTransferRecipe's RegisterLoad now works in terms of offset.
      >
      > LiftoffStackSlots work in terms of offset as well.
      >
      > TransferStackSlot currently still works in terms of indicies, but can be
      > converted to use offsets in a subsequent change.
      >
      > Bug: v8:9909
      > Change-Id: If54fb844309bdfd641720d063135dd59551813e0
      > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1922489
      > Reviewed-by: Clemens Backes <clemensb@chromium.org>
      > Commit-Queue: Zhi An Ng <zhin@chromium.org>
      > Cr-Commit-Position: refs/heads/master@{#65049}
      
      Bug: v8:9909
      Change-Id: I311da9d3bb1db8faf8693079177c77a7b3754243
      Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1925131Reviewed-by: 's avatarClemens Backes <clemensb@chromium.org>
      Commit-Queue: Zhi An Ng <zhin@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#65107}
      d3cd2702