diff options
author | Mike Pall <mike> | 2010-09-10 11:34:29 +0200 |
---|---|---|
committer | Mike Pall <mike> | 2010-09-10 11:34:29 +0200 |
commit | 6fd315581c7fae86bbe57840408a249c60a691a9 (patch) | |
tree | 5ad790b1a4ef9e7e79485cbf55c6b1557073c06d | |
parent | 96957a4551a464160be2c1450f39744ac8313364 (diff) | |
download | luajit-6fd315581c7fae86bbe57840408a249c60a691a9.tar.gz luajit-6fd315581c7fae86bbe57840408a249c60a691a9.tar.bz2 luajit-6fd315581c7fae86bbe57840408a249c60a691a9.zip |
Optimize BC_VARG: use RC for numparams.
-rw-r--r-- | src/buildvm_x64.h | 216 | ||||
-rw-r--r-- | src/buildvm_x64win.h | 221 | ||||
-rw-r--r-- | src/buildvm_x86.dasc | 7 | ||||
-rw-r--r-- | src/buildvm_x86.h | 211 | ||||
-rw-r--r-- | src/lj_gc.c | 2 | ||||
-rw-r--r-- | src/lj_parse.c | 15 |
6 files changed, 333 insertions, 339 deletions
diff --git a/src/buildvm_x64.h b/src/buildvm_x64.h index 4474ae1b..05e796c4 100644 --- a/src/buildvm_x64.h +++ b/src/buildvm_x64.h | |||
@@ -12,7 +12,7 @@ | |||
12 | #define DASM_SECTION_CODE_OP 0 | 12 | #define DASM_SECTION_CODE_OP 0 |
13 | #define DASM_SECTION_CODE_SUB 1 | 13 | #define DASM_SECTION_CODE_SUB 1 |
14 | #define DASM_MAXSECTION 2 | 14 | #define DASM_MAXSECTION 2 |
15 | static const unsigned char build_actionlist[14095] = { | 15 | static const unsigned char build_actionlist[14087] = { |
16 | 254,1,248,10,252,247,195,237,15,132,244,11,131,227,252,248,41,218,72,141, | 16 | 254,1,248,10,252,247,195,237,15,132,244,11,131,227,252,248,41,218,72,141, |
17 | 76,25,252,248,139,90,252,252,199,68,10,4,237,248,12,131,192,1,137,68,36,4, | 17 | 76,25,252,248,139,90,252,252,199,68,10,4,237,248,12,131,192,1,137,68,36,4, |
18 | 252,247,195,237,15,132,244,13,248,14,129,252,243,239,252,247,195,237,15,133, | 18 | 252,247,195,237,15,132,244,13,248,14,129,252,243,239,252,247,195,237,15,133, |
@@ -641,59 +641,59 @@ static const unsigned char build_actionlist[14095] = { | |||
641 | 105,8,137,65,12,139,105,224,139,65,228,137,105,252,248,137,65,252,252,129, | 641 | 105,8,137,65,12,139,105,224,139,65,228,137,105,252,248,137,65,252,252,129, |
642 | 252,248,239,184,237,15,133,244,28,137,202,137,90,252,252,139,157,233,139, | 642 | 252,248,239,184,237,15,133,244,28,137,202,137,90,252,252,139,157,233,139, |
643 | 11,15,182,252,233,15,182,205,131,195,4,65,252,255,36,252,238,255,15,182,252, | 643 | 11,15,182,252,233,15,182,205,131,195,4,65,252,255,36,252,238,255,15,182,252, |
644 | 236,139,66,252,248,141,12,202,139,128,233,15,182,128,233,68,137,60,36,68, | 644 | 236,15,182,192,68,137,60,36,68,141,188,253,194,233,141,12,202,68,43,122,252, |
645 | 141,188,253,194,233,68,43,122,252,252,133,252,237,15,132,244,251,141,108, | 645 | 252,133,252,237,15,132,244,251,141,108,252,233,252,248,65,57,215,15,131,244, |
646 | 252,233,252,248,65,57,215,15,131,244,248,248,1,65,139,71,252,248,137,1,65, | 646 | 248,248,1,65,139,71,252,248,137,1,65,139,71,252,252,65,131,199,8,137,65,4, |
647 | 139,71,252,252,65,131,199,8,137,65,4,131,193,8,57,252,233,15,131,244,249, | 647 | 131,193,8,57,252,233,15,131,244,249,65,57,215,15,130,244,1,248,2,199,65,4, |
648 | 65,57,215,15,130,244,1,248,2,199,65,4,237,131,193,8,57,252,233,15,130,244, | 648 | 237,131,193,8,57,252,233,15,130,244,2,248,3,68,139,60,36,139,3,15,182,204, |
649 | 2,248,3,68,139,60,36,139,3,15,182,204,15,182,232,131,195,4,193,232,16,65, | 649 | 15,182,232,131,195,4,193,232,16,65,252,255,36,252,238,248,5,199,68,36,4,1, |
650 | 252,255,36,252,238,248,5,199,68,36,4,1,0,0,0,137,208,68,41,252,248,15,134, | 650 | 0,0,0,137,208,68,41,252,248,15,134,244,3,137,197,193,252,237,3,131,197,1, |
651 | 244,3,255,137,197,193,252,237,3,131,197,1,137,108,36,4,139,108,36,24,1,200, | 651 | 137,108,36,4,139,108,36,24,1,200,59,133,233,15,135,244,253,248,6,255,65,139, |
652 | 59,133,233,15,135,244,253,248,6,65,139,71,252,248,137,1,65,139,71,252,252, | 652 | 71,252,248,137,1,65,139,71,252,252,65,131,199,8,137,65,4,131,193,8,65,57, |
653 | 65,131,199,8,137,65,4,131,193,8,65,57,215,15,130,244,6,252,233,244,3,248, | 653 | 215,15,130,244,6,252,233,244,3,248,7,137,149,233,137,141,233,137,92,36,28, |
654 | 7,137,149,233,137,141,233,137,92,36,28,65,41,215,139,116,36,4,131,252,238, | 654 | 65,41,215,139,116,36,4,131,252,238,1,137,252,239,232,251,1,0,139,149,233, |
655 | 1,137,252,239,232,251,1,0,139,149,233,139,141,233,65,1,215,252,233,244,6, | 655 | 139,141,233,65,1,215,252,233,244,6,255,193,225,3,255,248,1,139,90,252,252, |
656 | 255,193,225,3,255,248,1,139,90,252,252,137,68,36,4,252,247,195,237,15,133, | 656 | 137,68,36,4,252,247,195,237,15,133,244,253,255,248,13,65,137,215,131,232, |
657 | 244,253,255,248,13,65,137,215,131,232,1,15,132,244,249,248,2,65,139,44,15, | 657 | 1,15,132,244,249,248,2,65,139,44,15,65,137,111,252,248,65,139,108,15,4,65, |
658 | 65,137,111,252,248,65,139,108,15,4,65,137,111,252,252,65,131,199,8,131,232, | 658 | 137,111,252,252,65,131,199,8,131,232,1,15,133,244,2,248,3,139,68,36,4,15, |
659 | 1,15,133,244,2,248,3,139,68,36,4,15,182,107,252,255,248,5,57,197,15,135,244, | 659 | 182,107,252,255,248,5,57,197,15,135,244,252,255,139,108,10,4,137,106,252, |
660 | 252,255,139,108,10,4,137,106,252,252,139,44,10,137,106,252,248,255,248,5, | 660 | 252,139,44,10,137,106,252,248,255,248,5,56,67,252,255,15,135,244,252,255, |
661 | 56,67,252,255,15,135,244,252,255,15,182,75,252,253,72,252,247,209,141,20, | 661 | 15,182,75,252,253,72,252,247,209,141,20,202,68,139,122,252,248,69,139,191, |
662 | 202,68,139,122,252,248,69,139,191,233,69,139,191,233,139,3,15,182,204,15, | 662 | 233,69,139,191,233,139,3,15,182,204,15,182,232,131,195,4,193,232,16,65,252, |
663 | 182,232,131,195,4,193,232,16,65,252,255,36,252,238,248,6,255,65,199,71,252, | 663 | 255,36,252,238,248,6,255,65,199,71,252,252,237,65,131,199,8,255,199,68,194, |
664 | 252,237,65,131,199,8,255,199,68,194,252,244,237,255,131,192,1,252,233,244, | 664 | 252,244,237,255,131,192,1,252,233,244,5,248,7,141,171,233,252,247,197,237, |
665 | 5,248,7,141,171,233,252,247,197,237,15,133,244,14,41,252,234,255,1,252,233, | 665 | 15,133,244,14,41,252,234,255,1,252,233,255,137,221,209,252,237,129,229,239, |
666 | 255,137,221,209,252,237,129,229,239,102,65,131,172,253,46,233,1,15,132,244, | 666 | 102,65,131,172,253,46,233,1,15,132,244,140,255,141,12,202,255,129,121,253, |
667 | 140,255,141,12,202,255,129,121,253,4,239,15,135,244,53,129,121,253,12,239, | 667 | 4,239,15,135,244,53,129,121,253,12,239,15,135,244,53,255,139,105,20,255,129, |
668 | 15,135,244,53,255,139,105,20,255,129,252,253,239,15,135,244,53,255,252,242, | 668 | 252,253,239,15,135,244,53,255,252,242,15,16,1,252,242,15,16,73,8,255,252, |
669 | 15,16,1,252,242,15,16,73,8,255,252,242,15,88,65,16,252,242,15,17,1,133,252, | 669 | 242,15,88,65,16,252,242,15,17,1,133,252,237,15,136,244,249,255,15,140,244, |
670 | 237,15,136,244,249,255,15,140,244,249,255,102,15,46,200,248,1,252,242,15, | 670 | 249,255,102,15,46,200,248,1,252,242,15,17,65,24,255,221,65,8,221,1,255,220, |
671 | 17,65,24,255,221,65,8,221,1,255,220,65,16,221,17,221,81,24,133,252,237,15, | 671 | 65,16,221,17,221,81,24,133,252,237,15,136,244,247,255,221,81,24,15,140,244, |
672 | 136,244,247,255,221,81,24,15,140,244,247,255,217,201,248,1,255,15,183,67, | 672 | 247,255,217,201,248,1,255,15,183,67,252,254,255,15,131,244,248,141,156,253, |
673 | 252,254,255,15,131,244,248,141,156,253,131,233,255,141,156,253,131,233,15, | 673 | 131,233,255,141,156,253,131,233,15,183,67,252,254,15,131,245,255,15,130,244, |
674 | 183,67,252,254,15,131,245,255,15,130,244,248,141,156,253,131,233,255,248, | 674 | 248,141,156,253,131,233,255,248,3,102,15,46,193,252,233,244,1,255,141,12, |
675 | 3,102,15,46,193,252,233,244,1,255,141,12,202,139,105,4,129,252,253,239,15, | 675 | 202,139,105,4,129,252,253,239,15,132,244,247,255,137,105,252,252,139,41,137, |
676 | 132,244,247,255,137,105,252,252,139,41,137,105,252,248,252,233,245,255,141, | 676 | 105,252,248,252,233,245,255,141,156,253,131,233,139,1,137,105,252,252,137, |
677 | 156,253,131,233,139,1,137,105,252,252,137,65,252,248,255,65,139,142,233,139, | 677 | 65,252,248,255,65,139,142,233,139,4,129,72,139,128,233,139,108,36,24,65,137, |
678 | 4,129,72,139,128,233,139,108,36,24,65,137,150,233,65,137,174,233,76,137,36, | 678 | 150,233,65,137,174,233,76,137,36,36,76,137,108,36,8,72,131,252,236,16,252, |
679 | 36,76,137,108,36,8,72,131,252,236,16,252,255,224,255,141,156,253,131,233, | 679 | 255,224,255,141,156,253,131,233,139,3,15,182,204,15,182,232,131,195,4,193, |
680 | 139,3,15,182,204,15,182,232,131,195,4,193,232,16,65,252,255,36,252,238,255, | 680 | 232,16,65,252,255,36,252,238,255,137,221,209,252,237,129,229,239,102,65,131, |
681 | 137,221,209,252,237,129,229,239,102,65,131,172,253,46,233,1,15,132,244,142, | 681 | 172,253,46,233,1,15,132,244,142,255,68,139,187,233,139,108,36,24,141,12,202, |
682 | 255,68,139,187,233,139,108,36,24,141,12,202,59,141,233,15,135,244,23,15,182, | 682 | 59,141,233,15,135,244,23,15,182,139,233,57,200,15,134,244,249,248,2,255,15, |
683 | 139,233,57,200,15,134,244,249,248,2,255,15,183,67,252,254,252,233,245,255, | 683 | 183,67,252,254,252,233,245,255,248,3,199,68,194,252,252,237,131,192,1,57, |
684 | 248,3,199,68,194,252,252,237,131,192,1,57,200,15,134,244,3,252,233,244,2, | 684 | 200,15,134,244,3,252,233,244,2,255,141,44,197,237,141,4,194,68,139,122,252, |
685 | 255,141,44,197,237,141,4,194,68,139,122,252,248,137,104,252,252,68,137,120, | 685 | 248,137,104,252,252,68,137,120,252,248,139,108,36,24,141,12,200,59,141,233, |
686 | 252,248,139,108,36,24,141,12,200,59,141,233,15,135,244,22,137,209,137,194, | 686 | 15,135,244,22,137,209,137,194,15,182,171,233,133,252,237,15,132,244,248,248, |
687 | 15,182,171,233,133,252,237,15,132,244,248,248,1,131,193,8,57,209,15,131,244, | 687 | 1,131,193,8,57,209,15,131,244,249,68,139,121,252,248,68,137,56,68,139,121, |
688 | 249,68,139,121,252,248,68,137,56,68,139,121,252,252,68,137,120,4,131,192, | 688 | 252,252,68,137,120,4,131,192,8,199,65,252,252,237,131,252,237,1,15,133,244, |
689 | 8,199,65,252,252,237,131,252,237,1,15,133,244,1,248,2,255,68,139,187,233, | 689 | 1,248,2,255,68,139,187,233,139,3,15,182,204,15,182,232,131,195,4,193,232, |
690 | 139,3,15,182,204,15,182,232,131,195,4,193,232,16,65,252,255,36,252,238,255, | 690 | 16,65,252,255,36,252,238,255,248,3,199,64,4,237,131,192,8,131,252,237,1,15, |
691 | 248,3,199,64,4,237,131,192,8,131,252,237,1,15,133,244,3,252,233,244,2,255, | 691 | 133,244,3,252,233,244,2,255,139,106,252,248,76,139,189,233,139,108,36,24, |
692 | 139,106,252,248,76,139,189,233,139,108,36,24,141,68,194,252,248,137,149,233, | 692 | 141,68,194,252,248,137,149,233,141,136,233,59,141,233,137,133,233,255,137, |
693 | 141,136,233,59,141,233,137,133,233,255,137,252,239,255,76,137,252,254,137, | 693 | 252,239,255,76,137,252,254,137,252,239,255,15,135,244,21,65,199,134,233,237, |
694 | 252,239,255,15,135,244,21,65,199,134,233,237,255,65,252,255,215,255,65,252, | 694 | 255,65,252,255,215,255,65,252,255,150,233,255,65,199,134,233,237,139,149, |
695 | 255,150,233,255,65,199,134,233,237,139,149,233,141,12,194,252,247,217,3,141, | 695 | 233,141,12,194,252,247,217,3,141,233,139,90,252,252,252,233,244,12,255,254, |
696 | 233,139,90,252,252,252,233,244,12,255,254,0 | 696 | 0 |
697 | }; | 697 | }; |
698 | 698 | ||
699 | enum { | 699 | enum { |
@@ -1989,8 +1989,8 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
1989 | break; | 1989 | break; |
1990 | 1990 | ||
1991 | case BC_VARG: | 1991 | case BC_VARG: |
1992 | dasm_put(Dst, 13006, Dt7(->pc), PC2PROTO(numparams), (8+FRAME_VARG), LJ_TNIL); | 1992 | dasm_put(Dst, 13006, (8+FRAME_VARG), LJ_TNIL, Dt1(->maxstack)); |
1993 | dasm_put(Dst, 13160, Dt1(->maxstack), Dt1(->base), Dt1(->top), Dt1(->base), Dt1(->top)); | 1993 | dasm_put(Dst, 13180, Dt1(->base), Dt1(->top), Dt1(->base), Dt1(->top)); |
1994 | break; | 1994 | break; |
1995 | 1995 | ||
1996 | /* -- Returns ----------------------------------------------------------- */ | 1996 | /* -- Returns ----------------------------------------------------------- */ |
@@ -2001,30 +2001,30 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2001 | 2001 | ||
2002 | case BC_RET: case BC_RET0: case BC_RET1: | 2002 | case BC_RET: case BC_RET0: case BC_RET1: |
2003 | if (op != BC_RET0) { | 2003 | if (op != BC_RET0) { |
2004 | dasm_put(Dst, 13265); | 2004 | dasm_put(Dst, 13257); |
2005 | } | 2005 | } |
2006 | dasm_put(Dst, 13269, FRAME_TYPE); | 2006 | dasm_put(Dst, 13261, FRAME_TYPE); |
2007 | switch (op) { | 2007 | switch (op) { |
2008 | case BC_RET: | 2008 | case BC_RET: |
2009 | dasm_put(Dst, 13288); | 2009 | dasm_put(Dst, 13280); |
2010 | break; | 2010 | break; |
2011 | case BC_RET1: | 2011 | case BC_RET1: |
2012 | dasm_put(Dst, 13352); | 2012 | dasm_put(Dst, 13344); |
2013 | /* fallthrough */ | 2013 | /* fallthrough */ |
2014 | case BC_RET0: | 2014 | case BC_RET0: |
2015 | dasm_put(Dst, 13368); | 2015 | dasm_put(Dst, 13360); |
2016 | default: | 2016 | default: |
2017 | break; | 2017 | break; |
2018 | } | 2018 | } |
2019 | dasm_put(Dst, 13379, Dt7(->pc), PC2PROTO(k)); | 2019 | dasm_put(Dst, 13371, Dt7(->pc), PC2PROTO(k)); |
2020 | if (op == BC_RET) { | 2020 | if (op == BC_RET) { |
2021 | dasm_put(Dst, 13427, LJ_TNIL); | 2021 | dasm_put(Dst, 13419, LJ_TNIL); |
2022 | } else { | 2022 | } else { |
2023 | dasm_put(Dst, 13438, LJ_TNIL); | 2023 | dasm_put(Dst, 13430, LJ_TNIL); |
2024 | } | 2024 | } |
2025 | dasm_put(Dst, 13445, -FRAME_VARG, FRAME_TYPEP); | 2025 | dasm_put(Dst, 13437, -FRAME_VARG, FRAME_TYPEP); |
2026 | if (op != BC_RET0) { | 2026 | if (op != BC_RET0) { |
2027 | dasm_put(Dst, 13469); | 2027 | dasm_put(Dst, 13461); |
2028 | } | 2028 | } |
2029 | dasm_put(Dst, 4599); | 2029 | dasm_put(Dst, 4599); |
2030 | break; | 2030 | break; |
@@ -2034,7 +2034,7 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2034 | 2034 | ||
2035 | case BC_FORL: | 2035 | case BC_FORL: |
2036 | #if LJ_HASJIT | 2036 | #if LJ_HASJIT |
2037 | dasm_put(Dst, 13473, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2037 | dasm_put(Dst, 13465, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2038 | #endif | 2038 | #endif |
2039 | break; | 2039 | break; |
2040 | 2040 | ||
@@ -2046,57 +2046,57 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2046 | case BC_FORI: | 2046 | case BC_FORI: |
2047 | case BC_IFORL: | 2047 | case BC_IFORL: |
2048 | vk = (op == BC_IFORL || op == BC_JFORL); | 2048 | vk = (op == BC_IFORL || op == BC_JFORL); |
2049 | dasm_put(Dst, 13494); | 2049 | dasm_put(Dst, 13486); |
2050 | if (!vk) { | 2050 | if (!vk) { |
2051 | dasm_put(Dst, 13498, LJ_TISNUM, LJ_TISNUM); | 2051 | dasm_put(Dst, 13490, LJ_TISNUM, LJ_TISNUM); |
2052 | } | 2052 | } |
2053 | dasm_put(Dst, 13517); | 2053 | dasm_put(Dst, 13509); |
2054 | if (!vk) { | 2054 | if (!vk) { |
2055 | dasm_put(Dst, 13521, LJ_TISNUM); | 2055 | dasm_put(Dst, 13513, LJ_TISNUM); |
2056 | } | 2056 | } |
2057 | if (sse) { | 2057 | if (sse) { |
2058 | dasm_put(Dst, 13530); | 2058 | dasm_put(Dst, 13522); |
2059 | if (vk) { | 2059 | if (vk) { |
2060 | dasm_put(Dst, 13542); | 2060 | dasm_put(Dst, 13534); |
2061 | } else { | 2061 | } else { |
2062 | dasm_put(Dst, 13561); | 2062 | dasm_put(Dst, 13553); |
2063 | } | 2063 | } |
2064 | dasm_put(Dst, 13566); | 2064 | dasm_put(Dst, 13558); |
2065 | } else { | 2065 | } else { |
2066 | dasm_put(Dst, 13579); | 2066 | dasm_put(Dst, 13571); |
2067 | if (vk) { | 2067 | if (vk) { |
2068 | dasm_put(Dst, 13585); | 2068 | dasm_put(Dst, 13577); |
2069 | } else { | 2069 | } else { |
2070 | dasm_put(Dst, 13601); | 2070 | dasm_put(Dst, 13593); |
2071 | } | 2071 | } |
2072 | dasm_put(Dst, 13609); | 2072 | dasm_put(Dst, 13601); |
2073 | if (cmov) { | 2073 | if (cmov) { |
2074 | dasm_put(Dst, 9528); | 2074 | dasm_put(Dst, 9528); |
2075 | } else { | 2075 | } else { |
2076 | dasm_put(Dst, 9534); | 2076 | dasm_put(Dst, 9534); |
2077 | } | 2077 | } |
2078 | if (!cmov) { | 2078 | if (!cmov) { |
2079 | dasm_put(Dst, 13614); | 2079 | dasm_put(Dst, 13606); |
2080 | } | 2080 | } |
2081 | } | 2081 | } |
2082 | if (op == BC_FORI) { | 2082 | if (op == BC_FORI) { |
2083 | dasm_put(Dst, 13620, -BCBIAS_J*4); | 2083 | dasm_put(Dst, 13612, -BCBIAS_J*4); |
2084 | } else if (op == BC_JFORI) { | 2084 | } else if (op == BC_JFORI) { |
2085 | dasm_put(Dst, 13630, -BCBIAS_J*4, BC_JLOOP); | 2085 | dasm_put(Dst, 13622, -BCBIAS_J*4, BC_JLOOP); |
2086 | } else if (op == BC_IFORL) { | 2086 | } else if (op == BC_IFORL) { |
2087 | dasm_put(Dst, 13644, -BCBIAS_J*4); | 2087 | dasm_put(Dst, 13636, -BCBIAS_J*4); |
2088 | } else { | 2088 | } else { |
2089 | dasm_put(Dst, 13640, BC_JLOOP); | 2089 | dasm_put(Dst, 13632, BC_JLOOP); |
2090 | } | 2090 | } |
2091 | dasm_put(Dst, 9563); | 2091 | dasm_put(Dst, 9563); |
2092 | if (sse) { | 2092 | if (sse) { |
2093 | dasm_put(Dst, 13654); | 2093 | dasm_put(Dst, 13646); |
2094 | } | 2094 | } |
2095 | break; | 2095 | break; |
2096 | 2096 | ||
2097 | case BC_ITERL: | 2097 | case BC_ITERL: |
2098 | #if LJ_HASJIT | 2098 | #if LJ_HASJIT |
2099 | dasm_put(Dst, 13473, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2099 | dasm_put(Dst, 13465, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2100 | #endif | 2100 | #endif |
2101 | break; | 2101 | break; |
2102 | 2102 | ||
@@ -2105,18 +2105,18 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2105 | break; | 2105 | break; |
2106 | #endif | 2106 | #endif |
2107 | case BC_IITERL: | 2107 | case BC_IITERL: |
2108 | dasm_put(Dst, 13665, LJ_TNIL); | 2108 | dasm_put(Dst, 13657, LJ_TNIL); |
2109 | if (op == BC_JITERL) { | 2109 | if (op == BC_JITERL) { |
2110 | dasm_put(Dst, 13680, BC_JLOOP); | 2110 | dasm_put(Dst, 13672, BC_JLOOP); |
2111 | } else { | 2111 | } else { |
2112 | dasm_put(Dst, 13694, -BCBIAS_J*4); | 2112 | dasm_put(Dst, 13686, -BCBIAS_J*4); |
2113 | } | 2113 | } |
2114 | dasm_put(Dst, 9867); | 2114 | dasm_put(Dst, 9867); |
2115 | break; | 2115 | break; |
2116 | 2116 | ||
2117 | case BC_LOOP: | 2117 | case BC_LOOP: |
2118 | #if LJ_HASJIT | 2118 | #if LJ_HASJIT |
2119 | dasm_put(Dst, 13473, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2119 | dasm_put(Dst, 13465, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2120 | #endif | 2120 | #endif |
2121 | break; | 2121 | break; |
2122 | 2122 | ||
@@ -2126,12 +2126,12 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2126 | 2126 | ||
2127 | case BC_JLOOP: | 2127 | case BC_JLOOP: |
2128 | #if LJ_HASJIT | 2128 | #if LJ_HASJIT |
2129 | dasm_put(Dst, 13710, DISPATCH_J(trace), DtD(->mcode), DISPATCH_GL(jit_base), DISPATCH_GL(jit_L)); | 2129 | dasm_put(Dst, 13702, DISPATCH_J(trace), DtD(->mcode), DISPATCH_GL(jit_base), DISPATCH_GL(jit_L)); |
2130 | #endif | 2130 | #endif |
2131 | break; | 2131 | break; |
2132 | 2132 | ||
2133 | case BC_JMP: | 2133 | case BC_JMP: |
2134 | dasm_put(Dst, 13751, -BCBIAS_J*4); | 2134 | dasm_put(Dst, 13743, -BCBIAS_J*4); |
2135 | break; | 2135 | break; |
2136 | 2136 | ||
2137 | /* -- Function headers -------------------------------------------------- */ | 2137 | /* -- Function headers -------------------------------------------------- */ |
@@ -2145,7 +2145,7 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2145 | 2145 | ||
2146 | case BC_FUNCF: | 2146 | case BC_FUNCF: |
2147 | #if LJ_HASJIT | 2147 | #if LJ_HASJIT |
2148 | dasm_put(Dst, 13777, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2148 | dasm_put(Dst, 13769, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2149 | #endif | 2149 | #endif |
2150 | case BC_FUNCV: /* NYI: compiled vararg functions. */ | 2150 | case BC_FUNCV: /* NYI: compiled vararg functions. */ |
2151 | break; | 2151 | break; |
@@ -2155,13 +2155,13 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2155 | break; | 2155 | break; |
2156 | #endif | 2156 | #endif |
2157 | case BC_IFUNCF: | 2157 | case BC_IFUNCF: |
2158 | dasm_put(Dst, 13798, -4+PC2PROTO(k), Dt1(->maxstack), -4+PC2PROTO(numparams)); | 2158 | dasm_put(Dst, 13790, -4+PC2PROTO(k), Dt1(->maxstack), -4+PC2PROTO(numparams)); |
2159 | if (op == BC_JFUNCF) { | 2159 | if (op == BC_JFUNCF) { |
2160 | dasm_put(Dst, 13829, BC_JLOOP); | 2160 | dasm_put(Dst, 13821, BC_JLOOP); |
2161 | } else { | 2161 | } else { |
2162 | dasm_put(Dst, 9565); | 2162 | dasm_put(Dst, 9565); |
2163 | } | 2163 | } |
2164 | dasm_put(Dst, 13838, LJ_TNIL); | 2164 | dasm_put(Dst, 13830, LJ_TNIL); |
2165 | break; | 2165 | break; |
2166 | 2166 | ||
2167 | case BC_JFUNCV: | 2167 | case BC_JFUNCV: |
@@ -2172,30 +2172,30 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2172 | break; /* NYI: compiled vararg functions. */ | 2172 | break; /* NYI: compiled vararg functions. */ |
2173 | 2173 | ||
2174 | case BC_IFUNCV: | 2174 | case BC_IFUNCV: |
2175 | dasm_put(Dst, 13860, FRAME_VARG, Dt1(->maxstack), -4+PC2PROTO(numparams), LJ_TNIL); | 2175 | dasm_put(Dst, 13852, FRAME_VARG, Dt1(->maxstack), -4+PC2PROTO(numparams), LJ_TNIL); |
2176 | if (op == BC_JFUNCV) { | 2176 | if (op == BC_JFUNCV) { |
2177 | dasm_put(Dst, 13829, BC_JLOOP); | 2177 | dasm_put(Dst, 13821, BC_JLOOP); |
2178 | } else { | 2178 | } else { |
2179 | dasm_put(Dst, 13957, -4+PC2PROTO(k)); | 2179 | dasm_put(Dst, 13949, -4+PC2PROTO(k)); |
2180 | } | 2180 | } |
2181 | dasm_put(Dst, 13982, LJ_TNIL); | 2181 | dasm_put(Dst, 13974, LJ_TNIL); |
2182 | break; | 2182 | break; |
2183 | 2183 | ||
2184 | case BC_FUNCC: | 2184 | case BC_FUNCC: |
2185 | case BC_FUNCCW: | 2185 | case BC_FUNCCW: |
2186 | dasm_put(Dst, 14004, Dt8(->f), Dt1(->base), 8*LUA_MINSTACK, Dt1(->maxstack), Dt1(->top)); | 2186 | dasm_put(Dst, 13996, Dt8(->f), Dt1(->base), 8*LUA_MINSTACK, Dt1(->maxstack), Dt1(->top)); |
2187 | if (op == BC_FUNCC) { | 2187 | if (op == BC_FUNCC) { |
2188 | dasm_put(Dst, 14034); | 2188 | dasm_put(Dst, 14026); |
2189 | } else { | 2189 | } else { |
2190 | dasm_put(Dst, 14038); | 2190 | dasm_put(Dst, 14030); |
2191 | } | 2191 | } |
2192 | dasm_put(Dst, 14046, DISPATCH_GL(vmstate), ~LJ_VMST_C); | 2192 | dasm_put(Dst, 14038, DISPATCH_GL(vmstate), ~LJ_VMST_C); |
2193 | if (op == BC_FUNCC) { | 2193 | if (op == BC_FUNCC) { |
2194 | dasm_put(Dst, 14056); | 2194 | dasm_put(Dst, 14048); |
2195 | } else { | 2195 | } else { |
2196 | dasm_put(Dst, 14061, DISPATCH_GL(wrapf)); | 2196 | dasm_put(Dst, 14053, DISPATCH_GL(wrapf)); |
2197 | } | 2197 | } |
2198 | dasm_put(Dst, 14067, DISPATCH_GL(vmstate), ~LJ_VMST_INTERP, Dt1(->base), Dt1(->top)); | 2198 | dasm_put(Dst, 14059, DISPATCH_GL(vmstate), ~LJ_VMST_INTERP, Dt1(->base), Dt1(->top)); |
2199 | break; | 2199 | break; |
2200 | 2200 | ||
2201 | /* ---------------------------------------------------------------------- */ | 2201 | /* ---------------------------------------------------------------------- */ |
@@ -2223,7 +2223,7 @@ static int build_backend(BuildCtx *ctx) | |||
2223 | 2223 | ||
2224 | build_subroutines(ctx, cmov, sse); | 2224 | build_subroutines(ctx, cmov, sse); |
2225 | 2225 | ||
2226 | dasm_put(Dst, 14093); | 2226 | dasm_put(Dst, 14085); |
2227 | for (op = 0; op < BC__MAX; op++) | 2227 | for (op = 0; op < BC__MAX; op++) |
2228 | build_ins(ctx, (BCOp)op, op, cmov, sse); | 2228 | build_ins(ctx, (BCOp)op, op, cmov, sse); |
2229 | 2229 | ||
diff --git a/src/buildvm_x64win.h b/src/buildvm_x64win.h index 87f72a79..f6cc6567 100644 --- a/src/buildvm_x64win.h +++ b/src/buildvm_x64win.h | |||
@@ -12,7 +12,7 @@ | |||
12 | #define DASM_SECTION_CODE_OP 0 | 12 | #define DASM_SECTION_CODE_OP 0 |
13 | #define DASM_SECTION_CODE_SUB 1 | 13 | #define DASM_SECTION_CODE_SUB 1 |
14 | #define DASM_MAXSECTION 2 | 14 | #define DASM_MAXSECTION 2 |
15 | static const unsigned char build_actionlist[14042] = { | 15 | static const unsigned char build_actionlist[14034] = { |
16 | 254,1,248,10,252,247,198,237,15,132,244,11,131,230,252,248,41,252,242,72, | 16 | 254,1,248,10,252,247,198,237,15,132,244,11,131,230,252,248,41,252,242,72, |
17 | 141,76,49,252,248,139,114,252,252,199,68,10,4,237,248,12,131,192,1,137,68, | 17 | 141,76,49,252,248,139,114,252,252,199,68,10,4,237,248,12,131,192,1,137,68, |
18 | 36,84,252,247,198,237,15,132,244,13,248,14,129,252,246,239,252,247,198,237, | 18 | 36,84,252,247,198,237,15,132,244,13,248,14,129,252,246,239,252,247,198,237, |
@@ -640,62 +640,61 @@ static const unsigned char build_actionlist[14042] = { | |||
640 | 252,236,137,41,137,65,4,139,105,252,240,139,65,252,244,137,105,8,137,65,12, | 640 | 252,236,137,41,137,65,4,139,105,252,240,139,65,252,244,137,105,8,137,65,12, |
641 | 139,105,224,139,65,228,137,105,252,248,137,65,252,252,129,252,248,239,184, | 641 | 139,105,224,139,65,228,137,105,252,248,137,65,252,252,129,252,248,239,184, |
642 | 237,15,133,244,28,137,202,137,114,252,252,139,181,233,139,14,15,182,252,233, | 642 | 237,15,133,244,28,137,202,137,114,252,252,139,181,233,139,14,15,182,252,233, |
643 | 15,182,205,131,198,4,252,255,36,252,235,255,15,182,252,236,139,66,252,248, | 643 | 15,182,205,131,198,4,252,255,36,252,235,255,15,182,252,236,15,182,192,137, |
644 | 141,12,202,139,128,233,15,182,128,233,137,124,36,80,141,188,253,194,233,43, | 644 | 124,36,80,141,188,253,194,233,141,12,202,43,122,252,252,133,252,237,15,132, |
645 | 122,252,252,133,252,237,15,132,244,251,141,108,252,233,252,248,57,215,15, | 645 | 244,251,141,108,252,233,252,248,57,215,15,131,244,248,248,1,139,71,252,248, |
646 | 131,244,248,248,1,139,71,252,248,137,1,139,71,252,252,131,199,8,137,65,4, | 646 | 137,1,139,71,252,252,131,199,8,137,65,4,131,193,8,57,252,233,15,131,244,249, |
647 | 131,193,8,57,252,233,15,131,244,249,57,215,15,130,244,1,248,2,199,65,4,237, | 647 | 57,215,15,130,244,1,248,2,199,65,4,237,131,193,8,57,252,233,15,130,244,2, |
648 | 131,193,8,57,252,233,15,130,244,2,248,3,139,124,36,80,139,6,15,182,204,15, | 648 | 248,3,139,124,36,80,139,6,15,182,204,15,182,232,131,198,4,193,232,16,252, |
649 | 182,232,131,198,4,193,232,16,252,255,36,252,235,248,5,199,68,36,84,1,0,0, | 649 | 255,36,252,235,248,5,199,68,36,84,1,0,0,0,137,208,41,252,248,15,134,244,3, |
650 | 0,137,208,41,252,248,15,134,244,3,255,137,197,193,252,237,3,131,197,1,137, | 650 | 137,197,193,252,237,3,131,197,1,137,108,36,84,139,108,36,96,1,200,59,133, |
651 | 108,36,84,139,108,36,96,1,200,59,133,233,15,135,244,253,248,6,139,71,252, | 651 | 233,15,135,244,253,248,6,255,139,71,252,248,137,1,139,71,252,252,131,199, |
652 | 248,137,1,139,71,252,252,131,199,8,137,65,4,131,193,8,57,215,15,130,244,6, | 652 | 8,137,65,4,131,193,8,57,215,15,130,244,6,252,233,244,3,248,7,137,149,233, |
653 | 252,233,244,3,248,7,137,149,233,137,141,233,137,116,36,100,41,215,139,84, | 653 | 137,141,233,137,116,36,100,41,215,139,84,36,84,131,252,234,1,137,252,233, |
654 | 36,84,131,252,234,1,137,252,233,232,251,1,0,139,149,233,139,141,233,1,215, | 654 | 232,251,1,0,139,149,233,139,141,233,1,215,252,233,244,6,255,193,225,3,255, |
655 | 252,233,244,6,255,193,225,3,255,248,1,139,114,252,252,137,68,36,84,252,247, | 655 | 248,1,139,114,252,252,137,68,36,84,252,247,198,237,15,133,244,253,255,248, |
656 | 198,237,15,133,244,253,255,248,13,137,215,131,232,1,15,132,244,249,248,2, | 656 | 13,137,215,131,232,1,15,132,244,249,248,2,139,44,15,137,111,252,248,139,108, |
657 | 139,44,15,137,111,252,248,139,108,15,4,137,111,252,252,131,199,8,131,232, | 657 | 15,4,137,111,252,252,131,199,8,131,232,1,15,133,244,2,248,3,139,68,36,84, |
658 | 1,15,133,244,2,248,3,139,68,36,84,15,182,110,252,255,248,5,57,197,15,135, | 658 | 15,182,110,252,255,248,5,57,197,15,135,244,252,255,139,108,10,4,137,106,252, |
659 | 244,252,255,139,108,10,4,137,106,252,252,139,44,10,137,106,252,248,255,248, | 659 | 252,139,44,10,137,106,252,248,255,248,5,56,70,252,255,15,135,244,252,255, |
660 | 5,56,70,252,255,15,135,244,252,255,15,182,78,252,253,72,252,247,209,141,20, | 660 | 15,182,78,252,253,72,252,247,209,141,20,202,139,122,252,248,139,191,233,139, |
661 | 202,139,122,252,248,139,191,233,139,191,233,139,6,15,182,204,15,182,232,131, | 661 | 191,233,139,6,15,182,204,15,182,232,131,198,4,193,232,16,252,255,36,252,235, |
662 | 198,4,193,232,16,252,255,36,252,235,248,6,255,199,71,252,252,237,131,199, | 662 | 248,6,255,199,71,252,252,237,131,199,8,255,199,68,194,252,244,237,255,131, |
663 | 8,255,199,68,194,252,244,237,255,131,192,1,252,233,244,5,248,7,141,174,233, | 663 | 192,1,252,233,244,5,248,7,141,174,233,252,247,197,237,15,133,244,14,41,252, |
664 | 252,247,197,237,15,133,244,14,41,252,234,255,1,252,233,255,137,252,245,209, | 664 | 234,255,1,252,233,255,137,252,245,209,252,237,129,229,239,102,131,172,253, |
665 | 252,237,129,229,239,102,131,172,253,43,233,1,15,132,244,140,255,141,12,202, | 665 | 43,233,1,15,132,244,140,255,141,12,202,255,129,121,253,4,239,15,135,244,53, |
666 | 255,129,121,253,4,239,15,135,244,53,129,121,253,12,239,15,135,244,53,255, | 666 | 129,121,253,12,239,15,135,244,53,255,139,105,20,255,129,252,253,239,15,135, |
667 | 139,105,20,255,129,252,253,239,15,135,244,53,255,252,242,15,16,1,252,242, | 667 | 244,53,255,252,242,15,16,1,252,242,15,16,73,8,255,252,242,15,88,65,16,252, |
668 | 15,16,73,8,255,252,242,15,88,65,16,252,242,15,17,1,133,252,237,15,136,244, | 668 | 242,15,17,1,133,252,237,15,136,244,249,255,15,140,244,249,255,102,15,46,200, |
669 | 249,255,15,140,244,249,255,102,15,46,200,248,1,252,242,15,17,65,24,255,221, | 669 | 248,1,252,242,15,17,65,24,255,221,65,8,221,1,255,220,65,16,221,17,221,81, |
670 | 65,8,221,1,255,220,65,16,221,17,221,81,24,133,252,237,15,136,244,247,255, | 670 | 24,133,252,237,15,136,244,247,255,221,81,24,15,140,244,247,255,217,201,248, |
671 | 221,81,24,15,140,244,247,255,217,201,248,1,255,15,183,70,252,254,255,15,131, | 671 | 1,255,15,183,70,252,254,255,15,131,244,248,141,180,253,134,233,255,141,180, |
672 | 244,248,141,180,253,134,233,255,141,180,253,134,233,15,183,70,252,254,15, | 672 | 253,134,233,15,183,70,252,254,15,131,245,255,15,130,244,248,141,180,253,134, |
673 | 131,245,255,15,130,244,248,141,180,253,134,233,255,248,3,102,15,46,193,252, | 673 | 233,255,248,3,102,15,46,193,252,233,244,1,255,141,12,202,139,105,4,129,252, |
674 | 233,244,1,255,141,12,202,139,105,4,129,252,253,239,15,132,244,247,255,137, | 674 | 253,239,15,132,244,247,255,137,105,252,252,139,41,137,105,252,248,252,233, |
675 | 105,252,252,139,41,137,105,252,248,252,233,245,255,141,180,253,134,233,139, | 675 | 245,255,141,180,253,134,233,139,1,137,105,252,252,137,65,252,248,255,139, |
676 | 1,137,105,252,252,137,65,252,248,255,139,139,233,139,4,129,72,139,128,233, | 676 | 139,233,139,4,129,72,139,128,233,139,108,36,96,137,147,233,137,171,233,76, |
677 | 139,108,36,96,137,147,233,137,171,233,76,137,100,36,80,76,137,108,36,32,76, | 677 | 137,100,36,80,76,137,108,36,32,76,137,116,36,24,76,137,124,36,16,72,137,225, |
678 | 137,116,36,24,76,137,124,36,16,72,137,225,72,129,252,236,239,102,15,127,49, | 678 | 72,129,252,236,239,102,15,127,49,102,15,127,185,233,102,68,15,127,129,233, |
679 | 102,15,127,185,233,102,68,15,127,129,233,102,68,15,127,137,233,102,68,15, | 679 | 102,68,15,127,137,233,102,68,15,127,145,233,102,68,15,127,153,233,102,68, |
680 | 127,145,233,102,68,15,127,153,233,102,68,15,127,161,233,102,68,15,127,169, | 680 | 15,127,161,233,102,68,15,127,169,233,102,68,15,127,177,233,102,68,15,127, |
681 | 233,102,68,15,127,177,233,102,68,15,127,185,233,252,255,224,255,141,180,253, | 681 | 185,233,252,255,224,255,141,180,253,134,233,139,6,15,182,204,15,182,232,131, |
682 | 134,233,139,6,15,182,204,15,182,232,131,198,4,193,232,16,252,255,36,252,235, | 682 | 198,4,193,232,16,252,255,36,252,235,255,137,252,245,209,252,237,129,229,239, |
683 | 255,137,252,245,209,252,237,129,229,239,102,131,172,253,43,233,1,15,132,244, | 683 | 102,131,172,253,43,233,1,15,132,244,142,255,139,190,233,139,108,36,96,141, |
684 | 142,255,139,190,233,139,108,36,96,141,12,202,59,141,233,15,135,244,23,15, | 684 | 12,202,59,141,233,15,135,244,23,15,182,142,233,57,200,15,134,244,249,248, |
685 | 182,142,233,57,200,15,134,244,249,248,2,255,15,183,70,252,254,252,233,245, | 685 | 2,255,15,183,70,252,254,252,233,245,255,248,3,199,68,194,252,252,237,131, |
686 | 255,248,3,199,68,194,252,252,237,131,192,1,57,200,15,134,244,3,252,233,244, | 686 | 192,1,57,200,15,134,244,3,252,233,244,2,255,141,44,197,237,141,4,194,139, |
687 | 2,255,141,44,197,237,141,4,194,139,122,252,248,137,104,252,252,137,120,252, | 687 | 122,252,248,137,104,252,252,137,120,252,248,139,108,36,96,141,12,200,59,141, |
688 | 248,139,108,36,96,141,12,200,59,141,233,15,135,244,22,137,209,137,194,15, | 688 | 233,15,135,244,22,137,209,137,194,15,182,174,233,133,252,237,15,132,244,248, |
689 | 182,174,233,133,252,237,15,132,244,248,248,1,131,193,8,57,209,15,131,244, | 689 | 248,1,131,193,8,57,209,15,131,244,249,139,121,252,248,137,56,139,121,252, |
690 | 249,139,121,252,248,137,56,139,121,252,252,137,120,4,131,192,8,199,65,252, | 690 | 252,137,120,4,131,192,8,199,65,252,252,237,131,252,237,1,15,133,244,1,248, |
691 | 252,237,131,252,237,1,15,133,244,1,248,2,255,139,190,233,139,6,15,182,204, | 691 | 2,255,139,190,233,139,6,15,182,204,15,182,232,131,198,4,193,232,16,252,255, |
692 | 15,182,232,131,198,4,193,232,16,252,255,36,252,235,255,248,3,199,64,4,237, | 692 | 36,252,235,255,248,3,199,64,4,237,131,192,8,131,252,237,1,15,133,244,3,252, |
693 | 131,192,8,131,252,237,1,15,133,244,3,252,233,244,2,255,139,106,252,248,72, | 693 | 233,244,2,255,139,106,252,248,72,139,189,233,139,108,36,96,141,68,194,252, |
694 | 139,189,233,139,108,36,96,141,68,194,252,248,137,149,233,141,136,233,59,141, | 694 | 248,137,149,233,141,136,233,59,141,233,137,133,233,255,137,252,233,255,72, |
695 | 233,137,133,233,255,137,252,233,255,72,137,252,250,137,252,233,255,15,135, | 695 | 137,252,250,137,252,233,255,15,135,244,21,199,131,233,237,255,252,255,215, |
696 | 244,21,199,131,233,237,255,252,255,215,255,252,255,147,233,255,199,131,233, | 696 | 255,252,255,147,233,255,199,131,233,237,139,149,233,141,12,194,252,247,217, |
697 | 237,139,149,233,141,12,194,252,247,217,3,141,233,139,114,252,252,252,233, | 697 | 3,141,233,139,114,252,252,252,233,244,12,255,254,0 |
698 | 244,12,255,254,0 | ||
699 | }; | 698 | }; |
700 | 699 | ||
701 | enum { | 700 | enum { |
@@ -1992,8 +1991,8 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
1992 | break; | 1991 | break; |
1993 | 1992 | ||
1994 | case BC_VARG: | 1993 | case BC_VARG: |
1995 | dasm_put(Dst, 12926, Dt7(->pc), PC2PROTO(numparams), (8+FRAME_VARG), LJ_TNIL); | 1994 | dasm_put(Dst, 12926, (8+FRAME_VARG), LJ_TNIL, Dt1(->maxstack)); |
1996 | dasm_put(Dst, 13071, Dt1(->maxstack), Dt1(->base), Dt1(->top), Dt1(->base), Dt1(->top)); | 1995 | dasm_put(Dst, 13091, Dt1(->base), Dt1(->top), Dt1(->base), Dt1(->top)); |
1997 | break; | 1996 | break; |
1998 | 1997 | ||
1999 | /* -- Returns ----------------------------------------------------------- */ | 1998 | /* -- Returns ----------------------------------------------------------- */ |
@@ -2004,30 +2003,30 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2004 | 2003 | ||
2005 | case BC_RET: case BC_RET0: case BC_RET1: | 2004 | case BC_RET: case BC_RET0: case BC_RET1: |
2006 | if (op != BC_RET0) { | 2005 | if (op != BC_RET0) { |
2007 | dasm_put(Dst, 13170); | 2006 | dasm_put(Dst, 13162); |
2008 | } | 2007 | } |
2009 | dasm_put(Dst, 13174, FRAME_TYPE); | 2008 | dasm_put(Dst, 13166, FRAME_TYPE); |
2010 | switch (op) { | 2009 | switch (op) { |
2011 | case BC_RET: | 2010 | case BC_RET: |
2012 | dasm_put(Dst, 13193); | 2011 | dasm_put(Dst, 13185); |
2013 | break; | 2012 | break; |
2014 | case BC_RET1: | 2013 | case BC_RET1: |
2015 | dasm_put(Dst, 13251); | 2014 | dasm_put(Dst, 13243); |
2016 | /* fallthrough */ | 2015 | /* fallthrough */ |
2017 | case BC_RET0: | 2016 | case BC_RET0: |
2018 | dasm_put(Dst, 13267); | 2017 | dasm_put(Dst, 13259); |
2019 | default: | 2018 | default: |
2020 | break; | 2019 | break; |
2021 | } | 2020 | } |
2022 | dasm_put(Dst, 13278, Dt7(->pc), PC2PROTO(k)); | 2021 | dasm_put(Dst, 13270, Dt7(->pc), PC2PROTO(k)); |
2023 | if (op == BC_RET) { | 2022 | if (op == BC_RET) { |
2024 | dasm_put(Dst, 13322, LJ_TNIL); | 2023 | dasm_put(Dst, 13314, LJ_TNIL); |
2025 | } else { | 2024 | } else { |
2026 | dasm_put(Dst, 13331, LJ_TNIL); | 2025 | dasm_put(Dst, 13323, LJ_TNIL); |
2027 | } | 2026 | } |
2028 | dasm_put(Dst, 13338, -FRAME_VARG, FRAME_TYPEP); | 2027 | dasm_put(Dst, 13330, -FRAME_VARG, FRAME_TYPEP); |
2029 | if (op != BC_RET0) { | 2028 | if (op != BC_RET0) { |
2030 | dasm_put(Dst, 13362); | 2029 | dasm_put(Dst, 13354); |
2031 | } | 2030 | } |
2032 | dasm_put(Dst, 4573); | 2031 | dasm_put(Dst, 4573); |
2033 | break; | 2032 | break; |
@@ -2037,7 +2036,7 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2037 | 2036 | ||
2038 | case BC_FORL: | 2037 | case BC_FORL: |
2039 | #if LJ_HASJIT | 2038 | #if LJ_HASJIT |
2040 | dasm_put(Dst, 13366, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2039 | dasm_put(Dst, 13358, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2041 | #endif | 2040 | #endif |
2042 | break; | 2041 | break; |
2043 | 2042 | ||
@@ -2049,57 +2048,57 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2049 | case BC_FORI: | 2048 | case BC_FORI: |
2050 | case BC_IFORL: | 2049 | case BC_IFORL: |
2051 | vk = (op == BC_IFORL || op == BC_JFORL); | 2050 | vk = (op == BC_IFORL || op == BC_JFORL); |
2052 | dasm_put(Dst, 13387); | 2051 | dasm_put(Dst, 13379); |
2053 | if (!vk) { | 2052 | if (!vk) { |
2054 | dasm_put(Dst, 13391, LJ_TISNUM, LJ_TISNUM); | 2053 | dasm_put(Dst, 13383, LJ_TISNUM, LJ_TISNUM); |
2055 | } | 2054 | } |
2056 | dasm_put(Dst, 13410); | 2055 | dasm_put(Dst, 13402); |
2057 | if (!vk) { | 2056 | if (!vk) { |
2058 | dasm_put(Dst, 13414, LJ_TISNUM); | 2057 | dasm_put(Dst, 13406, LJ_TISNUM); |
2059 | } | 2058 | } |
2060 | if (sse) { | 2059 | if (sse) { |
2061 | dasm_put(Dst, 13423); | 2060 | dasm_put(Dst, 13415); |
2062 | if (vk) { | 2061 | if (vk) { |
2063 | dasm_put(Dst, 13435); | 2062 | dasm_put(Dst, 13427); |
2064 | } else { | 2063 | } else { |
2065 | dasm_put(Dst, 13454); | 2064 | dasm_put(Dst, 13446); |
2066 | } | 2065 | } |
2067 | dasm_put(Dst, 13459); | 2066 | dasm_put(Dst, 13451); |
2068 | } else { | 2067 | } else { |
2069 | dasm_put(Dst, 13472); | 2068 | dasm_put(Dst, 13464); |
2070 | if (vk) { | 2069 | if (vk) { |
2071 | dasm_put(Dst, 13478); | 2070 | dasm_put(Dst, 13470); |
2072 | } else { | 2071 | } else { |
2073 | dasm_put(Dst, 13494); | 2072 | dasm_put(Dst, 13486); |
2074 | } | 2073 | } |
2075 | dasm_put(Dst, 13502); | 2074 | dasm_put(Dst, 13494); |
2076 | if (cmov) { | 2075 | if (cmov) { |
2077 | dasm_put(Dst, 9536); | 2076 | dasm_put(Dst, 9536); |
2078 | } else { | 2077 | } else { |
2079 | dasm_put(Dst, 9542); | 2078 | dasm_put(Dst, 9542); |
2080 | } | 2079 | } |
2081 | if (!cmov) { | 2080 | if (!cmov) { |
2082 | dasm_put(Dst, 13507); | 2081 | dasm_put(Dst, 13499); |
2083 | } | 2082 | } |
2084 | } | 2083 | } |
2085 | if (op == BC_FORI) { | 2084 | if (op == BC_FORI) { |
2086 | dasm_put(Dst, 13513, -BCBIAS_J*4); | 2085 | dasm_put(Dst, 13505, -BCBIAS_J*4); |
2087 | } else if (op == BC_JFORI) { | 2086 | } else if (op == BC_JFORI) { |
2088 | dasm_put(Dst, 13523, -BCBIAS_J*4, BC_JLOOP); | 2087 | dasm_put(Dst, 13515, -BCBIAS_J*4, BC_JLOOP); |
2089 | } else if (op == BC_IFORL) { | 2088 | } else if (op == BC_IFORL) { |
2090 | dasm_put(Dst, 13537, -BCBIAS_J*4); | 2089 | dasm_put(Dst, 13529, -BCBIAS_J*4); |
2091 | } else { | 2090 | } else { |
2092 | dasm_put(Dst, 13533, BC_JLOOP); | 2091 | dasm_put(Dst, 13525, BC_JLOOP); |
2093 | } | 2092 | } |
2094 | dasm_put(Dst, 9571); | 2093 | dasm_put(Dst, 9571); |
2095 | if (sse) { | 2094 | if (sse) { |
2096 | dasm_put(Dst, 13547); | 2095 | dasm_put(Dst, 13539); |
2097 | } | 2096 | } |
2098 | break; | 2097 | break; |
2099 | 2098 | ||
2100 | case BC_ITERL: | 2099 | case BC_ITERL: |
2101 | #if LJ_HASJIT | 2100 | #if LJ_HASJIT |
2102 | dasm_put(Dst, 13366, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2101 | dasm_put(Dst, 13358, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2103 | #endif | 2102 | #endif |
2104 | break; | 2103 | break; |
2105 | 2104 | ||
@@ -2108,18 +2107,18 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2108 | break; | 2107 | break; |
2109 | #endif | 2108 | #endif |
2110 | case BC_IITERL: | 2109 | case BC_IITERL: |
2111 | dasm_put(Dst, 13558, LJ_TNIL); | 2110 | dasm_put(Dst, 13550, LJ_TNIL); |
2112 | if (op == BC_JITERL) { | 2111 | if (op == BC_JITERL) { |
2113 | dasm_put(Dst, 13573, BC_JLOOP); | 2112 | dasm_put(Dst, 13565, BC_JLOOP); |
2114 | } else { | 2113 | } else { |
2115 | dasm_put(Dst, 13587, -BCBIAS_J*4); | 2114 | dasm_put(Dst, 13579, -BCBIAS_J*4); |
2116 | } | 2115 | } |
2117 | dasm_put(Dst, 9871); | 2116 | dasm_put(Dst, 9871); |
2118 | break; | 2117 | break; |
2119 | 2118 | ||
2120 | case BC_LOOP: | 2119 | case BC_LOOP: |
2121 | #if LJ_HASJIT | 2120 | #if LJ_HASJIT |
2122 | dasm_put(Dst, 13366, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2121 | dasm_put(Dst, 13358, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2123 | #endif | 2122 | #endif |
2124 | break; | 2123 | break; |
2125 | 2124 | ||
@@ -2129,12 +2128,12 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2129 | 2128 | ||
2130 | case BC_JLOOP: | 2129 | case BC_JLOOP: |
2131 | #if LJ_HASJIT | 2130 | #if LJ_HASJIT |
2132 | dasm_put(Dst, 13603, DISPATCH_J(trace), DtD(->mcode), DISPATCH_GL(jit_base), DISPATCH_GL(jit_L), 9*16+4*8, -1*16, -2*16, -3*16, -4*16, -5*16, -6*16, -7*16, -8*16, -9*16); | 2131 | dasm_put(Dst, 13595, DISPATCH_J(trace), DtD(->mcode), DISPATCH_GL(jit_base), DISPATCH_GL(jit_L), 9*16+4*8, -1*16, -2*16, -3*16, -4*16, -5*16, -6*16, -7*16, -8*16, -9*16); |
2133 | #endif | 2132 | #endif |
2134 | break; | 2133 | break; |
2135 | 2134 | ||
2136 | case BC_JMP: | 2135 | case BC_JMP: |
2137 | dasm_put(Dst, 13712, -BCBIAS_J*4); | 2136 | dasm_put(Dst, 13704, -BCBIAS_J*4); |
2138 | break; | 2137 | break; |
2139 | 2138 | ||
2140 | /* -- Function headers -------------------------------------------------- */ | 2139 | /* -- Function headers -------------------------------------------------- */ |
@@ -2148,7 +2147,7 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2148 | 2147 | ||
2149 | case BC_FUNCF: | 2148 | case BC_FUNCF: |
2150 | #if LJ_HASJIT | 2149 | #if LJ_HASJIT |
2151 | dasm_put(Dst, 13737, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2150 | dasm_put(Dst, 13729, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2152 | #endif | 2151 | #endif |
2153 | case BC_FUNCV: /* NYI: compiled vararg functions. */ | 2152 | case BC_FUNCV: /* NYI: compiled vararg functions. */ |
2154 | break; | 2153 | break; |
@@ -2158,13 +2157,13 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2158 | break; | 2157 | break; |
2159 | #endif | 2158 | #endif |
2160 | case BC_IFUNCF: | 2159 | case BC_IFUNCF: |
2161 | dasm_put(Dst, 13758, -4+PC2PROTO(k), Dt1(->maxstack), -4+PC2PROTO(numparams)); | 2160 | dasm_put(Dst, 13750, -4+PC2PROTO(k), Dt1(->maxstack), -4+PC2PROTO(numparams)); |
2162 | if (op == BC_JFUNCF) { | 2161 | if (op == BC_JFUNCF) { |
2163 | dasm_put(Dst, 13788, BC_JLOOP); | 2162 | dasm_put(Dst, 13780, BC_JLOOP); |
2164 | } else { | 2163 | } else { |
2165 | dasm_put(Dst, 9573); | 2164 | dasm_put(Dst, 9573); |
2166 | } | 2165 | } |
2167 | dasm_put(Dst, 13797, LJ_TNIL); | 2166 | dasm_put(Dst, 13789, LJ_TNIL); |
2168 | break; | 2167 | break; |
2169 | 2168 | ||
2170 | case BC_JFUNCV: | 2169 | case BC_JFUNCV: |
@@ -2175,30 +2174,30 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2175 | break; /* NYI: compiled vararg functions. */ | 2174 | break; /* NYI: compiled vararg functions. */ |
2176 | 2175 | ||
2177 | case BC_IFUNCV: | 2176 | case BC_IFUNCV: |
2178 | dasm_put(Dst, 13819, FRAME_VARG, Dt1(->maxstack), -4+PC2PROTO(numparams), LJ_TNIL); | 2177 | dasm_put(Dst, 13811, FRAME_VARG, Dt1(->maxstack), -4+PC2PROTO(numparams), LJ_TNIL); |
2179 | if (op == BC_JFUNCV) { | 2178 | if (op == BC_JFUNCV) { |
2180 | dasm_put(Dst, 13788, BC_JLOOP); | 2179 | dasm_put(Dst, 13780, BC_JLOOP); |
2181 | } else { | 2180 | } else { |
2182 | dasm_put(Dst, 13910, -4+PC2PROTO(k)); | 2181 | dasm_put(Dst, 13902, -4+PC2PROTO(k)); |
2183 | } | 2182 | } |
2184 | dasm_put(Dst, 13933, LJ_TNIL); | 2183 | dasm_put(Dst, 13925, LJ_TNIL); |
2185 | break; | 2184 | break; |
2186 | 2185 | ||
2187 | case BC_FUNCC: | 2186 | case BC_FUNCC: |
2188 | case BC_FUNCCW: | 2187 | case BC_FUNCCW: |
2189 | dasm_put(Dst, 13955, Dt8(->f), Dt1(->base), 8*LUA_MINSTACK, Dt1(->maxstack), Dt1(->top)); | 2188 | dasm_put(Dst, 13947, Dt8(->f), Dt1(->base), 8*LUA_MINSTACK, Dt1(->maxstack), Dt1(->top)); |
2190 | if (op == BC_FUNCC) { | 2189 | if (op == BC_FUNCC) { |
2191 | dasm_put(Dst, 13985); | 2190 | dasm_put(Dst, 13977); |
2192 | } else { | 2191 | } else { |
2193 | dasm_put(Dst, 13989); | 2192 | dasm_put(Dst, 13981); |
2194 | } | 2193 | } |
2195 | dasm_put(Dst, 13997, DISPATCH_GL(vmstate), ~LJ_VMST_C); | 2194 | dasm_put(Dst, 13989, DISPATCH_GL(vmstate), ~LJ_VMST_C); |
2196 | if (op == BC_FUNCC) { | 2195 | if (op == BC_FUNCC) { |
2197 | dasm_put(Dst, 14006); | 2196 | dasm_put(Dst, 13998); |
2198 | } else { | 2197 | } else { |
2199 | dasm_put(Dst, 14010, DISPATCH_GL(wrapf)); | 2198 | dasm_put(Dst, 14002, DISPATCH_GL(wrapf)); |
2200 | } | 2199 | } |
2201 | dasm_put(Dst, 14015, DISPATCH_GL(vmstate), ~LJ_VMST_INTERP, Dt1(->base), Dt1(->top)); | 2200 | dasm_put(Dst, 14007, DISPATCH_GL(vmstate), ~LJ_VMST_INTERP, Dt1(->base), Dt1(->top)); |
2202 | break; | 2201 | break; |
2203 | 2202 | ||
2204 | /* ---------------------------------------------------------------------- */ | 2203 | /* ---------------------------------------------------------------------- */ |
@@ -2226,7 +2225,7 @@ static int build_backend(BuildCtx *ctx) | |||
2226 | 2225 | ||
2227 | build_subroutines(ctx, cmov, sse); | 2226 | build_subroutines(ctx, cmov, sse); |
2228 | 2227 | ||
2229 | dasm_put(Dst, 14040); | 2228 | dasm_put(Dst, 14032); |
2230 | for (op = 0; op < BC__MAX; op++) | 2229 | for (op = 0; op < BC__MAX; op++) |
2231 | build_ins(ctx, (BCOp)op, op, cmov, sse); | 2230 | build_ins(ctx, (BCOp)op, op, cmov, sse); |
2232 | 2231 | ||
diff --git a/src/buildvm_x86.dasc b/src/buildvm_x86.dasc index d7c36d90..598fe087 100644 --- a/src/buildvm_x86.dasc +++ b/src/buildvm_x86.dasc | |||
@@ -4442,13 +4442,10 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
4442 | break; | 4442 | break; |
4443 | 4443 | ||
4444 | case BC_VARG: | 4444 | case BC_VARG: |
4445 | | ins_AB_ // RA = base, RB = nresults+1, (RC = 1) | 4445 | | ins_ABC // RA = base, RB = nresults+1, RC = numparams |
4446 | | mov LFUNC:RC, [BASE-8] | ||
4447 | | lea RA, [BASE+RA*8] | ||
4448 | | mov RC, LFUNC:RC->pc | ||
4449 | | movzx RC, byte [RC+PC2PROTO(numparams)] | ||
4450 | | mov TMP1, KBASE // Need one more free register. | 4446 | | mov TMP1, KBASE // Need one more free register. |
4451 | | lea KBASE, [BASE+RC*8+(8+FRAME_VARG)] | 4447 | | lea KBASE, [BASE+RC*8+(8+FRAME_VARG)] |
4448 | | lea RA, [BASE+RA*8] | ||
4452 | | sub KBASE, [BASE-4] | 4449 | | sub KBASE, [BASE-4] |
4453 | | // Note: KBASE may now be even _above_ BASE if nargs was < numparams. | 4450 | | // Note: KBASE may now be even _above_ BASE if nargs was < numparams. |
4454 | | test RB, RB | 4451 | | test RB, RB |
diff --git a/src/buildvm_x86.h b/src/buildvm_x86.h index 10392991..7624330c 100644 --- a/src/buildvm_x86.h +++ b/src/buildvm_x86.h | |||
@@ -12,7 +12,7 @@ | |||
12 | #define DASM_SECTION_CODE_OP 0 | 12 | #define DASM_SECTION_CODE_OP 0 |
13 | #define DASM_SECTION_CODE_SUB 1 | 13 | #define DASM_SECTION_CODE_SUB 1 |
14 | #define DASM_MAXSECTION 2 | 14 | #define DASM_MAXSECTION 2 |
15 | static const unsigned char build_actionlist[15235] = { | 15 | static const unsigned char build_actionlist[15227] = { |
16 | 254,1,248,10,252,247,198,237,15,132,244,11,131,230,252,248,41,252,242,141, | 16 | 254,1,248,10,252,247,198,237,15,132,244,11,131,230,252,248,41,252,242,141, |
17 | 76,49,252,248,139,114,252,252,199,68,10,4,237,248,12,131,192,1,137,68,36, | 17 | 76,49,252,248,139,114,252,252,199,68,10,4,237,248,12,131,192,1,137,68,36, |
18 | 20,252,247,198,237,15,132,244,13,248,14,129,252,246,239,252,247,198,237,15, | 18 | 20,252,247,198,237,15,132,244,13,248,14,129,252,246,239,252,247,198,237,15, |
@@ -698,57 +698,56 @@ static const unsigned char build_actionlist[15235] = { | |||
698 | 139,105,252,240,139,65,252,244,137,105,8,137,65,12,139,105,224,139,65,228, | 698 | 139,105,252,240,139,65,252,244,137,105,8,137,65,12,139,105,224,139,65,228, |
699 | 137,105,252,248,137,65,252,252,129,252,248,239,184,237,15,133,244,28,137, | 699 | 137,105,252,248,137,65,252,252,129,252,248,239,184,237,15,133,244,28,137, |
700 | 202,137,114,252,252,139,181,233,139,14,15,182,252,233,15,182,205,131,198, | 700 | 202,137,114,252,252,139,181,233,139,14,15,182,252,233,15,182,205,131,198, |
701 | 4,252,255,36,171,255,15,182,252,236,139,66,252,248,141,12,202,139,128,233, | 701 | 4,252,255,36,171,255,15,182,252,236,15,182,192,137,124,36,16,141,188,253, |
702 | 15,182,128,233,137,124,36,16,141,188,253,194,233,43,122,252,252,133,252,237, | 702 | 194,233,141,12,202,43,122,252,252,133,252,237,15,132,244,251,141,108,252, |
703 | 15,132,244,251,141,108,252,233,252,248,57,215,15,131,244,248,248,1,139,71, | 703 | 233,252,248,57,215,15,131,244,248,248,1,139,71,252,248,137,1,139,71,252,252, |
704 | 252,248,137,1,139,71,252,252,131,199,8,137,65,4,131,193,8,57,252,233,15,131, | 704 | 131,199,8,137,65,4,131,193,8,57,252,233,15,131,244,249,57,215,15,130,244, |
705 | 244,249,57,215,15,130,244,1,248,2,199,65,4,237,131,193,8,57,252,233,15,130, | 705 | 1,248,2,199,65,4,237,131,193,8,57,252,233,15,130,244,2,248,3,139,124,36,16, |
706 | 244,2,248,3,139,124,36,16,139,6,15,182,204,15,182,232,131,198,4,193,232,16, | 706 | 139,6,15,182,204,15,182,232,131,198,4,193,232,16,252,255,36,171,248,5,199, |
707 | 252,255,36,171,248,5,199,68,36,20,1,0,0,0,137,208,41,252,248,15,134,244,3, | 707 | 68,36,20,1,0,0,0,137,208,41,252,248,15,134,244,3,137,197,193,252,237,3,131, |
708 | 255,137,197,193,252,237,3,131,197,1,137,108,36,20,139,108,36,48,1,200,59, | 708 | 197,1,137,108,36,20,139,108,36,48,1,200,59,133,233,15,135,244,253,248,6,255, |
709 | 133,233,15,135,244,253,248,6,139,71,252,248,137,1,139,71,252,252,131,199, | 709 | 139,71,252,248,137,1,139,71,252,252,131,199,8,137,65,4,131,193,8,57,215,15, |
710 | 8,137,65,4,131,193,8,57,215,15,130,244,6,252,233,244,3,248,7,137,149,233, | 710 | 130,244,6,252,233,244,3,248,7,137,149,233,137,141,233,137,116,36,24,41,215, |
711 | 137,141,233,137,116,36,24,41,215,139,84,36,20,131,252,234,1,137,252,233,232, | 711 | 139,84,36,20,131,252,234,1,137,252,233,232,251,1,0,139,149,233,139,141,233, |
712 | 251,1,0,139,149,233,139,141,233,1,215,252,233,244,6,255,193,225,3,255,248, | 712 | 1,215,252,233,244,6,255,193,225,3,255,248,1,139,114,252,252,137,68,36,20, |
713 | 1,139,114,252,252,137,68,36,20,252,247,198,237,15,133,244,253,255,248,13, | 713 | 252,247,198,237,15,133,244,253,255,248,13,137,215,131,232,1,15,132,244,249, |
714 | 137,215,131,232,1,15,132,244,249,248,2,139,44,15,137,111,252,248,139,108, | 714 | 248,2,139,44,15,137,111,252,248,139,108,15,4,137,111,252,252,131,199,8,131, |
715 | 15,4,137,111,252,252,131,199,8,131,232,1,15,133,244,2,248,3,139,68,36,20, | 715 | 232,1,15,133,244,2,248,3,139,68,36,20,15,182,110,252,255,248,5,57,197,15, |
716 | 15,182,110,252,255,248,5,57,197,15,135,244,252,255,139,108,10,4,137,106,252, | 716 | 135,244,252,255,139,108,10,4,137,106,252,252,139,44,10,137,106,252,248,255, |
717 | 252,139,44,10,137,106,252,248,255,248,5,56,70,252,255,15,135,244,252,255, | 717 | 248,5,56,70,252,255,15,135,244,252,255,15,182,78,252,253,252,247,209,141, |
718 | 15,182,78,252,253,252,247,209,141,20,202,139,122,252,248,139,191,233,139, | 718 | 20,202,139,122,252,248,139,191,233,139,191,233,139,6,15,182,204,15,182,232, |
719 | 191,233,139,6,15,182,204,15,182,232,131,198,4,193,232,16,252,255,36,171,248, | 719 | 131,198,4,193,232,16,252,255,36,171,248,6,255,199,71,252,252,237,131,199, |
720 | 6,255,199,71,252,252,237,131,199,8,255,199,68,194,252,244,237,255,131,192, | 720 | 8,255,199,68,194,252,244,237,255,131,192,1,252,233,244,5,248,7,141,174,233, |
721 | 1,252,233,244,5,248,7,141,174,233,252,247,197,237,15,133,244,14,41,252,234, | 721 | 252,247,197,237,15,133,244,14,41,252,234,255,1,252,233,255,137,252,245,209, |
722 | 255,1,252,233,255,137,252,245,209,252,237,129,229,239,102,131,172,253,43, | 722 | 252,237,129,229,239,102,131,172,253,43,233,1,15,132,244,140,255,141,12,202, |
723 | 233,1,15,132,244,140,255,141,12,202,255,129,121,253,4,239,15,135,244,53,129, | 723 | 255,129,121,253,4,239,15,135,244,53,129,121,253,12,239,15,135,244,53,255, |
724 | 121,253,12,239,15,135,244,53,255,139,105,20,255,129,252,253,239,15,135,244, | 724 | 139,105,20,255,129,252,253,239,15,135,244,53,255,252,242,15,16,1,252,242, |
725 | 53,255,252,242,15,16,1,252,242,15,16,73,8,255,252,242,15,88,65,16,252,242, | 725 | 15,16,73,8,255,252,242,15,88,65,16,252,242,15,17,1,133,252,237,15,136,244, |
726 | 15,17,1,133,252,237,15,136,244,249,255,15,140,244,249,255,102,15,46,200,248, | 726 | 249,255,15,140,244,249,255,102,15,46,200,248,1,252,242,15,17,65,24,255,221, |
727 | 1,252,242,15,17,65,24,255,221,65,8,221,1,255,220,65,16,221,17,221,81,24,133, | 727 | 65,8,221,1,255,220,65,16,221,17,221,81,24,133,252,237,15,136,244,247,255, |
728 | 252,237,15,136,244,247,255,221,81,24,15,140,244,247,255,217,201,248,1,255, | 728 | 221,81,24,15,140,244,247,255,217,201,248,1,255,15,183,70,252,254,255,15,131, |
729 | 15,183,70,252,254,255,15,131,244,248,141,180,253,134,233,255,141,180,253, | 729 | 244,248,141,180,253,134,233,255,141,180,253,134,233,15,183,70,252,254,15, |
730 | 134,233,15,183,70,252,254,15,131,245,255,15,130,244,248,141,180,253,134,233, | 730 | 131,245,255,15,130,244,248,141,180,253,134,233,255,248,3,102,15,46,193,252, |
731 | 255,248,3,102,15,46,193,252,233,244,1,255,141,12,202,139,105,4,129,252,253, | 731 | 233,244,1,255,141,12,202,139,105,4,129,252,253,239,15,132,244,247,255,137, |
732 | 239,15,132,244,247,255,137,105,252,252,139,41,137,105,252,248,252,233,245, | 732 | 105,252,252,139,41,137,105,252,248,252,233,245,255,141,180,253,134,233,139, |
733 | 255,141,180,253,134,233,139,1,137,105,252,252,137,65,252,248,255,139,139, | 733 | 1,137,105,252,252,137,65,252,248,255,139,139,233,139,4,129,139,128,233,139, |
734 | 233,139,4,129,139,128,233,139,108,36,48,137,147,233,137,171,233,252,255,224, | 734 | 108,36,48,137,147,233,137,171,233,252,255,224,255,141,180,253,134,233,139, |
735 | 255,141,180,253,134,233,139,6,15,182,204,15,182,232,131,198,4,193,232,16, | 735 | 6,15,182,204,15,182,232,131,198,4,193,232,16,252,255,36,171,255,137,252,245, |
736 | 252,255,36,171,255,137,252,245,209,252,237,129,229,239,102,131,172,253,43, | 736 | 209,252,237,129,229,239,102,131,172,253,43,233,1,15,132,244,142,255,139,190, |
737 | 233,1,15,132,244,142,255,139,190,233,139,108,36,48,141,12,202,59,141,233, | 737 | 233,139,108,36,48,141,12,202,59,141,233,15,135,244,23,15,182,142,233,57,200, |
738 | 15,135,244,23,15,182,142,233,57,200,15,134,244,249,248,2,255,15,183,70,252, | 738 | 15,134,244,249,248,2,255,15,183,70,252,254,252,233,245,255,248,3,199,68,194, |
739 | 254,252,233,245,255,248,3,199,68,194,252,252,237,131,192,1,57,200,15,134, | 739 | 252,252,237,131,192,1,57,200,15,134,244,3,252,233,244,2,255,141,44,197,237, |
740 | 244,3,252,233,244,2,255,141,44,197,237,141,4,194,139,122,252,248,137,104, | 740 | 141,4,194,139,122,252,248,137,104,252,252,137,120,252,248,139,108,36,48,141, |
741 | 252,252,137,120,252,248,139,108,36,48,141,12,200,59,141,233,15,135,244,22, | 741 | 12,200,59,141,233,15,135,244,22,137,209,137,194,15,182,174,233,133,252,237, |
742 | 137,209,137,194,15,182,174,233,133,252,237,15,132,244,248,248,1,131,193,8, | 742 | 15,132,244,248,248,1,131,193,8,57,209,15,131,244,249,139,121,252,248,137, |
743 | 57,209,15,131,244,249,139,121,252,248,137,56,139,121,252,252,137,120,4,131, | 743 | 56,139,121,252,252,137,120,4,131,192,8,199,65,252,252,237,131,252,237,1,15, |
744 | 192,8,199,65,252,252,237,131,252,237,1,15,133,244,1,248,2,255,139,190,233, | 744 | 133,244,1,248,2,255,139,190,233,139,6,15,182,204,15,182,232,131,198,4,193, |
745 | 139,6,15,182,204,15,182,232,131,198,4,193,232,16,252,255,36,171,255,248,3, | 745 | 232,16,252,255,36,171,255,248,3,199,64,4,237,131,192,8,131,252,237,1,15,133, |
746 | 199,64,4,237,131,192,8,131,252,237,1,15,133,244,3,252,233,244,2,255,139,106, | 746 | 244,3,252,233,244,2,255,139,106,252,248,139,189,233,139,108,36,48,141,68, |
747 | 252,248,139,189,233,139,108,36,48,141,68,194,252,248,137,149,233,141,136, | 747 | 194,252,248,137,149,233,141,136,233,59,141,233,137,133,233,255,137,44,36, |
748 | 233,59,141,233,137,133,233,255,137,44,36,255,137,124,36,4,137,44,36,255,15, | 748 | 255,137,124,36,4,137,44,36,255,15,135,244,21,199,131,233,237,255,252,255, |
749 | 135,244,21,199,131,233,237,255,252,255,215,255,252,255,147,233,255,199,131, | 749 | 215,255,252,255,147,233,255,199,131,233,237,139,149,233,141,12,194,252,247, |
750 | 233,237,139,149,233,141,12,194,252,247,217,3,141,233,139,114,252,252,252, | 750 | 217,3,141,233,139,114,252,252,252,233,244,12,255,254,0 |
751 | 233,244,12,255,254,0 | ||
752 | }; | 751 | }; |
753 | 752 | ||
754 | enum { | 753 | enum { |
@@ -2116,8 +2115,8 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2116 | break; | 2115 | break; |
2117 | 2116 | ||
2118 | case BC_VARG: | 2117 | case BC_VARG: |
2119 | dasm_put(Dst, 14211, Dt7(->pc), PC2PROTO(numparams), (8+FRAME_VARG), LJ_TNIL); | 2118 | dasm_put(Dst, 14211, (8+FRAME_VARG), LJ_TNIL, Dt1(->maxstack)); |
2120 | dasm_put(Dst, 14355, Dt1(->maxstack), Dt1(->base), Dt1(->top), Dt1(->base), Dt1(->top)); | 2119 | dasm_put(Dst, 14375, Dt1(->base), Dt1(->top), Dt1(->base), Dt1(->top)); |
2121 | break; | 2120 | break; |
2122 | 2121 | ||
2123 | /* -- Returns ----------------------------------------------------------- */ | 2122 | /* -- Returns ----------------------------------------------------------- */ |
@@ -2128,30 +2127,30 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2128 | 2127 | ||
2129 | case BC_RET: case BC_RET0: case BC_RET1: | 2128 | case BC_RET: case BC_RET0: case BC_RET1: |
2130 | if (op != BC_RET0) { | 2129 | if (op != BC_RET0) { |
2131 | dasm_put(Dst, 14454); | 2130 | dasm_put(Dst, 14446); |
2132 | } | 2131 | } |
2133 | dasm_put(Dst, 14458, FRAME_TYPE); | 2132 | dasm_put(Dst, 14450, FRAME_TYPE); |
2134 | switch (op) { | 2133 | switch (op) { |
2135 | case BC_RET: | 2134 | case BC_RET: |
2136 | dasm_put(Dst, 14477); | 2135 | dasm_put(Dst, 14469); |
2137 | break; | 2136 | break; |
2138 | case BC_RET1: | 2137 | case BC_RET1: |
2139 | dasm_put(Dst, 14535); | 2138 | dasm_put(Dst, 14527); |
2140 | /* fallthrough */ | 2139 | /* fallthrough */ |
2141 | case BC_RET0: | 2140 | case BC_RET0: |
2142 | dasm_put(Dst, 14551); | 2141 | dasm_put(Dst, 14543); |
2143 | default: | 2142 | default: |
2144 | break; | 2143 | break; |
2145 | } | 2144 | } |
2146 | dasm_put(Dst, 14562, Dt7(->pc), PC2PROTO(k)); | 2145 | dasm_put(Dst, 14554, Dt7(->pc), PC2PROTO(k)); |
2147 | if (op == BC_RET) { | 2146 | if (op == BC_RET) { |
2148 | dasm_put(Dst, 14604, LJ_TNIL); | 2147 | dasm_put(Dst, 14596, LJ_TNIL); |
2149 | } else { | 2148 | } else { |
2150 | dasm_put(Dst, 14613, LJ_TNIL); | 2149 | dasm_put(Dst, 14605, LJ_TNIL); |
2151 | } | 2150 | } |
2152 | dasm_put(Dst, 14620, -FRAME_VARG, FRAME_TYPEP); | 2151 | dasm_put(Dst, 14612, -FRAME_VARG, FRAME_TYPEP); |
2153 | if (op != BC_RET0) { | 2152 | if (op != BC_RET0) { |
2154 | dasm_put(Dst, 14644); | 2153 | dasm_put(Dst, 14636); |
2155 | } | 2154 | } |
2156 | dasm_put(Dst, 4683); | 2155 | dasm_put(Dst, 4683); |
2157 | break; | 2156 | break; |
@@ -2161,7 +2160,7 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2161 | 2160 | ||
2162 | case BC_FORL: | 2161 | case BC_FORL: |
2163 | #if LJ_HASJIT | 2162 | #if LJ_HASJIT |
2164 | dasm_put(Dst, 14648, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2163 | dasm_put(Dst, 14640, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2165 | #endif | 2164 | #endif |
2166 | break; | 2165 | break; |
2167 | 2166 | ||
@@ -2173,57 +2172,57 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2173 | case BC_FORI: | 2172 | case BC_FORI: |
2174 | case BC_IFORL: | 2173 | case BC_IFORL: |
2175 | vk = (op == BC_IFORL || op == BC_JFORL); | 2174 | vk = (op == BC_IFORL || op == BC_JFORL); |
2176 | dasm_put(Dst, 14669); | 2175 | dasm_put(Dst, 14661); |
2177 | if (!vk) { | 2176 | if (!vk) { |
2178 | dasm_put(Dst, 14673, LJ_TISNUM, LJ_TISNUM); | 2177 | dasm_put(Dst, 14665, LJ_TISNUM, LJ_TISNUM); |
2179 | } | 2178 | } |
2180 | dasm_put(Dst, 14692); | 2179 | dasm_put(Dst, 14684); |
2181 | if (!vk) { | 2180 | if (!vk) { |
2182 | dasm_put(Dst, 14696, LJ_TISNUM); | 2181 | dasm_put(Dst, 14688, LJ_TISNUM); |
2183 | } | 2182 | } |
2184 | if (sse) { | 2183 | if (sse) { |
2185 | dasm_put(Dst, 14705); | 2184 | dasm_put(Dst, 14697); |
2186 | if (vk) { | 2185 | if (vk) { |
2187 | dasm_put(Dst, 14717); | 2186 | dasm_put(Dst, 14709); |
2188 | } else { | 2187 | } else { |
2189 | dasm_put(Dst, 14736); | 2188 | dasm_put(Dst, 14728); |
2190 | } | 2189 | } |
2191 | dasm_put(Dst, 14741); | 2190 | dasm_put(Dst, 14733); |
2192 | } else { | 2191 | } else { |
2193 | dasm_put(Dst, 14754); | 2192 | dasm_put(Dst, 14746); |
2194 | if (vk) { | 2193 | if (vk) { |
2195 | dasm_put(Dst, 14760); | 2194 | dasm_put(Dst, 14752); |
2196 | } else { | 2195 | } else { |
2197 | dasm_put(Dst, 14776); | 2196 | dasm_put(Dst, 14768); |
2198 | } | 2197 | } |
2199 | dasm_put(Dst, 14784); | 2198 | dasm_put(Dst, 14776); |
2200 | if (cmov) { | 2199 | if (cmov) { |
2201 | dasm_put(Dst, 10812); | 2200 | dasm_put(Dst, 10812); |
2202 | } else { | 2201 | } else { |
2203 | dasm_put(Dst, 10818); | 2202 | dasm_put(Dst, 10818); |
2204 | } | 2203 | } |
2205 | if (!cmov) { | 2204 | if (!cmov) { |
2206 | dasm_put(Dst, 14789); | 2205 | dasm_put(Dst, 14781); |
2207 | } | 2206 | } |
2208 | } | 2207 | } |
2209 | if (op == BC_FORI) { | 2208 | if (op == BC_FORI) { |
2210 | dasm_put(Dst, 14795, -BCBIAS_J*4); | 2209 | dasm_put(Dst, 14787, -BCBIAS_J*4); |
2211 | } else if (op == BC_JFORI) { | 2210 | } else if (op == BC_JFORI) { |
2212 | dasm_put(Dst, 14805, -BCBIAS_J*4, BC_JLOOP); | 2211 | dasm_put(Dst, 14797, -BCBIAS_J*4, BC_JLOOP); |
2213 | } else if (op == BC_IFORL) { | 2212 | } else if (op == BC_IFORL) { |
2214 | dasm_put(Dst, 14819, -BCBIAS_J*4); | 2213 | dasm_put(Dst, 14811, -BCBIAS_J*4); |
2215 | } else { | 2214 | } else { |
2216 | dasm_put(Dst, 14815, BC_JLOOP); | 2215 | dasm_put(Dst, 14807, BC_JLOOP); |
2217 | } | 2216 | } |
2218 | dasm_put(Dst, 10847); | 2217 | dasm_put(Dst, 10847); |
2219 | if (sse) { | 2218 | if (sse) { |
2220 | dasm_put(Dst, 14829); | 2219 | dasm_put(Dst, 14821); |
2221 | } | 2220 | } |
2222 | break; | 2221 | break; |
2223 | 2222 | ||
2224 | case BC_ITERL: | 2223 | case BC_ITERL: |
2225 | #if LJ_HASJIT | 2224 | #if LJ_HASJIT |
2226 | dasm_put(Dst, 14648, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2225 | dasm_put(Dst, 14640, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2227 | #endif | 2226 | #endif |
2228 | break; | 2227 | break; |
2229 | 2228 | ||
@@ -2232,18 +2231,18 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2232 | break; | 2231 | break; |
2233 | #endif | 2232 | #endif |
2234 | case BC_IITERL: | 2233 | case BC_IITERL: |
2235 | dasm_put(Dst, 14840, LJ_TNIL); | 2234 | dasm_put(Dst, 14832, LJ_TNIL); |
2236 | if (op == BC_JITERL) { | 2235 | if (op == BC_JITERL) { |
2237 | dasm_put(Dst, 14855, BC_JLOOP); | 2236 | dasm_put(Dst, 14847, BC_JLOOP); |
2238 | } else { | 2237 | } else { |
2239 | dasm_put(Dst, 14869, -BCBIAS_J*4); | 2238 | dasm_put(Dst, 14861, -BCBIAS_J*4); |
2240 | } | 2239 | } |
2241 | dasm_put(Dst, 11144); | 2240 | dasm_put(Dst, 11144); |
2242 | break; | 2241 | break; |
2243 | 2242 | ||
2244 | case BC_LOOP: | 2243 | case BC_LOOP: |
2245 | #if LJ_HASJIT | 2244 | #if LJ_HASJIT |
2246 | dasm_put(Dst, 14648, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2245 | dasm_put(Dst, 14640, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2247 | #endif | 2246 | #endif |
2248 | break; | 2247 | break; |
2249 | 2248 | ||
@@ -2253,12 +2252,12 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2253 | 2252 | ||
2254 | case BC_JLOOP: | 2253 | case BC_JLOOP: |
2255 | #if LJ_HASJIT | 2254 | #if LJ_HASJIT |
2256 | dasm_put(Dst, 14885, DISPATCH_J(trace), DtD(->mcode), DISPATCH_GL(jit_base), DISPATCH_GL(jit_L)); | 2255 | dasm_put(Dst, 14877, DISPATCH_J(trace), DtD(->mcode), DISPATCH_GL(jit_base), DISPATCH_GL(jit_L)); |
2257 | #endif | 2256 | #endif |
2258 | break; | 2257 | break; |
2259 | 2258 | ||
2260 | case BC_JMP: | 2259 | case BC_JMP: |
2261 | dasm_put(Dst, 14908, -BCBIAS_J*4); | 2260 | dasm_put(Dst, 14900, -BCBIAS_J*4); |
2262 | break; | 2261 | break; |
2263 | 2262 | ||
2264 | /* -- Function headers -------------------------------------------------- */ | 2263 | /* -- Function headers -------------------------------------------------- */ |
@@ -2272,7 +2271,7 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2272 | 2271 | ||
2273 | case BC_FUNCF: | 2272 | case BC_FUNCF: |
2274 | #if LJ_HASJIT | 2273 | #if LJ_HASJIT |
2275 | dasm_put(Dst, 14932, HOTCOUNT_PCMASK, GG_DISP2HOT); | 2274 | dasm_put(Dst, 14924, HOTCOUNT_PCMASK, GG_DISP2HOT); |
2276 | #endif | 2275 | #endif |
2277 | case BC_FUNCV: /* NYI: compiled vararg functions. */ | 2276 | case BC_FUNCV: /* NYI: compiled vararg functions. */ |
2278 | break; | 2277 | break; |
@@ -2282,13 +2281,13 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2282 | break; | 2281 | break; |
2283 | #endif | 2282 | #endif |
2284 | case BC_IFUNCF: | 2283 | case BC_IFUNCF: |
2285 | dasm_put(Dst, 14953, -4+PC2PROTO(k), Dt1(->maxstack), -4+PC2PROTO(numparams)); | 2284 | dasm_put(Dst, 14945, -4+PC2PROTO(k), Dt1(->maxstack), -4+PC2PROTO(numparams)); |
2286 | if (op == BC_JFUNCF) { | 2285 | if (op == BC_JFUNCF) { |
2287 | dasm_put(Dst, 14983, BC_JLOOP); | 2286 | dasm_put(Dst, 14975, BC_JLOOP); |
2288 | } else { | 2287 | } else { |
2289 | dasm_put(Dst, 10849); | 2288 | dasm_put(Dst, 10849); |
2290 | } | 2289 | } |
2291 | dasm_put(Dst, 14992, LJ_TNIL); | 2290 | dasm_put(Dst, 14984, LJ_TNIL); |
2292 | break; | 2291 | break; |
2293 | 2292 | ||
2294 | case BC_JFUNCV: | 2293 | case BC_JFUNCV: |
@@ -2299,30 +2298,30 @@ static void build_ins(BuildCtx *ctx, BCOp op, int defop, int cmov, int sse) | |||
2299 | break; /* NYI: compiled vararg functions. */ | 2298 | break; /* NYI: compiled vararg functions. */ |
2300 | 2299 | ||
2301 | case BC_IFUNCV: | 2300 | case BC_IFUNCV: |
2302 | dasm_put(Dst, 15014, FRAME_VARG, Dt1(->maxstack), -4+PC2PROTO(numparams), LJ_TNIL); | 2301 | dasm_put(Dst, 15006, FRAME_VARG, Dt1(->maxstack), -4+PC2PROTO(numparams), LJ_TNIL); |
2303 | if (op == BC_JFUNCV) { | 2302 | if (op == BC_JFUNCV) { |
2304 | dasm_put(Dst, 14983, BC_JLOOP); | 2303 | dasm_put(Dst, 14975, BC_JLOOP); |
2305 | } else { | 2304 | } else { |
2306 | dasm_put(Dst, 15105, -4+PC2PROTO(k)); | 2305 | dasm_put(Dst, 15097, -4+PC2PROTO(k)); |
2307 | } | 2306 | } |
2308 | dasm_put(Dst, 15127, LJ_TNIL); | 2307 | dasm_put(Dst, 15119, LJ_TNIL); |
2309 | break; | 2308 | break; |
2310 | 2309 | ||
2311 | case BC_FUNCC: | 2310 | case BC_FUNCC: |
2312 | case BC_FUNCCW: | 2311 | case BC_FUNCCW: |
2313 | dasm_put(Dst, 15149, Dt8(->f), Dt1(->base), 8*LUA_MINSTACK, Dt1(->maxstack), Dt1(->top)); | 2312 | dasm_put(Dst, 15141, Dt8(->f), Dt1(->base), 8*LUA_MINSTACK, Dt1(->maxstack), Dt1(->top)); |
2314 | if (op == BC_FUNCC) { | 2313 | if (op == BC_FUNCC) { |
2315 | dasm_put(Dst, 15178); | 2314 | dasm_put(Dst, 15170); |
2316 | } else { | 2315 | } else { |
2317 | dasm_put(Dst, 15182); | 2316 | dasm_put(Dst, 15174); |
2318 | } | 2317 | } |
2319 | dasm_put(Dst, 15190, DISPATCH_GL(vmstate), ~LJ_VMST_C); | 2318 | dasm_put(Dst, 15182, DISPATCH_GL(vmstate), ~LJ_VMST_C); |
2320 | if (op == BC_FUNCC) { | 2319 | if (op == BC_FUNCC) { |
2321 | dasm_put(Dst, 15199); | 2320 | dasm_put(Dst, 15191); |
2322 | } else { | 2321 | } else { |
2323 | dasm_put(Dst, 15203, DISPATCH_GL(wrapf)); | 2322 | dasm_put(Dst, 15195, DISPATCH_GL(wrapf)); |
2324 | } | 2323 | } |
2325 | dasm_put(Dst, 15208, DISPATCH_GL(vmstate), ~LJ_VMST_INTERP, Dt1(->base), Dt1(->top)); | 2324 | dasm_put(Dst, 15200, DISPATCH_GL(vmstate), ~LJ_VMST_INTERP, Dt1(->base), Dt1(->top)); |
2326 | break; | 2325 | break; |
2327 | 2326 | ||
2328 | /* ---------------------------------------------------------------------- */ | 2327 | /* ---------------------------------------------------------------------- */ |
@@ -2350,7 +2349,7 @@ static int build_backend(BuildCtx *ctx) | |||
2350 | 2349 | ||
2351 | build_subroutines(ctx, cmov, sse); | 2350 | build_subroutines(ctx, cmov, sse); |
2352 | 2351 | ||
2353 | dasm_put(Dst, 15233); | 2352 | dasm_put(Dst, 15225); |
2354 | for (op = 0; op < BC__MAX; op++) | 2353 | for (op = 0; op < BC__MAX; op++) |
2355 | build_ins(ctx, (BCOp)op, op, cmov, sse); | 2354 | build_ins(ctx, (BCOp)op, op, cmov, sse); |
2356 | 2355 | ||
diff --git a/src/lj_gc.c b/src/lj_gc.c index 3e3d1ec5..e76175fc 100644 --- a/src/lj_gc.c +++ b/src/lj_gc.c | |||
@@ -274,7 +274,7 @@ static MSize gc_traverse_frames(global_State *g, lua_State *th) | |||
274 | TValue *ftop = frame; | 274 | TValue *ftop = frame; |
275 | if (isluafunc(fn)) ftop += funcproto(fn)->framesize; | 275 | if (isluafunc(fn)) ftop += funcproto(fn)->framesize; |
276 | if (ftop > top) top = ftop; | 276 | if (ftop > top) top = ftop; |
277 | gc_markobj(g, frame_gc(frame)); /* Need to mark hidden function (or L). */ | 277 | gc_markobj(g, fn); /* Need to mark hidden function (or L). */ |
278 | } | 278 | } |
279 | top++; /* Correct bias of -1 (frame == base-1). */ | 279 | top++; /* Correct bias of -1 (frame == base-1). */ |
280 | if (top > tvref(th->maxstack)) top = tvref(th->maxstack); | 280 | if (top > tvref(th->maxstack)) top = tvref(th->maxstack); |
diff --git a/src/lj_parse.c b/src/lj_parse.c index e1ca2ff7..522f8ef8 100644 --- a/src/lj_parse.c +++ b/src/lj_parse.c | |||
@@ -116,7 +116,7 @@ typedef struct FuncState { | |||
116 | BCPos bclim; /* Limit of bytecode stack. */ | 116 | BCPos bclim; /* Limit of bytecode stack. */ |
117 | MSize vbase; /* Base of variable stack for this function. */ | 117 | MSize vbase; /* Base of variable stack for this function. */ |
118 | uint8_t flags; /* Prototype flags. */ | 118 | uint8_t flags; /* Prototype flags. */ |
119 | uint8_t numparams; /* Number of active local variables. */ | 119 | uint8_t numparams; /* Number of parameters. */ |
120 | uint8_t framesize; /* Fixed frame size. */ | 120 | uint8_t framesize; /* Fixed frame size. */ |
121 | uint8_t nuv; /* Number of upvalues */ | 121 | uint8_t nuv; /* Number of upvalues */ |
122 | VarIndex varmap[LJ_MAX_LOCVAR]; /* Map from register to variable idx. */ | 122 | VarIndex varmap[LJ_MAX_LOCVAR]; /* Map from register to variable idx. */ |
@@ -1397,10 +1397,8 @@ static BCReg parse_params(LexState *ls, int needself) | |||
1397 | FuncState *fs = ls->fs; | 1397 | FuncState *fs = ls->fs; |
1398 | BCReg nparams = 0; | 1398 | BCReg nparams = 0; |
1399 | lex_check(ls, '('); | 1399 | lex_check(ls, '('); |
1400 | if (needself) { | 1400 | if (needself) |
1401 | var_new_lit(ls, 0, "self"); | 1401 | var_new_lit(ls, nparams++, "self"); |
1402 | var_add(ls, 1); | ||
1403 | } | ||
1404 | if (ls->token != ')') { | 1402 | if (ls->token != ')') { |
1405 | do { | 1403 | do { |
1406 | if (ls->token == TK_name) { | 1404 | if (ls->token == TK_name) { |
@@ -1415,9 +1413,10 @@ static BCReg parse_params(LexState *ls, int needself) | |||
1415 | } while (lex_opt(ls, ',')); | 1413 | } while (lex_opt(ls, ',')); |
1416 | } | 1414 | } |
1417 | var_add(ls, nparams); | 1415 | var_add(ls, nparams); |
1418 | bcreg_reserve(fs, fs->nactvar); | 1416 | lua_assert(fs->nactvar == nparams); |
1417 | bcreg_reserve(fs, nparams); | ||
1419 | lex_check(ls, ')'); | 1418 | lex_check(ls, ')'); |
1420 | return fs->nactvar; | 1419 | return nparams; |
1421 | } | 1420 | } |
1422 | 1421 | ||
1423 | /* Forward declaration. */ | 1422 | /* Forward declaration. */ |
@@ -1577,7 +1576,7 @@ static void expr_simple(LexState *ls, ExpDesc *v) | |||
1577 | checkcond(ls, fs->flags & PROTO_IS_VARARG, LJ_ERR_XDOTS); | 1576 | checkcond(ls, fs->flags & PROTO_IS_VARARG, LJ_ERR_XDOTS); |
1578 | bcreg_reserve(fs, 1); | 1577 | bcreg_reserve(fs, 1); |
1579 | base = fs->freereg-1; | 1578 | base = fs->freereg-1; |
1580 | expr_init(v, VCALL, bcemit_ABC(fs, BC_VARG, base, 2, 1)); | 1579 | expr_init(v, VCALL, bcemit_ABC(fs, BC_VARG, base, 2, fs->numparams)); |
1581 | v->u.s.aux = base; | 1580 | v->u.s.aux = base; |
1582 | break; | 1581 | break; |
1583 | } | 1582 | } |