37.3.4.7 Small Multiply, Add, Subtract, Exclusive OR

Purpose

This purpose of this service is to multiply a large number X by a single-word number, MulValue, and perform an optional accumulation/subtract with a large number Z, returning the result R.

The following options are available:

  • Work in the GF(2n) or in the standard GF(p) arithmetic integer field
  • Add of a supplemental CarryOperand
  • Overlap of the operands is possible, taking into account some constraints
  • Modulo-reduction of the computation result (see Modular Reduction from Related Links)
In addition to a multiply, possible uses of this service can include:
  • Copy a block of data from one place to another (if u4MulValue is 1). This operation can alternatively be made by using the Fast Copy service (see Fast Copy/Clear from Related Links)
  • Adding/Subtracting two numbers (if u4MulValue is1)
  • Xoring two blocks of data (if u4MulValue is 1 and the selected mathematical field is GF(2n))

How to Use the Service

Description

This service processes the following operation (if not computing a modular reduction of the result):

R = [Z] ± (MulValue × X + CarryOperand)

Or (if computing a modular reduction of the result):

R = ([Z] ± (MulValue × X + CarryOperand))mod N

The service name for this operation is Smult.

The result of the Small Multiply Operation is stored on u2RLength bytes, so the choice of this length compared to u2XLength may lead to:

  • A truncation if the result is too big to be stored on u2RLengthbytes.
  • A padding on the MSB side if the result does not take all the u2RLengthbytes.

    However, in all cases this rule must be followed:

    Important: The length of R must be greater than or equal to the length of X.

In these computations, the following parameters need to be provided:

  • R the result (pointed by{nu1RBase,u2Rlength})
  • X one input number or GF(2n) polynomial (pointed by{nu1XBase,u2XLength})
  • Z one optional input number or GF(2n) polynomial (pointed by{nu1ZBase,u2Rlength}).
  • MulValue one input number or GF(2n)polynomial on one word (provided in u4MulValue)
  • CarryOperand (provided through the CarryOptions and Carry values).
    Important: Even if neither accumulation nor subtraction is specified, the nu1ZBase must always be filled and point to a Crypto RAM space. It this case, nu1ZBase can point to the same space as the nu1RBase.

If using the modular reduction option, the Multiply operation is followed by a reduction (see Modular Reduction from Related Links) and the following parameters must be additionally provided:

  • N—the modulus (pointed by {nu1ModBase,u2Modlength +4})
  • Cns—the reduction constant
    • In case of Big reduction, Cns is pointed by {nu1CnsBase,64bytes}.
    • In case of Fast or Normalized reduction, Cns is pointed by {nu1CnsBase,u2ModLength +8}
    Important:

    The result buffer R must first be padded with zero bytes until its length is sufficient to perform the reduction (2*u2ModLength + 8) to be used by the Modular Reduction service as an input parameter.

    The result of the reduction is written in the area X pointed by {nu1XBase, u2ModLength + 4}.

  • For example, if relevant u2ModLength is 0x80 bytes and u2XLength is 0x80 too, the length of the Rspace may be 2*(u2ModLength + 4) = 0x108 bytes.

    In case of fast or normalized reduction, the length of the result may be u2ModLength + 4 so 0x84 bytes. Therefore, the zone X may lengths 0x84 bytes (at least). The multiplication of X by 1 word provide a result in the zone R which MSB bytes will be padded with zero bytes.

    In that example, the length of the zone R will be 2*u2ModLength + 8 = 0x108 bytes.

Parameters Definition

