Implementation notes: x86, trident, crypto_encrypt/3hfe

Computer: trident
Architecture: x86
CPU ID: GenuineIntel-000006fb-bfebfbff
SUPERCOP version: 20121016
Operation: crypto_encrypt
Primitive: 3hfe

Compiler output

Implementation: crypto_encrypt/3hfe/ref
Compiler: g++
HFE-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 12u]':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 3u]':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 13u]':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'

Number of similar (compiler,implementation) pairs: 35, namely:
CompilerImplementations
g++ ref
g++ -O2 -fomit-frame-pointer ref
g++ -O -fomit-frame-pointer ref
g++ -fno-schedule-insns -O2 -fomit-frame-pointer ref
g++ -fno-schedule-insns -O -fomit-frame-pointer ref
g++ -m32 -O2 -fomit-frame-pointer ref
g++ -m32 -O -fomit-frame-pointer ref
g++ -m32 -march=k8 -O2 -fomit-frame-pointer ref
g++ -m32 -march=k8 -O -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=pentium-m -O2 -fomit-frame-pointer ref
g++ -m32 -march=pentium-m -O -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=prescott -O2 -fomit-frame-pointer ref
g++ -m32 -march=prescott -O -fomit-frame-pointer ref
g++ -m32 -mcpu=G4 -O2 -fomit-frame-pointer ref
g++ -m32 -mcpu=G4 -O -fomit-frame-pointer ref
g++ -m32 -mcpu=G5 -O2 -fomit-frame-pointer ref
g++ -m32 -mcpu=G5 -O -fomit-frame-pointer ref
g++ -march=k8 -O2 -fomit-frame-pointer ref
g++ -march=k8 -O -fomit-frame-pointer ref
g++ -march=nocona -O2 -fomit-frame-pointer ref
g++ -march=nocona -O -fomit-frame-pointer ref
g++ -march=pentium-m -O2 -fomit-frame-pointer ref
g++ -march=pentium-m -O -fomit-frame-pointer ref
g++ -march=pentium4 -O2 -fomit-frame-pointer ref
g++ -march=pentium4 -O -fomit-frame-pointer ref
g++ -march=prescott -O2 -fomit-frame-pointer ref
g++ -march=prescott -O -fomit-frame-pointer ref
g++ -mcpu=G4 -O2 -fomit-frame-pointer ref
g++ -mcpu=G4 -O -fomit-frame-pointer ref
g++ -mcpu=G5 -O2 -fomit-frame-pointer ref
g++ -mcpu=G5 -O -fomit-frame-pointer ref

Compiler output

Implementation: crypto_encrypt/3hfe/ref
Compiler: g++ -O3 -fomit-frame-pointer
HFE-test.cpp: conversion.h: In function 'int shortplaintext(unsigned char*, long long unsigned int*, const unsigned char*, long long unsigned int, const unsigned char*, long long unsigned int)':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'

Number of similar (compiler,implementation) pairs: 17, namely:
CompilerImplementations
g++ -O3 -fomit-frame-pointer ref
g++ -fno-schedule-insns -O3 -fomit-frame-pointer ref
g++ -m32 -O3 -fomit-frame-pointer ref
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
g++ -m32 -mcpu=G4 -O3 -fomit-frame-pointer ref
g++ -m32 -mcpu=G5 -O3 -fomit-frame-pointer ref
g++ -march=k8 -O3 -fomit-frame-pointer ref
g++ -march=nocona -O3 -fomit-frame-pointer ref
g++ -march=pentium-m -O3 -fomit-frame-pointer ref
g++ -march=pentium4 -O3 -fomit-frame-pointer ref
g++ -march=prescott -O3 -fomit-frame-pointer ref
g++ -mcpu=G4 -O3 -fomit-frame-pointer ref
g++ -mcpu=G5 -O3 -fomit-frame-pointer ref

Compiler output

Implementation: crypto_encrypt/3hfe/ref
Compiler: g++ -Os -fomit-frame-pointer
HFE-test.cpp: conversion.h: In function 'int shortciphertext(unsigned char*, long long unsigned int*, const unsigned char*, long long unsigned int, const unsigned char*, long long unsigned int)':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'

Number of similar (compiler,implementation) pairs: 17, namely:
CompilerImplementations
g++ -Os -fomit-frame-pointer ref
g++ -fno-schedule-insns -Os -fomit-frame-pointer ref
g++ -m32 -Os -fomit-frame-pointer ref
g++ -m32 -march=k8 -Os -fomit-frame-pointer ref
g++ -m32 -march=nocona -Os -fomit-frame-pointer ref
g++ -m32 -march=pentium-m -Os -fomit-frame-pointer ref
g++ -m32 -march=pentium4 -Os -fomit-frame-pointer ref
g++ -m32 -march=prescott -Os -fomit-frame-pointer ref
g++ -m32 -mcpu=G4 -Os -fomit-frame-pointer ref
g++ -m32 -mcpu=G5 -Os -fomit-frame-pointer ref
g++ -march=k8 -Os -fomit-frame-pointer ref
g++ -march=nocona -Os -fomit-frame-pointer ref
g++ -march=pentium-m -Os -fomit-frame-pointer ref
g++ -march=pentium4 -Os -fomit-frame-pointer ref
g++ -march=prescott -Os -fomit-frame-pointer ref
g++ -mcpu=G4 -Os -fomit-frame-pointer ref
g++ -mcpu=G5 -Os -fomit-frame-pointer ref

