Botan  1.10.9
Namespaces | Macros | Functions
mp_asmi.h File Reference
#include <botan/internal/mp_asm.h>

Go to the source code of this file.

Namespaces

 Botan
 

Macros

#define ADD_OR_SUBTRACT(CORE_CODE)
 
#define ADDSUB2_OP(OPERATION, INDEX)
 
#define ADDSUB3_OP(OPERATION, INDEX)
 
#define ASM(x)   x "\n\t"
 
#define DO_8_TIMES(MACRO, ARG)
 
#define LINMUL_OP(WRITE_TO, INDEX)
 
#define MULADD_OP(IGNORED, INDEX)
 

Functions

void Botan::word3_muladd (word *w2, word *w1, word *w0, word a, word b)
 
void Botan::word3_muladd_2 (word *w2, word *w1, word *w0, word a, word b)
 
word Botan::word8_add2 (word x[8], const word y[8], word carry)
 
word Botan::word8_add3 (word z[8], const word x[8], const word y[8], word carry)
 
word Botan::word8_linmul2 (word x[8], word y, word carry)
 
word Botan::word8_linmul3 (word z[8], const word x[8], word y, word carry)
 
word Botan::word8_madd3 (word z[8], const word x[8], word y, word carry)
 
word Botan::word8_sub2 (word x[8], const word y[8], word carry)
 
word Botan::word8_sub2_rev (word x[8], const word y[8], word carry)
 
word Botan::word8_sub3 (word z[8], const word x[8], const word y[8], word carry)
 
word Botan::word_add (word x, word y, word *carry)
 
word Botan::word_sub (word x, word y, word *carry)
 

Macro Definition Documentation

#define ADD_OR_SUBTRACT (   CORE_CODE)
Value:
ASM("rorq %[carry]") \
ASM("sbbq %[carry],%[carry]") \
ASM("negq %[carry]")
#define ASM(x)
Definition: mp_asmi.h:22

Definition at line 62 of file mp_asmi.h.

#define ADDSUB2_OP (   OPERATION,
  INDEX 
)
Value:
ASM("movq 8*" #INDEX "(%[y]), %[carry]") \
ASM(OPERATION " %[carry], 8*" #INDEX "(%[x])") \
#define ASM(x)
Definition: mp_asmi.h:22

Definition at line 25 of file mp_asmi.h.

#define ADDSUB3_OP (   OPERATION,
  INDEX 
)
Value:
ASM("movq 8*" #INDEX "(%[x]), %[carry]") \
ASM(OPERATION " 8*" #INDEX "(%[y]), %[carry]") \
ASM("movq %[carry], 8*" #INDEX "(%[z])") \
#define ASM(x)
Definition: mp_asmi.h:22

Definition at line 29 of file mp_asmi.h.

#define ASM (   x)    x "\n\t"

Definition at line 22 of file mp_asmi.h.

#define DO_8_TIMES (   MACRO,
  ARG 
)
Value:
MACRO(ARG, 0) \
MACRO(ARG, 1) \
MACRO(ARG, 2) \
MACRO(ARG, 3) \
MACRO(ARG, 4) \
MACRO(ARG, 5) \
MACRO(ARG, 6) \
MACRO(ARG, 7)
#define ARG(NUM)
Definition: asm_x86_32.h:81

Definition at line 52 of file mp_asmi.h.

#define LINMUL_OP (   WRITE_TO,
  INDEX 
)
Value:
ASM("movq 8*" #INDEX "(%[x]),%%rax") \
ASM("mulq %[y]") \
ASM("addq %[carry],%%rax") \
ASM("adcq $0,%%rdx") \
ASM("movq %%rdx,%[carry]") \
ASM("movq %%rax, 8*" #INDEX "(%[" WRITE_TO "])")
#define ASM(x)
Definition: mp_asmi.h:22

Definition at line 34 of file mp_asmi.h.

#define MULADD_OP (   IGNORED,
  INDEX 
)
Value:
ASM("movq 8*" #INDEX "(%[x]),%%rax") \
ASM("mulq %[y]") \
ASM("addq %[carry],%%rax") \
ASM("adcq $0,%%rdx") \
ASM("addq 8*" #INDEX "(%[z]),%%rax") \
ASM("adcq $0,%%rdx") \
ASM("movq %%rdx,%[carry]") \
ASM("movq %%rax, 8*" #INDEX " (%[z])")
#define ASM(x)
Definition: mp_asmi.h:22

Definition at line 42 of file mp_asmi.h.