Skip to content

Replace scratch register with XOR swap #206

@bwburnsides

Description

@bwburnsides

I'm getting up to snuff on compiler backend details for a personal project and the regalloc2 overview and the follow on article have been great.

I'm not going to pretend to completely understand the details here, but the MachineEnv requires a scratch register for what I gather is typically swaps, symbolically like this.

let x = 4;
let y = 5;

let swap = x;
x = y;
y = swap;

However there is a way to swap two values without introducing a third variable/register which is via an XOR swap:

x = y ^ x;
y = x ^ y;
x = y ^ x;

You shouldn't do this in high level code but should be fine in machine code of course. If an ISA allows integer operations to be applied to float registers then this can be used for both classes.

I'm nearly certain you know of this already, but I wanted to get it out there for the off chance, and if nothing else get details on why it wouldn't work.

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions