• Andreas Haas's avatar
    [mips64][turbofan] Implement on-stack returns. · 461274fb
    Andreas Haas authored
    This is the implementation of crrev.com/c/766371 for mips64.
    
    Original description:
    
    Add the ability to return (multiple) return values on the stack:
    
    - Extend stack frames with a new buffer region for return slots.
      This region is located at the end of a caller's frame such that
      its slots can be indexed as caller frame slots in a callee
      (located beyond its parameters) and assigned return values.
    - Adjust stack frame constructon and deconstruction accordingly.
    - Extend linkage computation to support register plus stack returns.
    - Reserve return slots in caller frame when respective calls occur.
    - Introduce and generate architecture instructions ('peek') for
      reading back results from return slots in the caller.
    - Aggressive tests.
    - Some minor clean-up.
    
    R=v8-mips-ports@googlegroups.com
    
    Change-Id: Ia924f94367320b9062e33d35b58ccd38c8fc3ca3
    Reviewed-on: https://chromium-review.googlesource.com/842483Reviewed-by: 's avatarIvica Bogosavljevic <ivica.bogosavljevic@mips.com>
    Commit-Queue: Andreas Haas <ahaas@chromium.org>
    Cr-Commit-Position: refs/heads/master@{#50299}
    461274fb
cctest.status 16.1 KB