// Copyright 2009 The Go Authors. All rights reserved.// Use of this source code is governed by a BSD-style// license that can be found in the LICENSE file.package aesimport ()// BlockSize is the AES block size in bytes.constBlockSize = 16// A Block is an instance of AES using a particular key.// It is safe for concurrent use.typeBlockstruct {block}// blockExpanded is the block type used for all architectures except s390x,// which feeds the raw key directly to its instructions.type blockExpanded struct { rounds int// Round keys, where only the first (rounds + 1) × (128 ÷ 32) words are used. enc [60]uint32 dec [60]uint32}const (// AES-128 has 128-bit keys, 10 rounds, and uses 11 128-bit round keys // (11×128÷32 = 44 32-bit words).// AES-192 has 192-bit keys, 12 rounds, and uses 13 128-bit round keys // (13×128÷32 = 52 32-bit words).// AES-256 has 256-bit keys, 14 rounds, and uses 15 128-bit round keys // (15×128÷32 = 60 32-bit words). aes128KeySize = 16 aes192KeySize = 24 aes256KeySize = 32 aes128Rounds = 10 aes192Rounds = 12 aes256Rounds = 14)// roundKeysSize returns the number of uint32 of c.end or c.dec that are used.func ( *blockExpanded) () int {return (.rounds + 1) * (128 / 32)}typeKeySizeErrorintfunc ( KeySizeError) () string {return"crypto/aes: invalid key size " + strconv.Itoa(int())}// New creates and returns a new [cipher.Block] implementation.// The key argument should be the AES key, either 16, 24, or 32 bytes to select// AES-128, AES-192, or AES-256.func ( []byte) (*Block, error) {// This call is outline to let the allocation happen on the parent stack.returnnewOutlined(&Block{}, )}// newOutlined is marked go:noinline to avoid it inlining into New, and making New// too complex to inline itself.////go:noinlinefunc newOutlined( *Block, []byte) (*Block, error) {switchlen() {caseaes128KeySize, aes192KeySize, aes256KeySize:default:returnnil, KeySizeError(len()) }returnnewBlock(, ), nil}func newBlockExpanded( *blockExpanded, []byte) {switchlen() {caseaes128KeySize: .rounds = aes128Roundscaseaes192KeySize: .rounds = aes192Roundscaseaes256KeySize: .rounds = aes256Rounds }expandKeyGeneric(, )}func ( *Block) () int { returnBlockSize }func ( *Block) (, []byte) {iflen() < BlockSize {panic("crypto/aes: input not full block") }iflen() < BlockSize {panic("crypto/aes: output not full block") }ifalias.InexactOverlap([:BlockSize], [:BlockSize]) {panic("crypto/aes: invalid buffer overlap") }fips140.RecordApproved()encryptBlock(, , )}func ( *Block) (, []byte) {iflen() < BlockSize {panic("crypto/aes: input not full block") }iflen() < BlockSize {panic("crypto/aes: output not full block") }ifalias.InexactOverlap([:BlockSize], [:BlockSize]) {panic("crypto/aes: invalid buffer overlap") }fips140.RecordApproved()decryptBlock(, , )}
The pages are generated with Goldsv0.7.3. (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu.
PR and bug reports are welcome and can be submitted to the issue list.
Please follow @zigo_101 (reachable from the left QR code) to get the latest news of Golds.