📄 ztrsm_kernel_hummer_lt.s
字号:
slwi TEMP, r0, 2 + ZBASE_SHIFT slwi r0, r0, 1 + ZBASE_SHIFT add AO, AORIG, TEMP add BO, B, r0 addi AO2, AO, 2 * SIZE addi BO, BO, - 4 * SIZE addi BO2, BO, 2 * SIZE#endif#if defined(LN) || defined(LT) LFPDUX f16, BO, INC4 LFPDUX f20, BO2, INC4 LFPDUX f17, BO, INC4 LFPDUX f21, BO2, INC4 LFPDUX f18, BO, INC4 LFPDUX f22, BO2, INC4 LFPDUX f19, BO, INC4 LFPDUX f23, BO2, INC4 subi BO, BO, 16 * SIZE subi BO2, BO2, 16 * SIZE#else LFPDUX f16, AO, INC4 LFPDUX f17, AO2, INC4 LFPDUX f18, AO, INC4 LFPDUX f19, AO2, INC4 LFPDUX f20, AO, INC4 LFPDUX f21, AO2, INC4 LFPDUX f22, AO, INC4 LFPDUX f23, AO2, INC4 subi AO, AO, 16 * SIZE subi AO2, AO2, 16 * SIZE#endif fpsub f0, f16, f0 fpsub f1, f17, f1 fpsub f2, f18, f2 fpsub f3, f19, f3 fpsub f8, f20, f8 fpsub f9, f21, f9 fpsub f10, f22, f10 fpsub f11, f23, f11#ifdef LN LFPDUX A1, AO, INC4 add AO2, AO2, INC4 add AO, AO, INC4 add AO2, AO2, INC4 LFPDUX A2, AO, INC4 LFPDUX A3, AO2, INC4 add AO, AO, INC4 add AO2, AO2, INC4 LFPDUX A4, AO, INC4 LFPDUX A5, AO2, INC4 LFPDUX A6, AO, INC4 add AO2, AO2, INC4 LFPDUX A7, AO, INC4 LFPDUX A8, AO2, INC4 LFPDUX A9, AO, INC4 LFPDUX A10, AO2, INC4 subi AO, AO, 32 * SIZE subi AO2, AO2, 32 * SIZE fxpmul f4, A10, f3 fxpmul f5, A10, f11 FXCXNPMA f3, A10, f3, f4 FXCXNPMA f11, A10, f11, f5 fxcpnmsub f2, A9, f3, f2 fxcpnmsub f10, A9, f11, f10 FXCXNSMA f2, A9, f3, f2 FXCXNSMA f10, A9, f11, f10 fxcpnmsub f1, A8, f3, f1 fxcpnmsub f9, A8, f11, f9 FXCXNSMA f1, A8, f3, f1 FXCXNSMA f9, A8, f11, f9 fxcpnmsub f0, A7, f3, f0 fxcpnmsub f8, A7, f11, f8 FXCXNSMA f0, A7, f3, f0 FXCXNSMA f8, A7, f11, f8 fxpmul f4, A6, f2 fxpmul f5, A6, f10 FXCXNPMA f2, A6, f2, f4 FXCXNPMA f10, A6, f10, f5 fxcpnmsub f1, A5, f2, f1 fxcpnmsub f9, A5, f10, f9 FXCXNSMA f1, A5, f2, f1 FXCXNSMA f9, A5, f10, f9 fxcpnmsub f0, A4, f2, f0 fxcpnmsub f8, A4, f10, f8 FXCXNSMA f0, A4, f2, f0 FXCXNSMA f8, A4, f10, f8 fxpmul f4, A3, f1 fxpmul f5, A3, f9 FXCXNPMA f1, A3, f1, f4 FXCXNPMA f9, A3, f9, f5 fxcpnmsub f0, A2, f1, f0 fxcpnmsub f8, A2, f9, f8 FXCXNSMA f0, A2, f1, f0 FXCXNSMA f8, A2, f9, f8 fxpmul f4, A1, f0 fxpmul f5, A1, f8 FXCXNPMA f0, A1, f0, f4 FXCXNPMA f8, A1, f8, f5#endif#ifdef LT LFPDUX A1, AO, INC4 LFPDUX A2, AO2, INC4 LFPDUX A3, AO, INC4 LFPDUX A4, AO2, INC4 add AO, AO, INC4 LFPDUX A5, AO2, INC4 LFPDUX A6, AO, INC4 LFPDUX A7, AO2, INC4 add AO, AO, INC4 add AO2, AO2, INC4 LFPDUX A8, AO, INC4 LFPDUX A9, AO2, INC4 add AO, AO, INC4 add AO2, AO2, INC4 add AO, AO, INC4 LFPDUX A10, AO2, INC4 subi AO, AO, 32 * SIZE subi AO2, AO2, 32 * SIZE fxpmul f4, A1, f0 fxpmul f5, A1, f8 FXCXNPMA f0, A1, f0, f4 FXCXNPMA f8, A1, f8, f5 fxcpnmsub f1, A2, f0, f1 fxcpnmsub f9, A2, f8, f9 FXCXNSMA f1, A2, f0, f1 FXCXNSMA f9, A2, f8, f9 fxcpnmsub f2, A3, f0, f2 fxcpnmsub f10, A3, f8, f10 FXCXNSMA f2, A3, f0, f2 FXCXNSMA f10, A3, f8, f10 fxcpnmsub f3, A4, f0, f3 fxcpnmsub f11, A4, f8, f11 FXCXNSMA f3, A4, f0, f3 FXCXNSMA f11, A4, f8, f11 fxpmul f6, A5, f1 fxpmul f7, A5, f9 FXCXNPMA f1, A5, f1, f6 FXCXNPMA f9, A5, f9, f7 fxcpnmsub f2, A6, f1, f2 fxcpnmsub f10, A6, f9, f10 FXCXNSMA f2, A6, f1, f2 FXCXNSMA f10, A6, f9, f10 fxcpnmsub f3, A7, f1, f3 fxcpnmsub f11, A7, f9, f11 FXCXNSMA f3, A7, f1, f3 FXCXNSMA f11, A7, f9, f11 fxpmul f4, A8, f2 fxpmul f5, A8, f10 FXCXNPMA f2, A8, f2, f4 FXCXNPMA f10, A8, f10, f5 fxcpnmsub f3, A9, f2, f3 fxcpnmsub f11, A9, f10, f11 FXCXNSMA f3, A9, f2, f3 FXCXNSMA f11, A9, f10, f11 fxpmul f6, A10, f3 fxpmul f7, A10, f11 FXCXNPMA f3, A10, f3, f6 FXCXNPMA f11, A10, f11, f7#endif#ifdef RN LFPDUX A1, BO, INC4 LFPDUX A2, BO2, INC4 add BO, BO, INC4 LFPDUX A3, BO2, INC4 subi BO, BO, 8 * SIZE subi BO2, BO2, 8 * SIZE fxpmul f4, A1, f0 fxpmul f5, A1, f1 fxpmul f6, A1, f2 fxpmul f7, A1, f3 FXCXNPMA f0, A1, f0, f4 FXCXNPMA f1, A1, f1, f5 FXCXNPMA f2, A1, f2, f6 FXCXNPMA f3, A1, f3, f7 fxcpnmsub f8, A2, f0, f8 fxcpnmsub f9, A2, f1, f9 fxcpnmsub f10, A2, f2, f10 fxcpnmsub f11, A2, f3, f11 FXCXNSMA f8, A2, f0, f8 FXCXNSMA f9, A2, f1, f9 FXCXNSMA f10, A2, f2, f10 FXCXNSMA f11, A2, f3, f11 fxpmul f4, A3, f8 fxpmul f5, A3, f9 fxpmul f6, A3, f10 fxpmul f7, A3, f11 FXCXNPMA f8, A3, f8, f4 FXCXNPMA f9, A3, f9, f5 FXCXNPMA f10, A3, f10, f6 FXCXNPMA f11, A3, f11, f7#endif#ifdef RT LFPDUX A1, BO, INC4 add BO2, BO2, INC4 LFPDUX A2, BO, INC4 LFPDUX A3, BO2, INC4 subi BO, BO, 8 * SIZE subi BO2, BO2, 8 * SIZE fxpmul f4, A3, f8 fxpmul f5, A3, f9 fxpmul f6, A3, f10 fxpmul f7, A3, f11 FXCXNPMA f8, A3, f8, f4 FXCXNPMA f9, A3, f9, f5 FXCXNPMA f10, A3, f10, f6 FXCXNPMA f11, A3, f11, f7 fxcpnmsub f0, A2, f8, f0 fxcpnmsub f1, A2, f9, f1 fxcpnmsub f2, A2, f10, f2 fxcpnmsub f3, A2, f11, f3 FXCXNSMA f0, A2, f8, f0 FXCXNSMA f1, A2, f9, f1 FXCXNSMA f2, A2, f10, f2 FXCXNSMA f3, A2, f11, f3 fxpmul f4, A1, f0 fxpmul f5, A1, f1 fxpmul f6, A1, f2 fxpmul f7, A1, f3 FXCXNPMA f0, A1, f0, f4 FXCXNPMA f1, A1, f1, f5 FXCXNPMA f2, A1, f2, f6 FXCXNPMA f3, A1, f3, f7#endif#ifdef LN subi CO1, CO1, 8 * SIZE subi CO2, CO2, 8 * SIZE#endif#if defined(LN) || defined(LT) STFPDUX f0, BO, INC4 STFPDUX f8, BO2, INC4 STFPDUX f1, BO, INC4 STFPDUX f9, BO2, INC4 STFPDUX f2, BO, INC4 STFPDUX f10, BO2, INC4 STFPDUX f3, BO, INC4 STFPDUX f11, BO2, INC4 subi BO, BO, 16 * SIZE subi BO2, BO2, 16 * SIZE#else STFPDUX f0, AO, INC4 STFPDUX f1, AO2, INC4 STFPDUX f2, AO, INC4 STFPDUX f3, AO2, INC4 STFPDUX f8, AO, INC4 STFPDUX f9, AO2, INC4 STFPDUX f10, AO, INC4 STFPDUX f11, AO2, INC4 subi AO, AO, 16 * SIZE subi AO2, AO2, 16 * SIZE#endif STFDUX f0, CO1, INC STFSDUX f0, CO1, INC STFDUX f1, CO1, INC STFSDUX f1, CO1, INC STFDUX f2, CO1, INC STFSDUX f2, CO1, INC STFDUX f3, CO1, INC STFSDUX f3, CO1, INC STFDUX f8, CO2, INC STFSDUX f8, CO2, INC STFDUX f9, CO2, INC STFSDUX f9, CO2, INC STFDUX f10, CO2, INC STFSDUX f10, CO2, INC STFDUX f11, CO2, INC STFSDUX f11, CO2, INC#ifdef LN subi CO1, CO1, 8 * SIZE subi CO2, CO2, 8 * SIZE#endif#ifdef RT slwi r0, K, 2 + ZBASE_SHIFT add AORIG, AORIG, r0#endif#if defined(LT) || defined(RN) sub TEMP, K, KK slwi r0, TEMP, 2 + ZBASE_SHIFT slwi TEMP, TEMP, 1 + ZBASE_SHIFT add AO, AO, r0 add BO, BO, TEMP#endif#ifdef LT addi KK, KK, 4#endif#ifdef LN subi KK, KK, 4#endif addic. I, I, -1 li r0, FZERO lfpsx f0, SP, r0 bgt+ .L11 .align 4.L20: andi. I, M, 2 beq .L30#if defined(LT) || defined(RN) addi AO2, AO, 2 * SIZE fpmr f4, f0 addi BO, B, - 4 * SIZE fpmr f8, f0 addi BO2, B, - 2 * SIZE fpmr f12, f0 srawi. r0, KK, 2 fpmr f1, f0 fpmr f5, f0 fpmr f9, f0 mtspr CTR, r0 fpmr f13, f0 ble .L24#else#ifdef LN slwi r0, K, 1 + ZBASE_SHIFT sub AORIG, AORIG, r0#endif slwi r0 , KK, 1 + ZBASE_SHIFT add AO, AORIG, r0 add BO, B, r0 sub TEMP, K, KK addi AO2, AO, 2 * SIZE fpmr f4, f0 addi BO, BO, - 4 * SIZE fpmr f8, f0 addi BO2, BO, 2 * SIZE fpmr f12, f0 fpmr f1, f0 fpmr f5, f0 fpmr f9, f0 fpmr f13, f0 srawi. r0, TEMP, 2 mtspr CTR, r0 ble .L24#endif LFPDUX A1, AO, INC4 LFPDUX B1, BO, INC4 LFPDUX A2, AO2, INC4 LFPDUX B2, BO2, INC4 LFPDUX A3, AO, INC4 LFPDUX B3, BO, INC4 LFPDUX A4, AO2, INC4 LFPDUX B4, BO2, INC4 LFPDUX A5, AO, INC4 LFPDUX B5, BO, INC4 LFPDUX A6, AO2, INC4 LFPDUX B6, BO2, INC4 LFPDUX A7, AO, INC4 LFPDUX A9, BO, INC4 LFPDUX A10, BO2, INC4 bdz- .L23 .align 4.L22: FXCPMADD f0, B1, A1, f0 nop FXCSMADD f4, B1, A1, f4 LFPDUX A8, AO2, INC4 FXCPMADD f8, B2, A1, f8 nop FXCSMADD f12, B2, A1, f12 LFPDUX A1, AO, INC4 FXCPMADD f1, B1, A2, f1 nop FXCSMADD f5, B1, A2, f5 LFPDUX B1, BO, INC4 FXCPMADD f9, B2, A2, f9 nop FXCSMADD f13, B2, A2, f13 LFPDUX B2, BO2, INC4 FXCPMADD f0, B3, A3, f0 nop FXCSMADD f4, B3, A3, f4 LFPDUX A2, AO2, INC4 FXCPMADD f8, B4, A3, f8 nop FXCSMADD f12, B4, A3, f12 LFPDUX A3, AO, INC4 FXCPMADD f1, B3, A4, f1 nop FXCSMADD f5, B3, A4, f5 LFPDUX B3, BO, INC4 FXCPMADD f9, B4, A4, f9 nop FXCSMADD f13, B4, A4, f13 LFPDUX B4, BO2, INC4 FXCPMADD f0, B5, A5, f0 nop FXCSMADD f4, B5, A5, f4 LFPDUX A4, AO2, INC4 FXCPMADD f8, B6, A5, f8 nop FXCSMADD f12, B6, A5, f12 LFPDUX A5, AO, INC4 FXCPMADD f1, B5, A6, f1 nop FXCSMADD f5, B5, A6, f5 LFPDUX B5, BO, INC4 FXCPMADD f9, B6, A6, f9 nop FXCSMADD f13, B6, A6, f13 LFPDUX B6, BO2, INC4 FXCPMADD f0, A9, A7, f0 nop FXCSMADD f4, A9, A7, f4 LFPDUX A6, AO2, INC4 FXCPMADD f8, A10, A7, f8 nop FXCSMADD f12, A10, A7, f12 LFPDUX A7, AO, INC4 FXCPMADD f1, A9, A8, f1 nop FXCSMADD f5, A9, A8, f5 LFPDUX A9, BO, INC4 FXCPMADD f9, A10, A8, f9 nop FXCSMADD f13, A10, A8, f13 LFPDUX A10, BO2, INC4 bdnz+ .L22 .align 4.L23: FXCPMADD f0, B1, A1, f0 FXCSMADD f4, B1, A1, f4 LFPDUX A8, AO2, INC4 FXCPMADD f8, B2, A1, f8 FXCSMADD f12, B2, A1, f12 FXCPMADD f1, B1, A2, f1 FXCSMADD f5, B1, A2, f5 FXCPMADD f9, B2, A2, f9 FXCSMADD f13, B2, A2, f13 FXCPMADD f0, B3, A3, f0 FXCSMADD f4, B3, A3, f4 FXCPMADD f8, B4, A3, f8 FXCSMADD f12, B4, A3, f12 FXCPMADD f1, B3, A4, f1 FXCSMADD f5, B3, A4, f5 FXCPMADD f9, B4, A4, f9 FXCSMADD f13, B4, A4, f13 FXCPMADD f0, B5, A5, f0 FXCSMADD f4, B5, A5, f4 FXCPMADD f8, B6, A5, f8 FXCSMADD f12, B6, A5, f12 FXCPMADD f1, B5, A6, f1 FXCSMADD f5, B5, A6, f5 FXCPMADD f9, B6, A6, f9 FXCSMADD f13, B6, A6, f13 FXCPMADD f0, A9, A7, f0 FXCSMADD f4, A9, A7, f4 FXCPMADD f8, A10, A7, f8 FXCSMADD f12, A10, A7, f12 FXCPMADD f1, A9, A8, f1 FXCSMADD f5, A9, A8, f5 FXCPMADD f9, A10, A8, f9 FXCSMADD f13, A10, A8, f13 .align 4.L24:#if defined(LT) || defined(RN) andi. r0, KK, 3 mtspr CTR, r0 ble+ .L28#else andi. r0, TEMP, 3 mtspr CTR, r0 ble+ .L28#endif LFPDUX A1, AO, INC4 LFPDUX A2, AO2, INC4 LFPDUX B1, BO, INC4 LFPDUX B2, BO2, INC4 bdz- .L27 .align 4.L26: FXCPMADD f0, B1, A1, f0 FXCSMADD f4, B1, A1, f4 FXCPMADD f8, B2, A1, f8 FXCSMADD f12, B2, A1, f12 LFPDUX A1, AO, INC4 FXCPMADD f1, B1, A2, f1 FXCSMADD f5, B1, A2, f5 LFPDUX B1, BO, INC4 FXCPMADD f9, B2, A2, f9 FXCSMADD f13, B2, A2, f13 LFPDUX A2, AO2, INC4 LFPDUX B2, BO2, INC4 bdnz+ .L26 .align 4.L27: FXCPMADD f0, B1, A1, f0 FXCSMADD f4, B1, A1, f4 FXCPMADD f8, B2, A1, f8 FXCSMADD f12, B2, A1, f12 FXCPMADD f1, B1, A2, f1 FXCSMADD f5, B1, A2, f5 FXCPMADD f9, B2, A2, f9 FXCSMADD f13, B2, A2, f13 .align 4.L28: fpadd f0, f0, f4 fpadd f8, f8, f12 fpadd f1, f1, f5 fpadd f9, f9, f13#if defined(LN) || defined(RT)#ifdef LN subi r0, KK, 2#else subi r0, KK, 2#endif slwi r0, r0, 1 + ZBASE_SHIFT add AO, AORIG, r0 add BO, B, r0 addi AO2, AO, 2 * SIZE addi BO, BO, - 4 * SIZE addi BO2, BO, 2 * SIZE#endif#if defined(LN) || defined(LT) LFPDUX f16, BO, INC4 LFPDUX f18, BO2, INC4 LFPDUX f17, BO, INC4 LFPDUX f19, BO2, INC4 subi BO, BO, 8 * SIZE subi BO2, BO2, 8 * SIZE#else LFPDUX f16, AO, INC4 LFPDUX f17, AO2, INC4 LFPDUX f18, AO, INC4 LFPDUX f19, AO2, INC4 subi AO, AO, 8 * SIZE subi AO2, AO2, 8 * SIZE#endif fpsub f0, f16, f0 fpsub f1, f17, f1 fpsub f8, f18, f8 fpsub f9, f19, f9#ifdef LN LFPDUX A1, AO, INC4 add AO2, AO2, INC4 LFPDUX A2, AO, INC4 LFPDUX A3, AO2, INC4 subi AO, AO, 8 * SIZE subi AO2, AO2, 8 * SIZE fxpmul f4, A3, f1 fxpmul f5, A3, f9 FXCXNPMA f1, A3, f1, f4 FXCXNPMA f9, A3, f9, f5 fxcpnmsub f0, A2, f1, f0 fxcpnmsub f8, A2, f9, f8 FXCXNSMA f0, A2, f1, f0 FXCXNSMA f8, A2, f9, f8 fxpmul f4, A1, f0 fxpmul f5, A1, f8 FXCXNPMA f0, A1, f0, f4 FXCXNPMA f8, A1, f8, f5#endif#ifdef LT LFPDUX A1, AO, INC4 LFPDUX A2, AO2, INC4 add AO, AO, INC4 LFPDUX A3, AO2, INC4 subi AO, AO, 8 * SIZE subi AO2, AO2, 8 * SIZE fxpmul f4, A1, f0 fxpmul f5, A1, f8 FXCXNPMA f0, A1, f0, f4 FXCXNPMA f8, A1, f8, f5 fxcpnmsub f1, A2, f0, f1 fxcpnmsub f9, A2, f8, f9 FXCXNSMA f1, A2, f0, f1 FXCXNSMA f9, A2, f8, f9 fxpmul f6, A3, f1 fxpmul f7, A3, f9 FXCXNPMA f1, A3, f1, f6 FXCXNPMA f9, A3, f9, f7#endif#ifdef RN LFPDUX A1, BO, INC4 LFPDUX A2, BO2, INC4 add BO, BO, INC4 LFPDUX A3, BO2, INC4 subi BO, BO, 8 * SIZE subi BO2, BO2, 8 * SIZE fxpmul f4, A1, f0 fxpmul f5, A1, f1 FXCXNPMA f0, A1, f0, f4 FXCXNPMA f1, A1, f1, f5 fxcpnmsub f8, A2, f0, f8 fxcpnmsub f9, A2, f1, f9 FXCXNSMA f8, A2, f0, f8 FXCXNSMA f9, A2, f1, f9 fxpmul f4, A3, f8 fxpmul f5, A3, f9 FXCXNPMA f8, A3, f8, f4 FXCXNPMA f9, A3, f9, f5#endif#ifdef RT LFPDUX A1, BO, INC4 add BO2, BO2, INC4 LFPDUX A2, BO, INC4 LFPDUX A3, BO2, INC4 subi BO, BO, 8 * SIZE subi BO2, BO2, 8 * SIZE fxpmul f4, A3, f8 fxpmul f5, A3, f9 FXCXNPMA f8, A3, f8, f4 FXCXNPMA f9, A3, f9, f5 fxcpnmsub f0, A2, f8, f0 fxcpnmsub f1, A2, f9, f1 FXCXNSMA f0, A2, f8, f0 FXCXNSMA f1, A2, f9, f1 fxpmul f4, A1, f0 fxpmul f5, A1, f1 FXCXNPMA f0, A1, f0, f4 FXCXNPMA f1, A1, f1, f5#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -