mirror of
				https://github.com/Mbed-TLS/mbedtls.git
				synced 2025-10-26 00:37:41 +03:00 
			
		
		
		
	Add input parameter length check for the Koblitz reduction
Signed-off-by: Gabor Mezei <gabor.mezei@arm.com>
This commit is contained in:
		| @@ -5643,6 +5643,10 @@ int mbedtls_ecp_mod_p192k1_raw(mbedtls_mpi_uint *X, size_t X_limbs) | ||||
|                                   0x01, 0x00, 0x00, 0x00) | ||||
|     }; | ||||
|  | ||||
|     if (X_limbs != 2 * ((192 + biL - 1) / biL)) { | ||||
|         return MBEDTLS_ERR_ECP_BAD_INPUT_DATA; | ||||
|     } | ||||
|  | ||||
|     return ecp_mod_koblitz(X, X_limbs, Rp, 192); | ||||
| } | ||||
|  | ||||
| @@ -5673,6 +5677,10 @@ int mbedtls_ecp_mod_p224k1_raw(mbedtls_mpi_uint *X, size_t X_limbs) | ||||
|                                   0x01, 0x00, 0x00, 0x00) | ||||
|     }; | ||||
|  | ||||
|     if (X_limbs != 2 * 224 / biL) { | ||||
|         return MBEDTLS_ERR_ECP_BAD_INPUT_DATA; | ||||
|     } | ||||
|  | ||||
|     return ecp_mod_koblitz(X, X_limbs, Rp, 224); | ||||
| } | ||||
|  | ||||
| @@ -5702,6 +5710,11 @@ int mbedtls_ecp_mod_p256k1_raw(mbedtls_mpi_uint *X, size_t X_limbs) | ||||
|         MBEDTLS_BYTES_TO_T_UINT_8(0xD1, 0x03, 0x00, 0x00, | ||||
|                                   0x01, 0x00, 0x00, 0x00) | ||||
|     }; | ||||
|  | ||||
|     if (X_limbs != 2 * ((256 + biL - 1) / biL)) { | ||||
|         return MBEDTLS_ERR_ECP_BAD_INPUT_DATA; | ||||
|     } | ||||
|  | ||||
|     return ecp_mod_koblitz(X, X_limbs, Rp, 256); | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -184,6 +184,8 @@ int  mbedtls_ecp_mod_p384_raw(mbedtls_mpi_uint *X, size_t X_limbs); | ||||
|  * \param[in]       X_limbs The length of \p X in limbs. | ||||
|  * | ||||
|  * \return          \c 0 on success. | ||||
|  * \return          #MBEDTLS_ERR_ECP_BAD_INPUT_DATA if \p X does not have | ||||
|  *                  twice as many limbs as the modulus. | ||||
|  * \return          #MBEDTLS_ERR_ECP_ALLOC_FAILED if memory allocation failed. | ||||
|  */ | ||||
| MBEDTLS_STATIC_TESTABLE | ||||
| @@ -206,6 +208,8 @@ int mbedtls_ecp_mod_p192k1_raw(mbedtls_mpi_uint *X, size_t X_limbs); | ||||
|  * \param[in]       X_limbs The length of \p X in limbs. | ||||
|  * | ||||
|  * \return          \c 0 on success. | ||||
|  * \return          #MBEDTLS_ERR_ECP_BAD_INPUT_DATA if \p X does not have | ||||
|  *                  twice as many limbs as the modulus. | ||||
|  * \return          #MBEDTLS_ERR_ECP_ALLOC_FAILED if memory allocation failed. | ||||
|  */ | ||||
| MBEDTLS_STATIC_TESTABLE | ||||
| @@ -228,6 +232,8 @@ int mbedtls_ecp_mod_p224k1_raw(mbedtls_mpi_uint *X, size_t X_limbs); | ||||
|  * \param[in]       X_limbs The length of \p X in limbs. | ||||
|  * | ||||
|  * \return          \c 0 on success. | ||||
|  * \return          #MBEDTLS_ERR_ECP_BAD_INPUT_DATA if \p X does not have | ||||
|  *                  twice as many limbs as the modulus. | ||||
|  * \return          #MBEDTLS_ERR_ECP_ALLOC_FAILED if memory allocation failed. | ||||
|  */ | ||||
| MBEDTLS_STATIC_TESTABLE | ||||
|   | ||||
		Reference in New Issue
	
	Block a user