Implementation notes: x86, cryptologic, crypto_sign/3icp

Computer: cryptologic
Architecture: x86
CPU ID: GenuineIntel-000206c2-bfebfbff
SUPERCOP version: 20140517
Operation: crypto_sign
Primitive: 3icp

Compiler output

Implementation: crypto_sign/3icp/ref
Compiler: g++ -m32 -O2 -fomit-frame-pointer
ThreeIC_p-test.cpp: In file included from gfv.h:3,
ThreeIC_p-test.cpp: from bqas.h:5,
ThreeIC_p-test.cpp: from ThreeIC_p.h:5,
ThreeIC_p-test.cpp: from ThreeIC_p-test.cpp:16:
ThreeIC_p-test.cpp: /usr/lib/gcc/x86_64-redhat-linux/4.1.2/include/emmintrin.h:34:3: error: #error "SSE2 instruction set not enabled"
ThreeIC_p-test.cpp: gfv.h:7: error: '__m128i' does not name a type
ThreeIC_p-test.cpp: gfv.h:12: error: expected ',' or '...' before '&' token
ThreeIC_p-test.cpp: gfv.h:12: error: ISO C++ forbids declaration of '__m128i' with no type
ThreeIC_p-test.cpp: gfv.h: In copy constructor 'gfvgt;::gfv(const gfvgt;&)':
ThreeIC_p-test.cpp: gfv.h:11: error: class 'gfvgt;' does not have any field named 'v'
ThreeIC_p-test.cpp: ...
ThreeIC_p-test.cpp: transpose8.h:37: error: initializer expression list treated as compound expression
ThreeIC_p-test.cpp: transpose8.h:37: error: expected ',' or ';' before '{' token
ThreeIC_p-test.cpp: gfv.h: In member function 'const gfvgt; gfvgt;::operator*(const gfvgt;&) const [with unsigned int p = 31u]':
ThreeIC_p-test.cpp: gfv.h:47: instantiated from here
ThreeIC_p-test.cpp: gfv.h:22: error: 'const struct gfvgt;' has no member named 'v'
ThreeIC_p-test.cpp: gfv.h:22: error: 'const struct gfvgt;' has no member named 'v'
ThreeIC_p-test.cpp: gfv.h:22: error: '_mm_mullo_epi16' was not declared in this scope
ThreeIC_p-test.cpp: gfv.h: In member function 'gfvgt;& gfvgt;::operator=(const gfvgt;&) [with unsigned int p = 31u]':
ThreeIC_p-test.cpp: gfv.h:48: instantiated from here
ThreeIC_p-test.cpp: gfv.h:14: error: 'const struct gfvgt;' has no member named 'v'

Number of similar (compiler,implementation) pairs: 48, namely:
CompilerImplementations
g++ -m32 -O2 -fomit-frame-pointer ref
g++ -m32 -O3 -fomit-frame-pointer ref
g++ -m32 -O -fomit-frame-pointer ref
g++ -m32 -Os -fomit-frame-pointer ref
g++ -m32 -march=athlon -O2 -fomit-frame-pointer ref
g++ -m32 -march=athlon -O3 -fomit-frame-pointer ref
g++ -m32 -march=athlon -O -fomit-frame-pointer ref
g++ -m32 -march=athlon -Os -fomit-frame-pointer ref
g++ -m32 -march=i386 -O2 -fomit-frame-pointer ref
g++ -m32 -march=i386 -O3 -fomit-frame-pointer ref
g++ -m32 -march=i386 -O -fomit-frame-pointer ref
g++ -m32 -march=i386 -Os -fomit-frame-pointer ref
g++ -m32 -march=i486 -O2 -fomit-frame-pointer ref
g++ -m32 -march=i486 -O3 -fomit-frame-pointer ref
g++ -m32 -march=i486 -O -fomit-frame-pointer ref
g++ -m32 -march=i486 -Os -fomit-frame-pointer ref
g++ -m32 -march=k6-2 -O2 -fomit-frame-pointer ref
g++ -m32 -march=k6-2 -O3 -fomit-frame-pointer ref
g++ -m32 -march=k6-2 -O -fomit-frame-pointer ref
g++ -m32 -march=k6-2 -Os -fomit-frame-pointer ref
g++ -m32 -march=k6-3 -O2 -fomit-frame-pointer ref
g++ -m32 -march=k6-3 -O3 -fomit-frame-pointer ref
g++ -m32 -march=k6-3 -O -fomit-frame-pointer ref
g++ -m32 -march=k6-3 -Os -fomit-frame-pointer ref
g++ -m32 -march=k6 -O2 -fomit-frame-pointer ref
g++ -m32 -march=k6 -O3 -fomit-frame-pointer ref
g++ -m32 -march=k6 -O -fomit-frame-pointer ref
g++ -m32 -march=k6 -Os -fomit-frame-pointer ref
g++ -m32 -march=pentium-mmx -O2 -fomit-frame-pointer ref
g++ -m32 -march=pentium-mmx -O3 -fomit-frame-pointer ref
g++ -m32 -march=pentium-mmx -O -fomit-frame-pointer ref
g++ -m32 -march=pentium-mmx -Os -fomit-frame-pointer ref
g++ -m32 -march=pentium2 -O2 -fomit-frame-pointer ref
g++ -m32 -march=pentium2 -O3 -fomit-frame-pointer ref
g++ -m32 -march=pentium2 -O -fomit-frame-pointer ref
g++ -m32 -march=pentium2 -Os -fomit-frame-pointer ref
g++ -m32 -march=pentium3 -O2 -fomit-frame-pointer ref
g++ -m32 -march=pentium3 -O3 -fomit-frame-pointer ref
g++ -m32 -march=pentium3 -O -fomit-frame-pointer ref
g++ -m32 -march=pentium3 -Os -fomit-frame-pointer ref
g++ -m32 -march=pentium -O2 -fomit-frame-pointer ref
g++ -m32 -march=pentium -O3 -fomit-frame-pointer ref
g++ -m32 -march=pentium -O -fomit-frame-pointer ref
g++ -m32 -march=pentium -Os -fomit-frame-pointer ref
g++ -m32 -march=pentiumpro -O2 -fomit-frame-pointer ref
g++ -m32 -march=pentiumpro -O3 -fomit-frame-pointer ref
g++ -m32 -march=pentiumpro -O -fomit-frame-pointer ref
g++ -m32 -march=pentiumpro -Os -fomit-frame-pointer ref