Table 37-18. Smult Service Parameters
ParameterTypeDirectionLocationData LengthBefore Executing the ServiceAfter Executing the Service
u2Optionsu2IOptions (see below)Options (see below)
Specific/Gf2n CarryInBitsIGF(2n) Bit and Carry In
Specific/CarryOut Zero ViolationBitsICarry Out, Zero Bit and Violation Bit filled according to the result
nu1ModBasenu1ICrypto RAMu2ModLength + 4Base of NBase of N untouched
nu1CnsBasenu1ICrypto RAMu2ModLength + 8Base of CnsBase of Cns untouched
u2ModLengthu2ILength of NLength of N
nu1XBasenu1ICrypto RAMu2XLength or u2ModLength + 4(1)Base of XBase of X(2)
u2XLengthu2ILength of XLength of X
nu1ZBasenu1ICrypto RAMu2RLengthBase of ZBase of Z untouched
nu1RBasenu1ICrypto RAMu2RLengthBase of RBase of R (see Note 3)
u2RLengthu2ILength of RLength of R
u4MulValueu4IValue of MulValueValue of MulValue untouched
Note:
  1. If a reduction option is specified, the area X will be, if necessary, extended to u2ModLength + 4 bytes.
  2. If Smult is without reduction, X is untouched. If Smult is with reduction, X is filled with the final result.
  3. If Smult is without reduction, R is filled with the final result. If Smult is with reduction, R is corrupted.

Available Options

The options are set by the u2Options input parameter, which is composed of:

  • The mandatory Small Multiplication operation option described in the following table.
  • The mandatory CarryOperand option described in Smult Service (with Accumulate/Subtract From) Carry Settings and Smult Service Carry Settings tables.
  • The facultative Modular Reduction option (see Modular Reduction). If the Modular Reduction is not requested, this option is absent.

The u2Options number is calculated by an “Inclusive OR” of the options. Some examples in C language are:

  • Operation: Small Multiply only without carry and without Modular Reduction

    PUKCL(u2Options) = SET_MULTIPLIEROPTION(PUKCL_SMULT_ONLY) | SET_CARRYOPTION(CARRY_NONE);

  • Operation: Small Multiply with addition with Specific/CarryIn addition and with Fast Modular Reduction

    PUKCL(u2Options) =SET_MULTIPLIEROPTION(PUKCL_SMULT_ADD) | SET_CARRYOPTION(ADD_CARRY) | PUKCL_REDMOD_REDUCTION | PUKCL_REDMOD_USING_FASTRED;

The following table lists all of the necessary parameters for the Small Multiply option. When the Addition or Subtraction option is not chosen, it is not necessary to fill in the nu1ZBase parameter.

Table 37-19. Smult Service Operation Options
OptionPurposeRequired Parameters
SET_MULTIPLIEROPTION(PUKCL_SMULT_ ONLY)Perform R = MulValue*X + CarryOperandnu1RBase, u2RLength, nu1XBase, u2XLength, u4MulValue
SET_MULTIPLIEROPTION(PUKCL_SMULT_ ADD)Perform R = Z + MulValue*X + CarryOperandnu1RBase, u2RLength, nu1ZBase, nu1XBase, u2XLength,u4MulValue
SET_MULTIPLIEROPTION(PUKCL_SMULT_ SUB)Perform R = Z - (MulValue*X + CarryOperand)nu1RBase, u2RLength, nu1ZBase, nu1XBase, u2XLength,u4MulValue

Code Example

PUKCL_PARAM PUKCLParam;
PPUKCL_PARAM pvPUKCLParam = &PUKCLParam;

// Gf2n and CarryIn shall be beforehand filled (with zero or one) 
PUKCL(Specific).Gf2n = ...;
PUKCL(Specific).CarryIn = ...; PUKCL(u2Options) =...;

// Depending on the option specified, all fields must not be filled 
PUKCL_Smult(nu1XBase) = <Base of the X number>; 
PUKCL_Smult(u2XLength) = <Length of the X number>; 
PUKCL_Smult(nu1RBase) = <Base of the R number>; 
PUKCL_Smult(u2RLength) = <Length of the R number>; 
PUKCL_Smult(nu1ZBase) = <Base of the Z number>; 
PUKCL_Smult(u4MulValue) = <Value to be multiplied with>;

// vPUKCL_Process() is a macro command, which populates the service name
// and then calls the library... 
vPUKCL_Process(Smult,pvPUKCLParam); 
if (PUKCL(u2Status) == PUKCL_OK)
            {
            // The Small multiplication has been executed correctly
            ...
            }
else // Manage the error
Note:

The length of R must be greater or equal to the length of X. Additional options are available through the use of a modular reduction to be executed at the end of this operation. Some important considerations have to be taken into account concerning the length of resulting operands to get a mathematically correct result.

