xor.go 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. package xor
  2. // SIMD Extensions
  3. const (
  4. none = iota
  5. avx2
  6. // first introduced by Intel with the initial version of the Pentium 4 in 2001
  7. // so I think we can assume all amd64 has sse2
  8. sse2
  9. )
  10. var extension = none
  11. // Bytes : chose the shortest one as xor size
  12. // it's better to use it for big data ( > 64bytes )
  13. func Bytes(dst, src0, src1 []byte) {
  14. size := len(dst)
  15. if size > len(src0) {
  16. size = len(src0)
  17. }
  18. if size > len(src1) {
  19. size = len(src1)
  20. }
  21. xorBytes(dst, src0, src1, size)
  22. }
  23. // BytesSameLen : all slice's length must be equal
  24. // cut size branch, save time for small data
  25. func BytesSameLen(dst, src0, src1 []byte) {
  26. xorSrc1(dst, src0, src1)
  27. }
  28. // BytesSrc0 : src1 >= src0, dst >= src0
  29. // xor src0's len bytes
  30. func BytesSrc0(dst, src0, src1 []byte) {
  31. xorSrc0(dst, src0, src1)
  32. }
  33. // BytesSrc1 : src0 >= src1, dst >= src1
  34. // xor src1's len bytes
  35. func BytesSrc1(dst, src0, src1 []byte) {
  36. xorSrc1(dst, src0, src1)
  37. }
  38. // Matrix : all slice's length must be equal && != 0
  39. // len(src) must >= 2
  40. func Matrix(dst []byte, src [][]byte) {
  41. xorMatrix(dst, src)
  42. }