Compiler output

Implementation: crypto_encrypt/3hfe/ref
Compiler: g++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer
HFE-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 12u]':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 3u]':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 13u]':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'

Number of similar (compiler,implementation) pairs: 2, namely:
CompilerImplementations
g++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer ref
g++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer ref

Compiler output

Implementation: crypto_encrypt/3hfe/ref
Compiler: g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer
HFE-test.cpp: conversion.h: In function 'int shortplaintext(unsigned char*, long long unsigned int*, const unsigned char*, long long unsigned int, const unsigned char*, long long unsigned int)':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: ...
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer ref

Compiler output

Implementation: crypto_encrypt/3hfe/ref
Compiler: g++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer
HFE-test.cpp: conversion.h: In function 'int shortciphertext(unsigned char*, long long unsigned int*, const unsigned char*, long long unsigned int, const unsigned char*, long long unsigned int)':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: ...
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
g++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer ref

Compiler output

Implementation: crypto_encrypt/3hfe/ref
Compiler: g++ -m32 -march=athlon -O2 -fomit-frame-pointer
HFE-test.cpp: gfv.h:7: error: '__m128i' does not name a type
HFE-test.cpp: gfv.h:12: error: expected ',' or '...' before '&' token
HFE-test.cpp: gfv.h:12: error: ISO C++ forbids declaration of '__m128i' with no type
HFE-test.cpp: gfv.h: In copy constructor 'gfvgt;::gfv(const gfvgt;&)':
HFE-test.cpp: gfv.h:11: error: class 'gfvgt;' does not have any field named 'v'
HFE-test.cpp: gfv.h: In constructor 'gfvgt;::gfv(int)':
HFE-test.cpp: gfv.h:12: error: class 'gfvgt;' does not have any field named 'v'
HFE-test.cpp: gfv.h:12: error: 'a' was not declared in this scope
HFE-test.cpp: gfv.h: In constructor 'gfvgt;::gfv(const gfgt;&)':
HFE-test.cpp: gfv.h:13: error: class 'gfvgt;' does not have any field named 'v'
HFE-test.cpp: ...
HFE-test.cpp: bqas.h:238: error: 'struct gfvgt;' has no member named 'v'
HFE-test.cpp: bqas.h:238: error: 'transpose8' cannot be used as a function
HFE-test.cpp: bqas.h:239: error: 'struct gfvgt;' has no member named 'v'
HFE-test.cpp: bqas.h:239: error: 'transpose8' cannot be used as a function
HFE-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 12u]':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 3u]':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'
HFE-test.cpp: conversion.h: In function 'void convert_to_31(uint8*, uint64) [with unsigned int num_gf31 = 13u]':
HFE-test.cpp: conversion.h:48: error: unknown register name 'r8' in 'asm'

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

Compiler output

Implementation: crypto_encrypt/3hfe/ref
Compiler: g++ -m32 -march=athlon -O3 -fomit-frame-pointer
HFE-test.cpp: gfv.h:7: error: '__m128i' does not name a type
HFE-test.cpp: gfv.h:12: error: expected ',' or '...' before '&' token
HFE-test.cpp: gfv.h:12: error: ISO C++ forbids declaration of '__m128i' with no type
HFE-test.cpp: gfv.h: In copy constructor 'gfvgt;::gfv(const gfvgt;&)':
HFE-test.cpp: gfv.h:11: error: class 'gfvgt;' does not have any field named 'v'
HFE-test.cpp: gfv.h: In constructor 'gfvgt;::gfv(int)':
HFE-test.cpp: gfv.h:12: error: class 'gfvgt;' does not have any field named 'v'
HFE-test.cpp: gfv.h:12: error: 'a' was not declared in this scope
HFE-test.cpp: gfv.h: In constructor 'gfvgt;::gfv(const gfgt;&)':
HFE-test.cpp: gfv.h:13: error: class 'gfvgt;' does not have any field named 'v'
HFE-test.cpp: ...
HFE-test.cpp: bqas.h:232: error: 'transpose8' cannot be used as a function
HFE-test.cpp: bqas.h:294: instantiated from 'void rand_affine_inv(MLPSgt;*, MLPSgt;*) [with unsigned int p = 31u, unsigned int n = 27u]'
HFE-test.cpp: HFE.h:122: instantiated from 'static void HFE_3_31_9gt;::gen_key(uint8*, uint8*) [with unsigned int p = 31u]'
HFE-test.cpp: HFE-test.cpp:42: instantiated from here
HFE-test.cpp: bqas.h:237: error: 'struct gfvgt;' has no member named 'v'
HFE-test.cpp: bqas.h:238: error: 'struct gfvgt;' has no member named 'v'
HFE-test.cpp: bqas.h:238: error: 'struct gfvgt;' has no member named 'v'
HFE-test.cpp: bqas.h:238: error: 'transpose8' cannot be used as a function
HFE-test.cpp: bqas.h:239: error: 'struct gfvgt;' has no member named 'v'
HFE-test.cpp: bqas.h:239: error: 'transpose8' cannot be used as a function

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