https://gcc.gnu.org/bugzilla/show_bug.cgi?id=123524
--- Comment #5 from Hongtao Liu <liuhongt at gcc dot gnu.org> ---
(In reply to Hongtao Liu from comment #4)
> Maybe related to r16-1644-gaba3b9d3a48a07, it tries to do some CSE for
> vector broadcast from constant, the optimization is before RA.
It hoist from a big loop
Replace:
(insn 82914 82915 82939 7414 (set (reg:V4SI 99281)
(vec_duplicate:V4SI (reg:SI 99282))) "ipret-1.inc":1806:3 discrim 1
9355 {*vec_dupv4si}
(expr_list:REG_DEAD (reg:SI 99282)
(expr_list:REG_EQUAL (const_vector:V4SI [
(const_int 131074 [0x20002]) repeated x4
])
(nil))))
with:
(insn 82914 82915 82939 7414 (set (reg:V4SI 99281)
(reg:V4SI 117931)) "ipret-1.inc":1806:3 discrim 1 2460
{movv4si_internal}
(expr_list:REG_DEAD (reg:SI 99282)
(expr_list:REG_EQUAL (const_vector:V4SI [
(const_int 131074 [0x20002]) repeated x4
])
(nil))))
deferring rescan insn with uid = 82914.
Replace:
(insn 83529 83530 83554 7476 (set (reg:V4SI 99471)
(vec_duplicate:V4SI (reg:SI 99472))) "ipret-1.inc":1909:3 discrim 1
9355 {*vec_dupv4si}
(expr_list:REG_DEAD (reg:SI 99472)
(expr_list:REG_EQUAL (const_vector:V4SI [
(const_int 131074 [0x20002]) repeated x4
])
(nil))))
with:
(insn 83529 83530 83554 7476 (set (reg:V4SI 99471)
(reg:V4SI 117931)) "ipret-1.inc":1909:3 discrim 1 2460
{movv4si_internal}
(expr_list:REG_DEAD (reg:SI 99472)
(expr_list:REG_EQUAL (const_vector:V4SI [
(const_int 131074 [0x20002]) repeated x4
])
(nil))))
;; Loop 2
;; header 5, multiple latches: 11911 6 8 10 14 18 23 28 36 38 40 42 44 46 48
50 52 54 56 58 60 62 64 66 68 70 72 74 76 78 80 82 84 86 90 94 99 104 112 114
116 118 120 122 124 126 128 130 132 134 136 138 140 142 144 146 148 150 152 154
156 158 160 162 164 166 171 173 175 177 182 187 191 196 197 199 201 203 207 211
216 221 229 231 233 235 237 239 241 243 245 247 249 251 253 255 257 259 261 263
265 267 269 271 273 275 277 279 284 288 293 298 306 308 310 312 314 316 318 320
322 324 326 328 330 332 334 336 338 340 342 344 346 348 350 352 354 356 358 360
365 367 369 371 376 381 385 390 391 393 395 397 404 408 416 421 429 431 433 435
437 439 441 443 445 447 449 451 453 455 457 459 461 463 465 467 469 471 473 475
477 479 484 488 493 498 506 508 510 512 514 516 518 520 522 524 526 528 530 532
534 536 538 540 542 544 546 548 550 552 554 556 558 560 565 567 569 571 576 581
585 590 591 593 595 597 604 608 616 621 629 631 633 635 637 639 641 643 645 647
649 651 653 655 657 659 661 663 665 667 669 671 673 675 677 679 684 688 693 698
706 708 710 712 714 716 718 720 722 724 726 728 730 732 734 736 738 740 742 744
746 748 750 752 754 756 758 760 765 767 769 774 776 781 785 790 791 793 795 797
804 808 816 821 829 831 833 835 837 839 841 843 845 847 849 851 853 855 857 859
861 863 865 867 869 871 873 875 877 879 884 888 893 898 906 908 910 912 914 916
918 920 922 924 926 928 930 932 934 936 938 940 942 944 946 948 950 952 954 956
958 964 971 973 978 984 986 991 995 1000 1001 1002 1003 1004 1006 1008 1010
1012 1018 1021 1032 1034 1037 1041 1045 1049 1053 1057 1060 1065 1067 1069 1071
1073 1075 1077 1079 1081 1083 1085 1087 1089 1091 1093 1095 1097 1099 1101 1103
1107 1109 1111 1113 1115 1117 1124 1144 1164 1172 1174 1176 1180 1185 1186 1188
1190 1192 1194 1200 1203 1214 1216 1219 1223 1227 1231 1235 1239 1242 1247 1249
1251 1253 1255 1257 1259 1261 1263 1265 1267 1269 1271 1273 1275 1277 1279 1281
1283 1285 1289 1291 1293 1295 1297 1299 1305 1307 1309 1317 1319 1321 1325 1330
1331 1333 1335 1337 1339 1345 1348 1359 1361 1364 1368 1372 1376 1380 1384 1387
1392 1394 1396 1398 1400 1402 1404 1406 1408 1410 1412 1414 1416 1418 1420 1422
1424 1426 1428 1430 1434 1436 1438 1440 1442 1444 1450 1452 1454 1462 1464 1466
1470 1475 1476 1478 1480 1482 1484 1490 1493 1504 1506 1509 1513 1517 1521 1525
1529 1532 1537 1539 1541 1543 1545 1547 1549 1551 1553 1555 1557 1559 1561 1563
1565 1567 1569 1571 1573 1575 1577 1579 1581 1583 1585 1587 1593 1595 1597 1605
1607 1609 1613 1618 1619 1621 1623 1625 1627 1629 1632 1642 1644 1647 1651 1655
1659 1663 1667 1670 1672 1674 1676 1678 1680 1682 1684 1686 1688 1690 1692 1694
1696 1698 1700 1702 1704 1706 1708 1710 1712 1714 1716 1718 1720 1722 1728 1730
1732 1740 1742 1744 1748 1753 1754 1760 1766 1772 1778 1782 1786 1789 1795 1801
1816 1819 1821 1823 1827 1831 1840 1848 1851 1854 1856 1858 1860 1862 1864 1870
1874 1878 1881 1887 1893 1909 1912 1914 1916 1920 1924 1933 1941 1944 1947 1949
1951 1953 1955 1957 1963 1965 1969 1972 1976 1980 1983 1988 1992 1997 1998 1999
2003 2008 2013 2018 2025 2032 2035 2038 2041 2045 2050 2061 2070 2073 2078 2081
2084 2087 2090 2093 2100 2104 2109 2114 2117 2122 2129 2132 2135 2138 2142 2147
2157 2165 2168 2173 2175 2178 2181 2184 2187 2189 2192 2196 2199 2204 2209 2213
2218 2222 2227 2228 2229 2233 2237 2241 2246 2252 2257 2259 2261 2263 2267 2271
2280 2288 2291 2294 2296 2298 2300 2302 2304 2310 2314 2318 2322 2325 2329 2334
2336 2338 2340 2344 2348 2356 2363 2366 2369 2371 2373 2375 2377 2379 2381 2383
2387 2390 2394 2398 2401 2406 2410 2415 2416 2417 2421 2425 2429 2434 2440 2445
2447 2449 2451 2455 2459 2468 2476 2479 2482 2484 2486 2488 2490 2492 2498 2502
2506 2510 2513 2517 2522 2524 2526 2528 2532 2536 2544 2551 2554 2557 2559 2561
2563 2565 2567 2569 2571 2575 2578 2582 2586 2589 2591 2595 2600 2601 2602 2606
2610 2614 2618 2622 2626 2628 2630 2632 2636 2640 2644 2648 2652 2654 2656 2658
2660 2662 2664 2668 2672 2676 2680 2684 2688 2692 2694 2696 2698 2702 2706 2710
2714 2718 2720 2722 2724 2726 2728 2730 2735 2737 2741 2745 2749 2753 2758 2760
2764 2769 2770 2771 2778 2785 2792 2799 2806 2808 2810 2812 2814 2816 2818 2820
2822 2824 2826 2829 2833 2837 2841 2845 2848 2850 2852 2854 2856 2858 2860 2862
2866 2870 2874 2878 2882 2886 2890 2894 2898 2902 2906 2910 2912 2914 2919 2924
2926 2928 2930 2932 2934 2936 2938 2940 2942 2944 2948 2952 2956 2960 2964 2968
2972 2976 2980 2984 2988 2992 2994 2996 2998 3000 3005 3010 3012 3014 3016 3018
3020 3022 3024 3026 3028 3030 3032 3034 3038 3042 3046 3050 3054 3058 3062 3066
3070 3074 3078 3082 3084 3086 3088 3090 3095 3100 3102 3104 3106 3108 3110 3112
3114 3116 3118 3120 3122 3124 3127 3133 3138 3142 3147 3148 3158 3164 3170 3176
3182 3206 3228 3233 3238 3241 3242 3243 3247 3250 3253 3261 3262 3263 3281 3282
3283 3292 3293 3294 3295 3307 3351 3423 3451 3507 3518 3627 3660 3687 3688 3694
3709 3730 3743 3756 3790 3793 3796 3844 3845 3846 3907 3911 3915 3919 3923 3927
3931 3935 3939 3947 3951 3955 3959 3973 3975 3977 3981 3985 3990 3995 4003 4005
4007 4009 4011 4013 4015 4017 4019 4021 4023 4025 4027 4029 4031 4033 4035 4037
4039 4041 4043 4045 4047 4049 4051 4053 4057 4061 4066 4071 4079 4081 4083 4085
4087 4089 4091 4093 4095 4097 4099 4101 4103 4105 4107 4109 4111 4113 4115 4117
4119 4121 4123 4125 4127 4129 4131 4133 4138 4140 4142 4144 4149 4154 4158 4163
4164 4166 4168 4170 4174 4178 4183 4188 4196 4198 4200 4202 4204 4206 4208 4210
4212 4214 4216 4218 4220 4222 4224 4226 4228 4230 4232 4234 4236 4238 4240 4242
4244 4246 4250 4254 4259 4264 4272 4274 4276 4278 4280 4282 4284 4286 4288 4290
4292 4294 4296 4298 4300 4302 4304 4306 4308 4310 4312 4314 4316 4318 4320 4322
4324 4326 4331 4333 4335 4337 4342 4347 4351 4356 4357 4359 4361 4363 4370 4374
4382 4387 4395 4397 4399 4401 4403 4405 4407 4409 4411 4413 4415 4417 4419 4421
4423 4425 4427 4429 4431 4433 4435 4437 4439 4441 4443 4445 4450 4454 4459 4464
4472 4474 4476 4478 4480 4482 4484 4486 4488 4490 4492 4494 4496 4498 4500 4502
4504 4506 4508 4510 4512 4514 4516 4518 4520 4522 4524 4526 4531 4533 4535 4537
4542 4547 4551 4556 4557 4559 4561 4563 4570 4574 4582 4587 4595 4597 4599 4601
4603 4605 4607 4609 4611 4613 4615 4617 4619 4621 4623 4625 4627 4629 4631 4633
4635 4637 4639 4641 4643 4645 4650 4654 4659 4664 4672 4674 4676 4678 4680 4682
4684 4686 4688 4690 4692 4694 4696 4698 4700 4702 4704 4706 4708 4710 4712 4714
4716 4718 4720 4722 4724 4726 4731 4733 4735 4740 4742 4747 4751 4756 4757 4759
4761 4763 4770 4774 4782 4787 4795 4797 4799 4801 4803 4805 4807 4809 4811 4813
4815 4817 4819 4821 4823 4825 4827 4829 4831 4833 4835 4837 4839 4841 4843 4845
4850 4854 4859 4864 4872 4874 4876 4878 4880 4882 4884 4886 4888 4890 4892 4894
4896 4898 4900 4902 4904 4906 4908 4910 4912 4914 4916 4918 4920 4922 4924 4930
4937 4939 4944 4950 4952 4957 4961 4966 4967 4968 4969 4970 4972 4974 4976 4978
4984 4987 4998 5000 5003 5007 5011 5015 5019 5023 5026 5031 5033 5035 5037 5039
5041 5043 5045 5047 5049 5051 5053 5055 5057 5059 5061 5063 5065 5067 5069 5073
5075 5077 5079 5081 5083 5090 5110 5130 5138 5140 5142 5146 5151 5152 5154 5156
5158 5160 5166 5169 5180 5182 5185 5189 5193 5197 5201 5205 5208 5213 5215 5217
5219 5221 5223 5225 5227 5229 5231 5233 5235 5237 5239 5241 5243 5245 5247 5249
5251 5255 5257 5259 5261 5263 5265 5271 5273 5275 5283 5285 5287 5291 5296 5297
5299 5301 5303 5305 5311 5314 5325 5327 5330 5334 5338 5342 5346 5350 5353 5358
5360 5362 5364 5366 5368 5370 5372 5374 5376 5378 5380 5382 5384 5386 5388 5390
5392 5394 5396 5400 5402 5404 5406 5408 5410 5416 5418 5420 5428 5430 5432 5436
5441 5442 5444 5446 5448 5450 5456 5459 5470 5472 5475 5479 5483 5487 5491 5495
5498 5503 5505 5507 5509 5511 5513 5515 5517 5519 5521 5523 5525 5527 5529 5531
5533 5535 5537 5539 5541 5543 5545 5547 5549 5551 5553 5559 5561 5563 5571 5573
5575 5579 5584 5585 5587 5589 5591 5593 5595 5598 5608 5610 5613 5617 5621 5625
5629 5633 5636 5638 5640 5642 5644 5646 5648 5650 5652 5654 5656 5658 5660 5662
5664 5666 5668 5670 5672 5674 5676 5678 5680 5682 5684 5686 5688 5694 5696 5698
5706 5708 5710 5714 5719 5720 5726 5732 5738 5744 5748 5752 5755 5761 5767 5782
5785 5787 5789 5793 5797 5806 5814 5817 5820 5822 5824 5826 5828 5830 5836 5840
5844 5847 5853 5859 5874 5877 5879 5881 5885 5889 5898 5906 5909 5912 5914 5916
5918 5920 5922 5929 5931 5935 5938 5942 5946 5949 5954 5958 5963 5964 5965 5969
5974 5979 5984 5991 5998 6001 6004 6007 6011 6016 6027 6036 6039 6044 6047 6050
6053 6056 6059 6066 6070 6075 6080 6085 6092 6099 6102 6105 6108 6112 6117 6128
6137 6140 6145 6148 6151 6154 6157 6160 6167 6170 6174 6177 6182 6187 6191 6196
6200 6205 6206 6207 6211 6215 6219 6224 6230 6235 6237 6239 6241 6245 6249 6258
6266 6269 6272 6274 6276 6278 6280 6282 6288 6292 6296 6300 6303 6307 6312 6314
6316 6318 6322 6326 6334 6341 6344 6347 6349 6351 6353 6355 6357 6359 6361 6365
6368 6372 6376 6379 6384 6388 6393 6394 6395 6399 6403 6407 6412 6418 6423 6425
6427 6429 6433 6437 6446 6454 6457 6460 6462 6464 6466 6468 6470 6476 6480 6484
6488 6491 6495 6500 6502 6504 6506 6510 6514 6522 6529 6532 6535 6537 6539 6541
6543 6545 6547 6549 6553 6556 6560 6564 6567 6569 6573 6578 6579 6580 6584 6588
6592 6596 6600 6604 6606 6608 6610 6614 6618 6622 6626 6630 6632 6634 6636 6638
6640 6642 6646 6650 6654 6658 6662 6666 6670 6672 6674 6676 6680 6684 6688 6692
6696 6698 6700 6702 6704 6706 6708 6712 6714 6718 6722 6726 6730 6735 6737 6741
6746 6747 6748 6755 6762 6769 6776 6783 6785 6787 6789 6791 6793 6795 6797 6799
6801 6803 6806 6810 6814 6818 6822 6825 6827 6829 6831 6833 6835 6837 6839 6843
6847 6851 6855 6859 6863 6867 6871 6875 6879 6883 6887 6889 6891 6896 6901 6903
6905 6907 6909 6911 6913 6915 6917 6919 6921 6925 6929 6933 6937 6941 6945 6949
6953 6957 6961 6965 6969 6971 6973 6975 6977 6982 6987 6989 6991 6993 6995 6997
6999 7001 7003 7005 7007 7009 7011 7015 7019 7023 7027 7031 7035 7039 7043 7047
7051 7055 7059 7061 7063 7065 7067 7072 7077 7079 7081 7083 7085 7087 7089 7091
7093 7095 7097 7099 7101 7104 7110 7115 7119 7124 7125 7135 7141 7147 7153 7159
7183 7205 7210 7215 7218 7219 7220 7224 7227 7230 7238 7239 7240 7258 7267 7279
7323 7395 7429 7491 7502 7613 7646 7673 7674 7680 7695 7716 7729 7742 7776 7779
7782 7830 7831 7832 7892 7896 7900 7904 7908 7912 7916 7920 7924 7932 7934 7936
7938 7942 7946 7951 7956 7964 7966 7968 7970 7972 7974 7976 7978 7980 7982 7984
7986 7988 7990 7992 7994 7996 7998 8000 8002 8004 8006 8008 8010 8012 8014 8018
8022 8027 8032 8040 8042 8044 8046 8048 8050 8052 8054 8056 8058 8060 8062 8064
8066 8068 8070 8072 8074 8076 8078 8080 8082 8084 8086 8088 8090 8092 8094 8099
8101 8103 8105 8110 8115 8119 8124 8125 8127 8129 8131 8135 8139 8144 8149 8157
8159 8161 8163 8165 8167 8169 8171 8173 8175 8177 8179 8181 8183 8185 8187 8189
8191 8193 8195 8197 8199 8201 8203 8205 8207 8211 8215 8220 8225 8233 8235 8237
8239 8241 8243 8245 8247 8249 8251 8253 8255 8257 8259 8261 8263 8265 8267 8269
8271 8273 8275 8277 8279 8281 8283 8285 8287 8292 8294 8296 8298 8303 8308 8312
8317 8318 8320 8322 8324 8331 8335 8343 8348 8356 8358 8360 8362 8364 8366 8368
8370 8372 8374 8376 8378 8380 8382 8384 8386 8388 8390 8392 8394 8396 8398 8400
8402 8404 8406 8413 8417 8425 8430 8438 8440 8442 8444 8446 8448 8450 8452 8454
8456 8458 8460 8462 8464 8466 8468 8470 8472 8474 8476 8478 8480 8482 8484 8486
8488 8490 8492 8497 8499 8501 8503 8508 8513 8517 8522 8523 8525 8527 8529 8536
8540 8548 8553 8561 8563 8565 8567 8569 8571 8573 8575 8577 8579 8581 8583 8585
8587 8589 8591 8593 8595 8597 8599 8601 8603 8605 8607 8609 8611 8617 8621 8629
8634 8642 8644 8646 8648 8650 8652 8654 8656 8658 8660 8662 8664 8666 8668 8670
8672 8674 8676 8678 8680 8682 8684 8686 8688 8690 8692 8694 8696 8701 8703 8705
8710 8712 8717 8721 8726 8727 8729 8731 8733 8740 8744 8752 8757 8765 8767 8769
8771 8773 8775 8777 8779 8781 8783 8785 8787 8789 8791 8793 8795 8797 8799 8801
8803 8805 8807 8809 8811 8813 8815 8821 8825 8833 8838 8846 8848 8850 8852 8854
8856 8858 8860 8862 8864 8866 8868 8870 8872 8874 8876 8878 8880 8882 8884 8886
8888 8890 8892 8894 8896 8898 8904 8911 8913 8918 8924 8926 8931 8935 8940 8941
8942 8943 8944 8946 8948 8950 8952 8958 8961 8972 8974 8977 8981 8985 8989 8993
8997 9000 9005 9007 9009 9011 9013 9015 9017 9019 9021 9023 9025 9027 9029 9031
9033 9035 9037 9039 9041 9043 9047 9049 9051 9053 9055 9057 9064 9084 9104 9112
9114 9116 9120 9125 9126 9128 9130 9132 9134 9140 9143 9154 9156 9159 9163 9167
9171 9175 9179 9182 9187 9189 9191 9193 9195 9197 9199 9201 9203 9205 9207 9209
9211 9213 9215 9217 9219 9221 9223 9225 9229 9231 9233 9235 9237 9239 9245 9247
9249 9257 9259 9261 9265 9270 9271 9273 9275 9277 9279 9285 9288 9299 9301 9304
9308 9312 9316 9320 9324 9327 9332 9334 9336 9338 9340 9342 9344 9346 9348 9350
9352 9354 9356 9358 9360 9362 9364 9366 9368 9370 9374 9376 9378 9380 9382 9384
9390 9392 9394 9402 9404 9406 9410 9415 9416 9418 9420 9422 9424 9430 9433 9444
9446 9449 9453 9457 9461 9465 9469 9472 9477 9479 9481 9483 9485 9487 9489 9491
9493 9495 9497 9499 9501 9503 9505 9507 9509 9511 9513 9515 9517 9519 9521 9523
9525 9527 9533 9535 9537 9545 9547 9549 9553 9558 9559 9561 9563 9565 9567 9569
9572 9582 9584 9587 9591 9595 9599 9603 9607 9610 9612 9614 9616 9618 9620 9622
9624 9626 9628 9630 9632 9634 9636 9638 9640 9642 9644 9646 9648 9650 9652 9654
9656 9658 9660 9662 9668 9670 9672 9680 9682 9684 9688 9693 9694 9700 9706 9712
9718 9722 9726 9729 9735 9741 9756 9759 9761 9763 9767 9771 9780 9788 9791 9794
9796 9798 9800 9802 9804 9810 9814 9818 9821 9827 9833 9848 9851 9853 9855 9859
9863 9872 9880 9883 9886 9888 9890 9892 9894 9896 9903 9905 9909 9912 9916 9920
9923 9928 9932 9937 9938 9939 9943 9948 9953 9958 9965 9972 9975 9978 9981 9985
9990 10001 10010 10013 10018 10021 10024 10027 10030 10033 10040 10044 10049
10054 10059 10066 10073 10076 10079 10082 10086 10091 10102 10111 10114 10119
10122 10125 10128 10131 10134 10141 10144 10148 10151 10156 10161 10165 10170
10174 10179 10180 10181 10185 10189 10193 10198 10204 10209 10211 10213 10215
10219 10223 10232 10240 10243 10246 10248 10250 10252 10254 10256 10262 10266
10270 10274 10279 10285 10290 10292 10294 10296 10300 10304 10313 10321 10324
10327 10329 10331 10333 10335 10337 10343 10345 10349 10352 10356 10360 10363
10368 10372 10377 10378 10379 10383 10387 10391 10396 10402 10407 10409 10411
10413 10417 10421 10430 10438 10441 10444 10446 10448 10450 10452 10454 10460
10464 10468 10472 10477 10483 10488 10490 10492 10494 10498 10502 10511 10519
10522 10525 10527 10529 10531 10533 10535 10541 10543 10547 10550 10554 10558
10561 10563 10567 10572 10573 10574 10578 10582 10586 10590 10594 10598 10600
10602 10604 10608 10612 10616 10620 10624 10626 10628 10630 10632 10634 10636
10640 10644 10648 10652 10656 10660 10664 10666 10668 10670 10674 10678 10682
10686 10690 10692 10694 10696 10698 10700 10702 10706 10708 10712 10716 10720
10724 10729 10731 10735 10740 10741 10742 10749 10756 10763 10770 10777 10779
10781 10783 10785 10787 10789 10791 10793 10795 10797 10800 10804 10808 10812
10816 10819 10821 10823 10825 10827 10829 10831 10833 10837 10841 10845 10849
10853 10857 10861 10865 10869 10873 10877 10881 10883 10885 10890 10895 10897
10899 10901 10903 10905 10907 10909 10911 10913 10915 10919 10923 10927 10931
10935 10939 10943 10947 10951 10955 10959 10963 10965 10967 10969 10971 10976
10981 10983 10985 10987 10989 10991 10993 10995 10997 10999 11001 11003 11005
11009 11013 11017 11021 11025 11029 11033 11037 11041 11045 11049 11053 11055
11057 11059 11061 11066 11071 11073 11075 11077 11079 11081 11083 11085 11087
11089 11091 11093 11095 11098 11104 11109 11113 11118 11119 11129 11135 11141
11147 11153 11177 11199 11204 11209 11212 11213 11214 11218 11221 11224 11232
11233 11234 11252 11261 11273 11317 11389 11417 11473 11484 11594 11627 11654
11655 11661 11676 11697 11709 11721 11755 11758 11761 11809 11810 11811 11871
11875 11879 11883 11887 11891 11895 11899 11903
Maybe we should restrict loop size or any other better heuristic could have a
good estimation of register pressure?