The output of this operation is not obviously compatible with the modular reduction, as it may be either smaller or bigger. In the case (most of the time) where the result (pointed by nu1RBase) is smaller in size than twice the modulus plus one word, it is mandatory to add padding bytes to zero. Otherwise, the reduced value will be taken considering the high order words (potentially uninitialized) as part of the number, thus resulting in a mathematically correct but unexpected result.

In the case that the result is bigger than twice the modulus plus one word, the modular reduction feature has to be executed as a separate operation, using an Euclidean division.

Constraints

For the case of a small multiplication with an option indicating either subtraction or accumulation, the following conditions must be avoided to ensure the service works correctly:

  • nu1XBase, nu1RBase or nu1ZBase are not aligned on 32-bit boundaries
  • {nu1XBase, u2XLength}, {nu1ZLength, u2RLength} or {nu1RBase, u2RLength} do not entirely lie in Crypto RAM
  • u2XLength or u2RLength is either: < 4, > 0xffc or not a 32-bit length or u2XLength >u2RLength
  • {nu1RBase, u2RLength} overlaps {nu1XBase, u2XLength} or nu1R < nu1Z and {nu1RBase,u2RLength} overlaps {nu1ZBase, u2RLength}

If the nu1R value is greater or equals to the nu1Z one, the overlapping between R and Z is allowed.

If a modular reduction is specified, the relevant parameters must be defined according to the chosen reduction and follow the description in Modular Reduction. Additional constraints to be respected and error codes are described in this section and in Smult Service Return Codes.

Multiplication with Accumulation or Subtraction

When the options bits specify that either an Accumulation or a Subtraction must be performed, this service performs the following operation:

R = (Z ± (MulValue × X + CarryOperand))mod BRLength

Table 37-20. Smult Service (with Accumulate/Subtract From) Carry Settings
Carry OptionsCarryOperandResulting Operation
SET_CARRYOPTION(ADD_CARRY)CarryInR = Z ± (MulValue*X + CarryIn)
SET_CARRYOPTION(SUB_CARRY)- CarryInR = Z ± (MulValue*X - CarryIn)
SET_CARRYOPTION(ADD_1_PLUS_CARRY)1 + CarryInR = Z ± (MulValue*X + 1 + CarryIn)
SET_CARRYOPTION(ADD_1_MINUS_CARRY)1 - CarryInR = Z ± (MulValue*X + 1 - CarryIn)
SET_CARRYOPTION(CARRY_NONE)0R = Z ± (MulValue*X)
SET_CARRYOPTION(ADD_1)1R = Z ± (MulValue*X + 1)
SET_CARRYOPTION(SUB_1)- 1R = Z ± (MulValue*X - 1)
SET_CARRYOPTION(ADD_2)2R = Z ± (MulValue*X + 2)

Multiplication without Accumulation or Subtraction

When the case the options bits specify that neither an Accumulation nor a Subtraction must be performed, this service performs the following operation:

R = (MulValue × X + CarryOperand)mod BRLength

Table 37-21. Smult Service Carry Settings
Carry OptionsCarryOperandResulting Operation
SET_CARRYOPTION(ADD_CARRY)CarryInR = MulValue*X + CarryIn
SET_CARRYOPTION(SUB_CARRY)- CarryInR = MulValue*X - CarryIn
SET_CARRYOPTION(ADD_1_PLUS_CARRY)1 + CarryInR = MulValue*X + 1 + CarryIn
SET_CARRYOPTION(ADD_1_MINUS_CARRY)1 - CarryInR = MulValue*X + 1 - CarryIn
SET_CARRYOPTION(CARRY_NONE)0R = MulValue*X
SET_CARRYOPTION(ADD_1)1R = MulValue*X + 1
SET_CARRYOPTION(SUB_1)-1R = MulValue*X - 1
SET_CARRYOPTION(ADD_2)2R = MulValue*X + 2

Status Returned Values

Table 37-22. Smult Service Return Codes
Returned StatusImportanceMeaning
PUKCL_OKService functioned correctly