mirror of
https://github.com/freebsd/freebsd-src
synced 2024-10-15 21:05:08 +00:00
e0c4386e7e
* Fixed PKCS12 Decoding crashes ([CVE-2024-0727]) * Fixed Excessive time spent checking invalid RSA public keys ([CVE-2023-6237]) * Fixed POLY1305 MAC implementation corrupting vector registers on PowerPC CPUs which support PowerISA 2.07 ([CVE-2023-6129]) * Fix excessive time spent in DH check / generation with large Q parameter value ([CVE-2023-5678]) Release notes can be found at https://www.openssl.org/news/openssl-3.0-notes.html. Approved by: emaste MFC after: 3 days Merge commit '9dd13e84fa8eca8f3462bd55485aa3da8c37f54a'
45 lines
1.4 KiB
Raku
45 lines
1.4 KiB
Raku
#! /usr/bin/env perl
|
|
# Copyright 2021 The OpenSSL Project Authors. All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License 2.0 (the "License"). You may not use
|
|
# this file except in compliance with the License. You can obtain a copy
|
|
# in the file LICENSE in the source distribution or at
|
|
# https://www.openssl.org/source/license.html
|
|
|
|
use Getopt::Long;
|
|
|
|
my $activate = 1;
|
|
my $conditional_errors = 1;
|
|
my $security_checks = 1;
|
|
my $mac_key;
|
|
my $module_name;
|
|
my $section_name = "fips_sect";
|
|
|
|
GetOptions("key=s" => \$mac_key,
|
|
"module=s" => \$module_name,
|
|
"section_name=s" => \$section_name)
|
|
or die "Error when getting command line arguments";
|
|
|
|
my $mac_keylen = length($mac_key);
|
|
|
|
use Digest::SHA qw(hmac_sha256_hex);
|
|
my $module_size = [ stat($module_name) ]->[7];
|
|
|
|
open my $fh, "<:raw", $module_name or die "Trying to open $module_name: $!";
|
|
read $fh, my $data, $module_size or die "Trying to read $module_name: $!";
|
|
close $fh;
|
|
|
|
# Calculate HMAC-SHA256 in hex, and split it into a list of two character
|
|
# chunks, and join the chunks with colons.
|
|
my @module_mac
|
|
= ( uc(hmac_sha256_hex($data, pack("H$mac_keylen", $mac_key))) =~ m/../g );
|
|
my $module_mac = join(':', @module_mac);
|
|
|
|
print <<_____;
|
|
[$section_name]
|
|
activate = $activate
|
|
conditional-errors = $conditional_errors
|
|
security-checks = $security_checks
|
|
module-mac = $module_mac
|
|
_____
|