181 // zero heap space aligned to jlong (8 bytes)
182 static address _zero_aligned_words;
183
184 static address _aescrypt_encryptBlock;
185 static address _aescrypt_decryptBlock;
186 static address _cipherBlockChaining_encryptAESCrypt;
187 static address _cipherBlockChaining_decryptAESCrypt;
188 static address _ghash_processBlocks;
189
190 static address _sha1_implCompress;
191 static address _sha1_implCompressMB;
192 static address _sha256_implCompress;
193 static address _sha256_implCompressMB;
194 static address _sha512_implCompress;
195 static address _sha512_implCompressMB;
196
197 static address _updateBytesCRC32;
198 static address _crc_table_adr;
199
200 static address _updateBytesCRC32C;
201
202 static address _multiplyToLen;
203 static address _squareToLen;
204 static address _mulAdd;
205 static address _montgomeryMultiply;
206 static address _montgomerySquare;
207
208 // These are versions of the java.lang.Math methods which perform
209 // the same operations as the intrinsic version. They are used for
210 // constant folding in the compiler to ensure equivalence. If the
211 // intrinsic version returns the same result as the strict version
212 // then they can be set to the appropriate function from
213 // SharedRuntime.
214 static double (*_intrinsic_log)(double);
215 static double (*_intrinsic_log10)(double);
216 static double (*_intrinsic_exp)(double);
217 static double (*_intrinsic_pow)(double, double);
218 static double (*_intrinsic_sin)(double);
219 static double (*_intrinsic_cos)(double);
220 static double (*_intrinsic_tan)(double);
347 static address arrayof_jshort_fill() { return _arrayof_jshort_fill; }
348 static address arrayof_jint_fill() { return _arrayof_jint_fill; }
349
350 static address aescrypt_encryptBlock() { return _aescrypt_encryptBlock; }
351 static address aescrypt_decryptBlock() { return _aescrypt_decryptBlock; }
352 static address cipherBlockChaining_encryptAESCrypt() { return _cipherBlockChaining_encryptAESCrypt; }
353 static address cipherBlockChaining_decryptAESCrypt() { return _cipherBlockChaining_decryptAESCrypt; }
354 static address ghash_processBlocks() { return _ghash_processBlocks; }
355
356 static address sha1_implCompress() { return _sha1_implCompress; }
357 static address sha1_implCompressMB() { return _sha1_implCompressMB; }
358 static address sha256_implCompress() { return _sha256_implCompress; }
359 static address sha256_implCompressMB() { return _sha256_implCompressMB; }
360 static address sha512_implCompress() { return _sha512_implCompress; }
361 static address sha512_implCompressMB() { return _sha512_implCompressMB; }
362
363 static address updateBytesCRC32() { return _updateBytesCRC32; }
364 static address crc_table_addr() { return _crc_table_adr; }
365
366 static address updateBytesCRC32C() { return _updateBytesCRC32C; }
367
368 static address multiplyToLen() {return _multiplyToLen; }
369 static address squareToLen() {return _squareToLen; }
370 static address mulAdd() {return _mulAdd; }
371 static address montgomeryMultiply() { return _montgomeryMultiply; }
372 static address montgomerySquare() { return _montgomerySquare; }
373
374 static address select_fill_function(BasicType t, bool aligned, const char* &name);
375
376 static address zero_aligned_words() { return _zero_aligned_words; }
377
378 static double intrinsic_log(double d) {
379 assert(_intrinsic_log != NULL, "must be defined");
380 return _intrinsic_log(d);
381 }
382 static double intrinsic_log10(double d) {
383 assert(_intrinsic_log != NULL, "must be defined");
384 return _intrinsic_log10(d);
385 }
386 static double intrinsic_exp(double d) {
|
181 // zero heap space aligned to jlong (8 bytes)
182 static address _zero_aligned_words;
183
184 static address _aescrypt_encryptBlock;
185 static address _aescrypt_decryptBlock;
186 static address _cipherBlockChaining_encryptAESCrypt;
187 static address _cipherBlockChaining_decryptAESCrypt;
188 static address _ghash_processBlocks;
189
190 static address _sha1_implCompress;
191 static address _sha1_implCompressMB;
192 static address _sha256_implCompress;
193 static address _sha256_implCompressMB;
194 static address _sha512_implCompress;
195 static address _sha512_implCompressMB;
196
197 static address _updateBytesCRC32;
198 static address _crc_table_adr;
199
200 static address _updateBytesCRC32C;
201 static address _updateBytesAdler32;
202
203 static address _multiplyToLen;
204 static address _squareToLen;
205 static address _mulAdd;
206 static address _montgomeryMultiply;
207 static address _montgomerySquare;
208
209 // These are versions of the java.lang.Math methods which perform
210 // the same operations as the intrinsic version. They are used for
211 // constant folding in the compiler to ensure equivalence. If the
212 // intrinsic version returns the same result as the strict version
213 // then they can be set to the appropriate function from
214 // SharedRuntime.
215 static double (*_intrinsic_log)(double);
216 static double (*_intrinsic_log10)(double);
217 static double (*_intrinsic_exp)(double);
218 static double (*_intrinsic_pow)(double, double);
219 static double (*_intrinsic_sin)(double);
220 static double (*_intrinsic_cos)(double);
221 static double (*_intrinsic_tan)(double);
348 static address arrayof_jshort_fill() { return _arrayof_jshort_fill; }
349 static address arrayof_jint_fill() { return _arrayof_jint_fill; }
350
351 static address aescrypt_encryptBlock() { return _aescrypt_encryptBlock; }
352 static address aescrypt_decryptBlock() { return _aescrypt_decryptBlock; }
353 static address cipherBlockChaining_encryptAESCrypt() { return _cipherBlockChaining_encryptAESCrypt; }
354 static address cipherBlockChaining_decryptAESCrypt() { return _cipherBlockChaining_decryptAESCrypt; }
355 static address ghash_processBlocks() { return _ghash_processBlocks; }
356
357 static address sha1_implCompress() { return _sha1_implCompress; }
358 static address sha1_implCompressMB() { return _sha1_implCompressMB; }
359 static address sha256_implCompress() { return _sha256_implCompress; }
360 static address sha256_implCompressMB() { return _sha256_implCompressMB; }
361 static address sha512_implCompress() { return _sha512_implCompress; }
362 static address sha512_implCompressMB() { return _sha512_implCompressMB; }
363
364 static address updateBytesCRC32() { return _updateBytesCRC32; }
365 static address crc_table_addr() { return _crc_table_adr; }
366
367 static address updateBytesCRC32C() { return _updateBytesCRC32C; }
368 static address updateBytesAdler32() { return _updateBytesAdler32; }
369
370 static address multiplyToLen() {return _multiplyToLen; }
371 static address squareToLen() {return _squareToLen; }
372 static address mulAdd() {return _mulAdd; }
373 static address montgomeryMultiply() { return _montgomeryMultiply; }
374 static address montgomerySquare() { return _montgomerySquare; }
375
376 static address select_fill_function(BasicType t, bool aligned, const char* &name);
377
378 static address zero_aligned_words() { return _zero_aligned_words; }
379
380 static double intrinsic_log(double d) {
381 assert(_intrinsic_log != NULL, "must be defined");
382 return _intrinsic_log(d);
383 }
384 static double intrinsic_log10(double d) {
385 assert(_intrinsic_log != NULL, "must be defined");
386 return _intrinsic_log10(d);
387 }
388 static double intrinsic_exp(double d) {
|