diff options
| author | Jung-uk Kim <jkim@FreeBSD.org> | 2019-05-28 20:13:54 +0000 | 
|---|---|---|
| committer | Jung-uk Kim <jkim@FreeBSD.org> | 2019-05-28 20:13:54 +0000 | 
| commit | 10d08b8de39401736faf1f37a8c6121cdd6814c8 (patch) | |
| tree | 3eb1a0ee652178757d91d9bab8053aa7bece8c27 /crypto/ec/ec_lib.c | |
| parent | d98e9d8878016a75426544bc9110d4ce403abf61 (diff) | |
Diffstat (limited to 'crypto/ec/ec_lib.c')
| -rw-r--r-- | crypto/ec/ec_lib.c | 22 | 
1 files changed, 19 insertions, 3 deletions
| diff --git a/crypto/ec/ec_lib.c b/crypto/ec/ec_lib.c index df56484b5ee2..cd2c420176f7 100644 --- a/crypto/ec/ec_lib.c +++ b/crypto/ec/ec_lib.c @@ -3,7 +3,7 @@   * Originally written by Bodo Moeller for the OpenSSL project.   */  /* ==================================================================== - * Copyright (c) 1998-2018 The OpenSSL Project.  All rights reserved. + * Copyright (c) 1998-2019 The OpenSSL Project.  All rights reserved.   *   * Redistribution and use in source and binary forms, with or without   * modification, are permitted provided that the following conditions @@ -872,7 +872,15 @@ int EC_POINT_set_affine_coordinates_GFp(const EC_GROUP *group,                EC_R_INCOMPATIBLE_OBJECTS);          return 0;      } -    return group->meth->point_set_affine_coordinates(group, point, x, y, ctx); +    if (!group->meth->point_set_affine_coordinates(group, point, x, y, ctx)) +        return 0; + +    if (EC_POINT_is_on_curve(group, point, ctx) <= 0) { +        ECerr(EC_F_EC_POINT_SET_AFFINE_COORDINATES_GFP, +              EC_R_POINT_IS_NOT_ON_CURVE); +        return 0; +    } +    return 1;  }  #ifndef OPENSSL_NO_EC2M @@ -890,7 +898,15 @@ int EC_POINT_set_affine_coordinates_GF2m(const EC_GROUP *group,                EC_R_INCOMPATIBLE_OBJECTS);          return 0;      } -    return group->meth->point_set_affine_coordinates(group, point, x, y, ctx); +    if (!group->meth->point_set_affine_coordinates(group, point, x, y, ctx)) +        return 0; + +    if (EC_POINT_is_on_curve(group, point, ctx) <= 0) { +        ECerr(EC_F_EC_POINT_SET_AFFINE_COORDINATES_GF2M, +              EC_R_POINT_IS_NOT_ON_CURVE); +        return 0; +    } +    return 1;  }  #endif | 