Compiler output

Implementation: crypto_sign/3icp/ref
Compiler: g++ -m32 -march=core2 -O2 -fomit-frame-pointer
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 13u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 7u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 12u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 6u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: tower.h: In function 'const gftowergt; square(const gftowergt;&) [with unsigned int p = 31u, unsigned int pow = 9u]':
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: ...
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate

Number of similar (compiler,implementation) pairs: 2, namely:
CompilerImplementations
g++ -m32 -march=core2 -O2 -fomit-frame-pointer ref
g++ -m32 -march=core2 -O -fomit-frame-pointer ref

Compiler output

Implementation: crypto_sign/3icp/ref
Compiler: g++ -m32 -march=core2 -O3 -fomit-frame-pointer
ThreeIC_p-test.cpp: conversion.h: In function 'int verification(const unsigned char*, long long unsigned int, const unsigned char*, long long unsigned int, const unsigned char*, long long unsigned int)':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: tower.h: In function 'const gftowergt; square(const gftowergt;&) [with unsigned int p = 31u, unsigned int pow = 9u]':
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h: In function 'void _mult(gftowergt;*, const gftowergt;*, const gftowergt;*) [with unsigned int p = 31u, unsigned int pow = 9u]':
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: ...
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
g++ -m32 -march=core2 -O3 -fomit-frame-pointer ref

Compiler output

Implementation: crypto_sign/3icp/ref
Compiler: g++ -m32 -march=core2 -Os -fomit-frame-pointer
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 13u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 7u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 12u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 6u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: tower.h: In function 'long long int __vector__ srli2(long long int __vector__, long long int __vector__, int)':
ThreeIC_p-test.cpp: tower.h:364: error: shift must be an immediate

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
g++ -m32 -march=core2 -Os -fomit-frame-pointer ref

Compiler output

Implementation: crypto_sign/3icp/ref
Compiler: g++ -m32 -march=k8 -O2 -fomit-frame-pointer
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 13u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 7u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 12u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 6u]':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'

Number of similar (compiler,implementation) pairs: 15, namely:
CompilerImplementations
g++ -m32 -march=k8 -O2 -fomit-frame-pointer ref
g++ -m32 -march=k8 -O -fomit-frame-pointer ref
g++ -m32 -march=k8 -Os -fomit-frame-pointer ref
g++ -m32 -march=nocona -O2 -fomit-frame-pointer ref
g++ -m32 -march=nocona -O -fomit-frame-pointer ref
g++ -m32 -march=nocona -Os -fomit-frame-pointer ref
g++ -m32 -march=pentium-m -O2 -fomit-frame-pointer ref
g++ -m32 -march=pentium-m -O -fomit-frame-pointer ref
g++ -m32 -march=pentium-m -Os -fomit-frame-pointer ref
g++ -m32 -march=pentium4 -O2 -fomit-frame-pointer ref
g++ -m32 -march=pentium4 -O -fomit-frame-pointer ref
g++ -m32 -march=pentium4 -Os -fomit-frame-pointer ref
g++ -m32 -march=prescott -O2 -fomit-frame-pointer ref
g++ -m32 -march=prescott -O -fomit-frame-pointer ref
g++ -m32 -march=prescott -Os -fomit-frame-pointer ref

Compiler output

Implementation: crypto_sign/3icp/ref
Compiler: g++ -m32 -march=k8 -O3 -fomit-frame-pointer
ThreeIC_p-test.cpp: conversion.h: In function 'int verification(const unsigned char*, long long unsigned int, const unsigned char*, long long unsigned int, const unsigned char*, long long unsigned int)':
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
ThreeIC_p-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
g++ -m32 -march=k8 -O3 -fomit-frame-pointer ref
g++ -m32 -march=nocona -O3 -fomit-frame-pointer ref
g++ -m32 -march=pentium-m -O3 -fomit-frame-pointer ref
g++ -m32 -march=pentium4 -O3 -fomit-frame-pointer ref
g++ -m32 -march=prescott -O3 -fomit-frame-pointer ref