You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
24 lines
922 B
24 lines
922 B
10 years ago
|
// +build amd64
|
||
|
|
||
|
package sha256
|
||
|
|
||
|
// #cgo CFLAGS: -DHAS_SSE41 -DHAS_AVX -DHAS_AVX2
|
||
|
// #include <stdint.h>
|
||
|
// void sha256_transform_ssse3 (const char *input_data, uint32_t *digest, unsigned long num_blks);
|
||
|
// void sha256_transform_avx (const char *input_data, uint32_t *digest, unsigned long num_blks);
|
||
|
// void sha256_transform_rorx (const char *input_data, uint32_t *digest, unsigned long num_blks);
|
||
|
import "C"
|
||
|
import "unsafe"
|
||
|
|
||
|
func blockSSE(dig *digest, p []byte) {
|
||
|
C.sha256_transform_ssse3((*C.char)(unsafe.Pointer(&p[0])), (*C.uint32_t)(unsafe.Pointer(&dig.h[0])), (C.ulong)(len(p)/64))
|
||
|
}
|
||
|
|
||
|
func blockAVX(dig *digest, p []byte) {
|
||
|
C.sha256_transform_avx((*C.char)(unsafe.Pointer(&p[0])), (*C.uint32_t)(unsafe.Pointer(&dig.h[0])), (C.ulong)(len(p)/64))
|
||
|
}
|
||
|
|
||
|
func blockAVX2(dig *digest, p []byte) {
|
||
|
C.sha256_transform_rorx((*C.char)(unsafe.Pointer(&p[0])), (*C.uint32_t)(unsafe.Pointer(&dig.h[0])), (C.ulong)(len(p)/64))
|
||
|
}
|