if vpush/vpop needs to emit multiple instructions (because of non-consecutive registers), then the emitted sequence should be: vpush list1 vpush list2 ... vpop list2 vpop list1 Subzero was emiting vpop in the wrong order: vpop list1 vpop list2 These multiple lists push/pop arise because of the way fp32 and fp64 registers are declared (s0 -> s31, d31 -> d0). This CL modifies fp64 registers so they are declared in ascending order (d0 -> d31), which fixes subzero temporarily. The appropriate fix is to change vpop to be emitted in the right order. BUG= https://bugs.chromium.org/p/nativeclient/issues/detail?id=4076 R=sehr@chromium.org, stichnot@chromium.org Review URL: https://codereview.chromium.org/1592663004 .
| Name |
Last commit
|
Last update |
|---|---|---|
| .. | ||
| add.ll | Loading commit data... | |
| and.ll | Loading commit data... | |
| asr.ll | Loading commit data... | |
| bic.ll | Loading commit data... | |
| blx.ll | Loading commit data... | |
| branch-mult-fwd.ll | Loading commit data... | |
| branch-simple.ll | Loading commit data... | |
| clz.ll | Loading commit data... | |
| cmn.ll | Loading commit data... | |
| cmp.ll | Loading commit data... | |
| dmb.ll | Loading commit data... | |
| eor.ll | Loading commit data... | |
| global-load-store.ll | Loading commit data... | |
| int-extend.ll | Loading commit data... | |
| ldr-shift.ll | Loading commit data... | |
| ldr-str-more.ll | Loading commit data... | |
| ldrex-strex.ll | Loading commit data... | |
| load-store.ll | Loading commit data... | |
| lsl.ll | Loading commit data... | |
| lsr.ll | Loading commit data... | |
| mls.ll | Loading commit data... | |
| mov-const.ll | Loading commit data... | |
| mov-imm.ll | Loading commit data... | |
| mov-reg.ll | Loading commit data... | |
| mul.ll | Loading commit data... | |
| mvn.ll | Loading commit data... | |
| orr.ll | Loading commit data... | |
| push-pop.ll | Loading commit data... | |
| rbit.ll | Loading commit data... | |
| ret.ll | Loading commit data... | |
| rev.ll | Loading commit data... | |
| rsb.ll | Loading commit data... | |
| rsc.ll | Loading commit data... | |
| sandboxing.ll | Loading commit data... | |
| sdiv.ll | Loading commit data... | |
| store-sf.ll | Loading commit data... | |
| sub.ll | Loading commit data... | |
| udiv.ll | Loading commit data... | |
| uxtb.ll | Loading commit data... | |
| vadd.ll | Loading commit data... | |
| vcmp.ll | Loading commit data... | |
| vcvt_f32_f64.ll | Loading commit data... | |
| vdiv.ll | Loading commit data... | |
| vmul.ll | Loading commit data... | |
| vpush.ll | Loading commit data... | |
| vsub.ll | Loading commit data... |