aes_keysched.c revision 1.1
11.1Sriastrad/* $NetBSD: aes_keysched.c,v 1.1 2025/11/22 22:32:39 riastradh Exp $ */ 21.1Sriastrad 31.1Sriastrad/*- 41.1Sriastrad * Copyright (c) 2025 The NetBSD Foundation, Inc. 51.1Sriastrad * All rights reserved. 61.1Sriastrad * 71.1Sriastrad * Redistribution and use in source and binary forms, with or without 81.1Sriastrad * modification, are permitted provided that the following conditions 91.1Sriastrad * are met: 101.1Sriastrad * 1. Redistributions of source code must retain the above copyright 111.1Sriastrad * notice, this list of conditions and the following disclaimer. 121.1Sriastrad * 2. Redistributions in binary form must reproduce the above copyright 131.1Sriastrad * notice, this list of conditions and the following disclaimer in the 141.1Sriastrad * documentation and/or other materials provided with the distribution. 151.1Sriastrad * 161.1Sriastrad * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 171.1Sriastrad * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 181.1Sriastrad * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 191.1Sriastrad * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 201.1Sriastrad * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 211.1Sriastrad * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 221.1Sriastrad * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 231.1Sriastrad * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 241.1Sriastrad * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 251.1Sriastrad * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 261.1Sriastrad * POSSIBILITY OF SUCH DAMAGE. 271.1Sriastrad */ 281.1Sriastrad 291.1Sriastrad#include <sys/cdefs.h> 301.1Sriastrad__KERNEL_RCSID(1, "$NetBSD: aes_keysched.c,v 1.1 2025/11/22 22:32:39 riastradh Exp $"); 311.1Sriastrad 321.1Sriastrad#include <sys/types.h> 331.1Sriastrad 341.1Sriastrad#include <crypto/aes/aes_bear.h> 351.1Sriastrad#include <crypto/aes/aes_keysched.h> 361.1Sriastrad 371.1Sriastrad/* 381.1Sriastrad * aes_keysched_enc(rk, key, keybytes) 391.1Sriastrad * 401.1Sriastrad * Compute the standard AES encryption key schedule, expanding a 411.1Sriastrad * 16-, 24-, or 32-byte key into 44, 52, or 60 32-bit round keys 421.1Sriastrad * for encryption. Returns the number of rounds for the key of 431.1Sriastrad * this length. 441.1Sriastrad */ 451.1Sriastradu_int 461.1Sriastradaes_keysched_enc(uint32_t *rk, const void *key, size_t keybytes) 471.1Sriastrad{ 481.1Sriastrad 491.1Sriastrad return br_aes_ct_keysched_stdenc(rk, key, keybytes); 501.1Sriastrad} 511.1Sriastrad 521.1Sriastrad/* 531.1Sriastrad * aes_keysched_dec(rk, key, keybytes) 541.1Sriastrad * 551.1Sriastrad * Compute the standard AES decryption key schedule, expanding a 561.1Sriastrad * 16-, 24-, or 32-byte key into 44, 52, or 60 32-bit round keys 571.1Sriastrad * and applying InvMixColumns for decryption. Returns the number 581.1Sriastrad * of rounds for the key of this length. 591.1Sriastrad */ 601.1Sriastradu_int 611.1Sriastradaes_keysched_dec(uint32_t *rk, const void *key, size_t keybytes) 621.1Sriastrad{ 631.1Sriastrad 641.1Sriastrad return br_aes_ct_keysched_stddec(rk, key, keybytes); 651.1Sriastrad} 66