package core:crypto/ristretto255

⌘K
Ctrl+K
or
/

    Types

    Group_Element ¶

    Group_Element :: struct {
    	// WARNING: While the internal representation is an Edwards25519
    	// group element, this is not guaranteed to always be the case,
    	// and your code *WILL* break if you mess with `_p`.
    	_p:              _edwards25519.Group_Element,
    	_is_initialized: bool,
    }
     

    Group_Element is a ristretto255 group element. The zero-initialized value is invalid.

    Related Procedures With Parameters

    Scalar ¶

    Scalar :: field_scalar25519.Montgomery_Domain_Field_Element
     

    Scalar is a ristretto255 scalar. The zero-initialized value is valid, and represents 0.

    Constants

    ELEMENT_SIZE ¶

    ELEMENT_SIZE :: 32
     

    ELEMENT_SIZE is the size of a byte-encoded ristretto255 group element.

    SCALAR_SIZE ¶

    SCALAR_SIZE :: 32
     

    SCALAR_SIZE is the size of a byte-encoded ristretto255 scalar.

    WIDE_ELEMENT_SIZE ¶

    WIDE_ELEMENT_SIZE :: 64
     

    WIDE_ELEMENT_SIZE is the side of a wide byte-encoded ristretto255 group element.

    WIDE_SCALAR_SIZE ¶

    WIDE_SCALAR_SIZE :: 64
     

    WIDE_SCALAR_SIZE is the size of a wide byte-encoded ristretto255 scalar.

    Variables

    This section is empty.

    Procedures

    ge_add ¶

    ge_add :: proc(ge, a, b: ^Group_Element) {…}
     

    ge_add sets ge = a + b.

    ge_bytes ¶

    ge_bytes :: proc(ge: ^Group_Element, dst: []u8) {…}
     

    ge_bytes sets dst to the canonical encoding of ge.

    ge_clear ¶

    ge_clear :: proc "contextless" (ge: ^Group_Element) {…}
     

    ge_clear clears ge to the uninitialized state.

    ge_cond_assign ¶

    ge_cond_assign :: proc(ge, a: ^Group_Element, ctrl: int) {…}
     

    ge_cond_assign sets ge = ge iff ctrl == 0 and ge = a iff ctrl == 1. Behavior for all other values of ctrl are undefined,

    ge_cond_negate ¶

    ge_cond_negate :: proc(ge, a: ^Group_Element, ctrl: int) {…}
     

    ge_cond_negate sets ge = a iff ctrl == 0 and ge = -a iff ctrl == 1. Behavior for all other values of ctrl are undefined,

    ge_cond_select ¶

    ge_cond_select :: proc(ge, a, b: ^Group_Element, ctrl: int) {…}
     

    ge_cond_select sets ge = a iff ctrl == 0 and ge = b iff ctrl == 1. Behavior for all other values of ctrl are undefined,

    ge_double ¶

    ge_double :: proc(ge, a: ^Group_Element) {…}
     

    ge_double sets ge = a + a.

    ge_double_scalarmult_generator_vartime ¶

    ge_double_scalarmult_generator_vartime :: proc(ge: ^Group_Element, a: ^field_scalar25519.Montgomery_Domain_Field_Element, A: ^Group_Element, b: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    ge_double_scalarmult_generator_vartime sets ge = A * a + G * b in variable time.

    ge_equal ¶

    ge_equal :: proc(a, b: ^Group_Element) -> int {…}
     

    ge_equal returns 1 iff a == b, and 0 otherwise.

    ge_generator ¶

    ge_generator :: proc "contextless" (ge: ^Group_Element) {…}
     

    ge_generator sets ge to the group generator.

    ge_identity ¶

    ge_identity :: proc "contextless" (ge: ^Group_Element) {…}
     

    ge_identity sets ge to the identity (neutral) element.

    ge_is_identity ¶

    ge_is_identity :: proc(ge: ^Group_Element) -> int {…}
     

    ge_is_identity returns 1 iff ge is the identity element, and 0 otherwise.

    ge_negate ¶

    ge_negate :: proc(ge, a: ^Group_Element) {…}
     

    ge_negate sets ge = -a.

    ge_scalarmult ¶

    ge_scalarmult :: proc(ge, A: ^Group_Element, sc: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    ge_scalarmult sets ge = A * sc.

    ge_scalarmult_generator ¶

    ge_scalarmult_generator :: proc "contextless" (ge: ^Group_Element, sc: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    ge_scalarmult_generator sets ge = G * sc

    ge_scalarmult_vartime ¶

    ge_scalarmult_vartime :: proc(ge, A: ^Group_Element, sc: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    ge_scalarmult_vartime sets ge = A * sc in variable time.

    ge_set ¶

    ge_set :: proc(ge, a: ^Group_Element) {…}
     

    ge_set sets ge = a.

    ge_set_bytes ¶

    ge_set_bytes :: proc "contextless" (ge: ^Group_Element, b: []u8) -> bool {…}
     

    ge_set_bytes sets ge to the result of decoding b as a ristretto255 group element, and returns true on success.

    ge_set_wide_bytes ¶

    ge_set_wide_bytes :: proc(ge: ^Group_Element, b: []u8) {…}
     

    ge_set_wide_bytes sets ge to the result of deriving a ristretto255 group element, from a wide (512-bit) byte string.

    sc_add ¶

    sc_add :: proc "contextless" (sc, a, b: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    sc_add sets sc = a + b.

    sc_bytes ¶

    sc_bytes :: proc(sc: ^field_scalar25519.Montgomery_Domain_Field_Element, dst: []u8) {…}
     

    sc_bytes sets dst to the canonical encoding of sc.

    sc_clear ¶

    sc_clear :: proc "contextless" (sc: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    sc_clear clears sc to the uninitialized state.

    sc_cond_assign ¶

    sc_cond_assign :: proc(sc, a: ^field_scalar25519.Montgomery_Domain_Field_Element, ctrl: int) {…}
     

    sc_cond_assign sets sc = sc iff ctrl == 0 and sc = a iff ctrl == 1. Behavior for all other values of ctrl are undefined,

    sc_equal ¶

    sc_equal :: proc(a, b: ^field_scalar25519.Montgomery_Domain_Field_Element) -> int {…}
     

    sc_equal returns 1 iff a == b, and 0 otherwise.

    sc_mul ¶

    sc_mul :: proc "contextless" (sc, a, b: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    sc_mul sets sc = a * b.

    sc_negate ¶

    sc_negate :: proc "contextless" (sc, a: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    sc_negate sets sc = -a.

    sc_set ¶

    sc_set :: proc "contextless" (sc, a: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    sc_set sets sc = a.

    sc_set_bytes ¶

    sc_set_bytes :: proc(sc: ^field_scalar25519.Montgomery_Domain_Field_Element, b: []u8) -> bool {…}
     

    sc_set_bytes sets sc to the result of decoding b as a ristretto255 scalar, and returns true on success.

    sc_set_bytes_wide ¶

    sc_set_bytes_wide :: proc(sc: ^field_scalar25519.Montgomery_Domain_Field_Element, b: []u8) {…}
     

    sc_set_wide_bytes sets sc to the result of deriving a ristretto255 scalar, from a wide (512-bit) byte string by interpreting b as a little-endian value, and reducing it mod the group order.

    sc_set_u64 ¶

    sc_set_u64 :: proc "contextless" (sc: ^field_scalar25519.Montgomery_Domain_Field_Element, i: u64) {…}
     

    sc_set_u64 sets sc = i.

    sc_square ¶

    sc_square :: proc "contextless" (sc, a: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    sc_square sets sc = a^2.

    sc_sub ¶

    sc_sub :: proc "contextless" (sc, a, b: ^field_scalar25519.Montgomery_Domain_Field_Element) {…}
     

    sc_sub sets sc = a - b.

    Procedure Groups

    This section is empty.

    Source Files

    Generation Information

    Generated with odin version dev-2025-01 (vendor "odin") Windows_amd64 @ 2025-01-20 21:11:03.391328500 +0000 UTC