mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 12:28:12 +00:00
LibJS/Bytecode: Don't replace the entry block in MergeBlocks
The entry block must stay in place, although it's okay to merge stuff into it. This fixes 4 test262 tests and brings us to parity with optimization disabled. :^)
This commit is contained in:
parent
5b29974bfa
commit
acd29e064c
1 changed files with 2 additions and 1 deletions
|
@ -36,7 +36,8 @@ void MergeBlocks::perform(PassPipelineExecutable& executable)
|
|||
if (entry.key->terminator()->type() != Instruction::Type::Jump)
|
||||
continue;
|
||||
|
||||
{
|
||||
// NOTE: We can't replace the first block in a function, as it's the entry block.
|
||||
if (entry.key != executable.executable.basic_blocks.first()) {
|
||||
InstructionStreamIterator it { entry.key->instruction_stream() };
|
||||
auto& first_instruction = *it;
|
||||
if (first_instruction.type() == Instruction::Type::Jump) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue