Botan 3.6.1
Crypto and TLS for C&
|
#include <pcurves_wrap.h>
Classes | |
class | PrecomputedMul2TableC |
Public Types | |
typedef std::shared_ptr< const PrimeOrderCurve > | CurvePtr |
typedef std::array< word, StorageWords > | StorageUnit |
Public Member Functions | |
bool | affine_point_is_identity (const AffinePoint &pt) const override |
Scalar | base_point_mul_x_mod_order (const Scalar &scalar, RandomNumberGenerator &rng) const override |
std::optional< AffinePoint > | deserialize_point (std::span< const uint8_t > bytes) const override |
std::optional< Scalar > | deserialize_scalar (std::span< const uint8_t > bytes) const override |
size_t | field_element_bytes () const override |
AffinePoint | generator () const override |
Return the standard generator. | |
AffinePoint | hash_to_curve_nu (std::string_view hash, std::span< const uint8_t > input, std::span< const uint8_t > domain_sep) const override |
ProjectivePoint | hash_to_curve_ro (std::string_view hash, std::span< const uint8_t > input, std::span< const uint8_t > domain_sep) const override |
ProjectivePoint | mul (const AffinePoint &pt, const Scalar &scalar, RandomNumberGenerator &rng) const override |
std::unique_ptr< const PrecomputedMul2Table > | mul2_setup (const AffinePoint &x, const AffinePoint &y) const override |
Setup a table for 2-ary multiplication. | |
std::optional< ProjectivePoint > | mul2_vartime (const PrecomputedMul2Table &tableb, const Scalar &s1, const Scalar &s2) const override |
bool | mul2_vartime_x_mod_order_eq (const PrecomputedMul2Table &tableb, const Scalar &v, const Scalar &s1, const Scalar &s2) const override |
ProjectivePoint | mul_by_g (const Scalar &scalar, RandomNumberGenerator &rng) const override |
size_t | order_bits () const override |
Return the bit length of the group order. | |
ProjectivePoint | point_add (const ProjectivePoint &a, const ProjectivePoint &b) const override |
ProjectivePoint | point_add_mixed (const ProjectivePoint &a, const AffinePoint &b) const override |
ProjectivePoint | point_double (const ProjectivePoint &pt) const override |
ProjectivePoint | point_negate (const ProjectivePoint &pt) const override |
AffinePoint | point_to_affine (const ProjectivePoint &pt) const override |
ProjectivePoint | point_to_projective (const AffinePoint &pt) const override |
PrimeOrderCurveImpl () | |
Scalar | random_scalar (RandomNumberGenerator &rng) const override |
Scalar | scalar_add (const Scalar &a, const Scalar &b) const override |
size_t | scalar_bytes () const override |
Return the byte length of the scalar element. | |
bool | scalar_equal (const Scalar &a, const Scalar &b) const override |
Scalar | scalar_from_u32 (uint32_t x) const override |
std::optional< Scalar > | scalar_from_wide_bytes (std::span< const uint8_t > bytes) const override |
Scalar | scalar_invert (const Scalar &ss) const override |
bool | scalar_is_zero (const Scalar &s) const override |
Scalar | scalar_mul (const Scalar &a, const Scalar &b) const override |
Scalar | scalar_negate (const Scalar &s) const override |
Scalar | scalar_one () const override |
Scalar | scalar_square (const Scalar &s) const override |
Scalar | scalar_sub (const Scalar &a, const Scalar &b) const override |
Scalar | scalar_zero () const override |
void | serialize_point (std::span< uint8_t > bytes, const AffinePoint &pt) const override |
void | serialize_point_compressed (std::span< uint8_t > bytes, const AffinePoint &pt) const override |
void | serialize_point_x (std::span< uint8_t > bytes, const AffinePoint &pt) const override |
void | serialize_scalar (std::span< uint8_t > bytes, const Scalar &scalar) const override |
Static Public Member Functions | |
static std::shared_ptr< const PrimeOrderCurve > | from_id (PrimeOrderCurveId id) |
static std::shared_ptr< const PrimeOrderCurve > | from_name (std::string_view name) |
static std::shared_ptr< const PrimeOrderCurve > | instance () |
Static Public Attributes | |
static const size_t | MaximumBitLength = 521 |
static const size_t | MaximumByteLength = (MaximumBitLength + 7) / 8 |
static const size_t | StorageWords = (MaximumByteLength + sizeof(word) - 1) / sizeof(word) |
Number of words used to store MaximumByteLength. | |
Definition at line 21 of file pcurves_wrap.h.
|
inherited |
|
inherited |
|
inline |
Definition at line 291 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 181 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Base point multiplication, returning only the x coordinate modulo the group order
Multiply by the standard generator point g, then extract the x coordinate as an integer, then reduce the x coordinate modulo the group order
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 152 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Deserialize a point
Both compressed and uncompressed encodings are accepted
Note that the deprecated "hybrid" encoding is not supported here
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 224 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Deserialize a scalar
This function requires the input length be exactly scalar_bytes long; it does not accept inputs that are shorter, or with excess leading zero padding bytes.
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 206 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Return the byte length of a field element
Each point consists of two field elements
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 43 of file pcurves_wrap.h.
|
staticinherited |
Definition at line 101 of file pcurves.cpp.
References Botan::PCurve::PCurveInstance::brainpool256r1(), Botan::PCurve::PrimeOrderCurveId::brainpool256r1, Botan::PCurve::PCurveInstance::brainpool384r1(), Botan::PCurve::PrimeOrderCurveId::brainpool384r1, Botan::PCurve::PCurveInstance::brainpool512r1(), Botan::PCurve::PrimeOrderCurveId::brainpool512r1, Botan::PCurve::PCurveInstance::frp256v1(), Botan::PCurve::PrimeOrderCurveId::frp256v1, Botan::PCurve::PCurveInstance::numsp512d1(), Botan::PCurve::PrimeOrderCurveId::numsp512d1, Botan::PCurve::PCurveInstance::secp192r1(), Botan::PCurve::PrimeOrderCurveId::secp192r1, Botan::PCurve::PCurveInstance::secp224r1(), Botan::PCurve::PrimeOrderCurveId::secp224r1, Botan::PCurve::PCurveInstance::secp256k1(), Botan::PCurve::PrimeOrderCurveId::secp256k1, Botan::PCurve::PCurveInstance::secp256r1(), Botan::PCurve::PrimeOrderCurveId::secp256r1, Botan::PCurve::PCurveInstance::secp384r1(), Botan::PCurve::PrimeOrderCurveId::secp384r1, Botan::PCurve::PCurveInstance::secp521r1(), Botan::PCurve::PrimeOrderCurveId::secp521r1, Botan::PCurve::PCurveInstance::sm2p256v1(), and Botan::PCurve::PrimeOrderCurveId::sm2p256v1.
|
inlinestaticinherited |
Definition at line 44 of file pcurves.h.
References name.
|
inlineoverridevirtual |
Return the standard generator.
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 159 of file pcurves_wrap.h.
|
inlineoverridevirtual |
RFC 9380 hash to curve (NU variant)
This is currently only supported for a few specific curves
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 232 of file pcurves_wrap.h.
|
inlineoverridevirtual |
RFC 9380 hash to curve (RO variant)
This is currently only supported for a few specific curves
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 242 of file pcurves_wrap.h.
|
inlinestatic |
Definition at line 293 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Generic point multiplication
Multiply an arbitrary point by a scalar
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 49 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Setup a table for 2-ary multiplication.
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 54 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Perform 2-ary multiplication (variable time)
Compute s1*pt1 + s2*pt2 in variable time
Returns nullopt if the produced point is the point at infinity
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 59 of file pcurves_wrap.h.
References Botan::PCurve::PrimeOrderCurveImpl< C >::PrecomputedMul2TableC::table().
|
inlineoverridevirtual |
Perform 2-ary multiplication (variable time), reducing x modulo order
Compute s1*pt1 + s2*pt2 in variable time, then extract the x coordinate of the result, and reduce x modulo the group order. Compare that value with v. If equal, returns true. Otherwise returns false, including if the produced point is the point at infinity
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 75 of file pcurves_wrap.h.
References Botan::bigint_ct_is_lt(), and Botan::PCurve::PrimeOrderCurveImpl< C >::PrecomputedMul2TableC::table().
|
inlineoverridevirtual |
Base point multiplication
Multiply by the standard generator point g
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 45 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Return the bit length of the group order.
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 39 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 171 of file pcurves_wrap.h.
References Botan::b.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 175 of file pcurves_wrap.h.
References Botan::b.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 169 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 179 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 161 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 165 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Return a new random scalar
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 289 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 252 of file pcurves_wrap.h.
References Botan::b.
|
inlineoverridevirtual |
Return the byte length of the scalar element.
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 41 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 279 of file pcurves_wrap.h.
References Botan::b.
|
inlineoverridevirtual |
Return a small scalar
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 287 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Reduce an integer modulo the group order
The input can be at most twice the bit length of the order; if larger than this nullopt is returned
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 216 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 266 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 277 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 260 of file pcurves_wrap.h.
References Botan::b.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 275 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Return the scalar one
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 285 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 264 of file pcurves_wrap.h.
References Botan::square().
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 256 of file pcurves_wrap.h.
References Botan::b.
|
inlineoverridevirtual |
Return the scalar zero
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 283 of file pcurves_wrap.h.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 185 of file pcurves_wrap.h.
References BOTAN_ARG_CHECK.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 190 of file pcurves_wrap.h.
References BOTAN_ARG_CHECK.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 196 of file pcurves_wrap.h.
References BOTAN_ARG_CHECK.
|
inlineoverridevirtual |
Implements Botan::PCurve::PrimeOrderCurve.
Definition at line 201 of file pcurves_wrap.h.
References BOTAN_ARG_CHECK.
|
staticinherited |
|
staticinherited |
|
staticinherited |