diff --git a/src/hotspot/cpu/ppc/macroAssembler_ppc.cpp b/src/hotspot/cpu/ppc/macroAssembler_ppc.cpp index 7729d9ba592..095fd9c58fb 100644 --- a/src/hotspot/cpu/ppc/macroAssembler_ppc.cpp +++ b/src/hotspot/cpu/ppc/macroAssembler_ppc.cpp @@ -4013,105 +4013,6 @@ void MacroAssembler::update_1word_crc32(Register crc, Register buf, Register tab xorr(crc, t0, t2); // Now crc contains the final checksum value. } -/** - * @param crc register containing existing CRC (32-bit) - * @param buf register pointing to input byte buffer (byte*) - * @param len register containing number of bytes - * @param table register pointing to CRC table - * - * Uses R9..R12 as work register. Must be saved/restored by caller! - */ -void MacroAssembler::kernel_crc32_2word(Register crc, Register buf, Register len, Register table, - Register t0, Register t1, Register t2, Register t3, - Register tc0, Register tc1, Register tc2, Register tc3, - bool invertCRC) { - assert_different_registers(crc, buf, len, table); - - Label L_mainLoop, L_tail; - Register tmp = t0; - Register data = t0; - Register tmp2 = t1; - const int mainLoop_stepping = 8; - const int tailLoop_stepping = 1; - const int log_stepping = exact_log2(mainLoop_stepping); - const int mainLoop_alignment = 32; // InputForNewCode > 4 ? InputForNewCode : 32; - const int complexThreshold = 2*mainLoop_stepping; - - // Don't test for len <= 0 here. This pathological case should not occur anyway. - // Optimizing for it by adding a test and a branch seems to be a waste of CPU cycles - // for all well-behaved cases. The situation itself is detected and handled correctly - // within update_byteLoop_crc32. - assert(tailLoop_stepping == 1, "check tailLoop_stepping!"); - - BLOCK_COMMENT("kernel_crc32_2word {"); - - if (invertCRC) { - nand(crc, crc, crc); // 1s complement of crc - } - - // Check for short ( mainLoop_stepping) { - sub(len, len, tmp2); // Remaining bytes for main loop (>=mainLoop_stepping is guaranteed). - } else { - sub(tmp, len, tmp2); // Remaining bytes for main loop. - cmpdi(CCR0, tmp, mainLoop_stepping); - blt(CCR0, L_tail); // For less than one mainloop_stepping left, do only tail processing - mr(len, tmp); // remaining bytes for main loop (>=mainLoop_stepping is guaranteed). - } - update_byteLoop_crc32(crc, buf, tmp2, table, data, false); - } - - srdi(tmp2, len, log_stepping); // #iterations for mainLoop - andi(len, len, mainLoop_stepping-1); // remaining bytes for tailLoop - mtctr(tmp2); - -#ifdef VM_LITTLE_ENDIAN - Register crc_rv = crc; -#else - Register crc_rv = tmp; // Load_reverse needs separate registers to work on. - // Occupies tmp, but frees up crc. - load_reverse_32(crc_rv, crc); // Revert byte order because we are dealing with big-endian data. - tmp = crc; -#endif - - int reconstructTableOffset = crc32_table_columns(table, tc0, tc1, tc2, tc3); - - align(mainLoop_alignment); // Octoword-aligned loop address. Shows 2% improvement. - BIND(L_mainLoop); - update_1word_crc32(crc_rv, buf, table, 0, 0, crc_rv, t1, t2, t3, tc0, tc1, tc2, tc3); - update_1word_crc32(crc_rv, buf, table, 4, mainLoop_stepping, crc_rv, t1, t2, t3, tc0, tc1, tc2, tc3); - bdnz(L_mainLoop); - -#ifndef VM_LITTLE_ENDIAN - load_reverse_32(crc, crc_rv); // Revert byte order because we are dealing with big-endian data. - tmp = crc_rv; // Tmp uses it's original register again. -#endif - - // Restore original table address for tailLoop. - if (reconstructTableOffset != 0) { - addi(table, table, -reconstructTableOffset); - } - - // Process last few (