On Sun, Jun 16, 2019 at 08:52:32AM +0200, Ard Biesheuvel wrote:
> On Sun, 16 Jun 2019 at 03:20, Eric Biggers <[email protected]> wrote:
> >
> > On Sat, Jun 15, 2019 at 11:17:45AM +0200, Ard Biesheuvel wrote:
> > > The wusb code takes a very peculiar approach at implementing CBC-MAC,
> > > by using plain CBC into a scratch buffer, and taking the output IV
> > > as the MAC.
> > >
> > > We can clean up this code substantially by switching to the cbcmac
> > > shash, as exposed by the CCM template. To ensure that the module is
> > > loaded on demand, add the cbcmac template name as a module alias.
> > >
> > > Signed-off-by: Ard Biesheuvel <[email protected]>
> > > ---
> > > v3: - add missing #include to fix build error spotted by kbuild test robot
> > > v2: - use finup()/digest() where possible, and process b0+b1 using a
> > > single
> > > call to update()
> > > - make 'stv_hsmic_hs' static const and remove comment regarding GCC
> > > 4.1
> > >
> > > NOTE: I don't have any hardware to test this, but the built-in selftest
> > > still passes.
> > >
> > > crypto/ccm.c | 1 +
> > > drivers/usb/wusbcore/crypto.c | 169 +++++---------------
> > > 2 files changed, 45 insertions(+), 125 deletions(-)
> > >
> >
> > drivers/usb/wusbcore/Kconfig also needs to be updated:
> >
> > diff --git a/drivers/usb/wusbcore/Kconfig b/drivers/usb/wusbcore/Kconfig
> > index 12e89189ca7d..2ec17d6af1f8 100644
> > --- a/drivers/usb/wusbcore/Kconfig
> > +++ b/drivers/usb/wusbcore/Kconfig
> > @@ -6,9 +6,7 @@ config USB_WUSB
> > tristate "Enable Wireless USB extensions"
> > depends on UWB
> > select CRYPTO
> > - select CRYPTO_BLKCIPHER
> > - select CRYPTO_CBC
> > - select CRYPTO_MANAGER
>
> We'll need this one, as it isn't implied by any of the other ones, and
> cbcmac(aes) will be composed of the ccm template and the aes cipher on
> all architectures except arm64.
>
> > + select CRYPTO_CCM
Are you talking about CRYPTO_MANAGER? One of my recent patches added
'select CRYPTO_MANAGER' to the templates that didn't already select it,
including CCM. See in cryptodev.git:
commit c8a3315a5f691cc4be16421aeb0608495c9a33ba
Author: Eric Biggers <[email protected]>
Date: Mon May 20 09:49:46 2019 -0700
crypto: make all templates select CRYPTO_MANAGER
So it shouldn't need to be selected here.
- Eric