1 1.21 riastrad /* $NetBSD: cgdvar.h,v 1.21 2020/06/13 22:15:58 riastradh Exp $ */ 2 1.1 elric 3 1.1 elric /*- 4 1.1 elric * Copyright (c) 2002 The NetBSD Foundation, Inc. 5 1.1 elric * All rights reserved. 6 1.1 elric * 7 1.1 elric * This code is derived from software contributed to The NetBSD Foundation 8 1.1 elric * by Roland C. Dowdeswell. 9 1.1 elric * 10 1.1 elric * Redistribution and use in source and binary forms, with or without 11 1.1 elric * modification, are permitted provided that the following conditions 12 1.1 elric * are met: 13 1.1 elric * 1. Redistributions of source code must retain the above copyright 14 1.1 elric * notice, this list of conditions and the following disclaimer. 15 1.1 elric * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 elric * notice, this list of conditions and the following disclaimer in the 17 1.1 elric * documentation and/or other materials provided with the distribution. 18 1.1 elric * 19 1.1 elric * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.1 elric * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.1 elric * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.1 elric * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.1 elric * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.1 elric * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.1 elric * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.1 elric * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.1 elric * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.1 elric * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.1 elric * POSSIBILITY OF SUCH DAMAGE. 30 1.1 elric */ 31 1.1 elric 32 1.3 thorpej #ifndef _DEV_CGDVAR_H_ 33 1.3 thorpej #define _DEV_CGDVAR_H_ 34 1.3 thorpej 35 1.18 dholland #include <sys/ioccom.h> 36 1.18 dholland 37 1.16 christos /* ioctl(2) code: used by CGDIOCSET and CGDIOCCLR */ 38 1.1 elric struct cgd_ioctl { 39 1.4 christos const char *ci_disk; 40 1.4 christos int ci_flags; 41 1.4 christos int ci_unit; 42 1.4 christos size_t ci_size; 43 1.4 christos const char *ci_alg; 44 1.4 christos const char *ci_ivmethod; 45 1.4 christos size_t ci_keylen; 46 1.4 christos const char *ci_key; 47 1.8 christos size_t ci_blocksize; 48 1.1 elric }; 49 1.1 elric 50 1.16 christos /* ioctl(2) code: used by CGDIOCGET */ 51 1.16 christos struct cgd_user { 52 1.16 christos int cgu_unit; /* which cgd unit */ 53 1.16 christos dev_t cgu_dev; /* target device */ 54 1.16 christos char cgu_alg[32]; /* algorithm name */ 55 1.16 christos size_t cgu_blocksize; /* block size (in bytes) */ 56 1.16 christos int cgu_mode; /* Cipher Mode and IV Gen method */ 57 1.16 christos #define CGD_CIPHER_CBC_ENCBLKNO8 1 /* CBC Mode w/ Enc Block Number 58 1.16 christos * 8 passes (compat only) 59 1.16 christos */ 60 1.16 christos #define CGD_CIPHER_CBC_ENCBLKNO1 2 /* CBC Mode w/ Enc Block Number 61 1.16 christos * 1 pass (default) 62 1.16 christos */ 63 1.16 christos int cgu_keylen; /* keylength */ 64 1.16 christos }; 65 1.16 christos 66 1.1 elric #ifdef _KERNEL 67 1.1 elric 68 1.1 elric #include <dev/cgd_crypto.h> 69 1.20 riastrad #include <dev/dkvar.h> 70 1.1 elric 71 1.1 elric /* This cryptdata structure is here rather than cgd_crypto.h, since 72 1.1 elric * it stores local state which will not be generalised beyond the 73 1.1 elric * cgd driver. 74 1.1 elric */ 75 1.1 elric 76 1.1 elric struct cryptdata { 77 1.6 christos size_t cf_blocksize; /* block size (in bytes) */ 78 1.16 christos int cf_keylen; /* key length */ 79 1.16 christos int cf_mode; /* Cipher Mode and IV Gen method 80 1.16 christos * (see cgu_mode above for defines) */ 81 1.1 elric void *cf_priv; /* enc alg private data */ 82 1.1 elric }; 83 1.1 elric 84 1.19 mlelstv struct cgd_xfer { 85 1.19 mlelstv struct work cx_work; 86 1.19 mlelstv struct cgd_softc *cx_sc; 87 1.19 mlelstv struct buf *cx_obp; 88 1.19 mlelstv struct buf *cx_nbp; 89 1.19 mlelstv void *cx_dstv; 90 1.21 riastrad const void *cx_srcv; 91 1.19 mlelstv size_t cx_len; 92 1.19 mlelstv daddr_t cx_blkno; 93 1.19 mlelstv size_t cx_secsize; 94 1.19 mlelstv int cx_dir; 95 1.19 mlelstv }; 96 1.19 mlelstv 97 1.19 mlelstv struct cgd_worker { 98 1.19 mlelstv struct workqueue *cw_wq; /* work queue */ 99 1.19 mlelstv struct pool *cw_cpool; /* cgd_xfer contexts */ 100 1.19 mlelstv u_int cw_busy; /* number of busy contexts */ 101 1.19 mlelstv u_int cw_last; /* index of last CPU used */ 102 1.19 mlelstv kmutex_t cw_lock; 103 1.19 mlelstv }; 104 1.19 mlelstv 105 1.1 elric struct cgd_softc { 106 1.1 elric struct dk_softc sc_dksc; /* generic disk interface */ 107 1.1 elric struct vnode *sc_tvn; /* target device's vnode */ 108 1.1 elric dev_t sc_tdev; /* target device */ 109 1.1 elric char *sc_tpath; /* target device's path */ 110 1.19 mlelstv void *sc_data; /* emergency buffer */ 111 1.19 mlelstv bool sc_data_used; /* Really lame, we'll change */ 112 1.1 elric size_t sc_tpathlen; /* length of prior string */ 113 1.1 elric struct cryptdata sc_cdata; /* crypto data */ 114 1.16 christos const struct cryptfuncs *sc_cfuncs; /* encryption functions */ 115 1.19 mlelstv kmutex_t sc_lock; 116 1.19 mlelstv kcondvar_t sc_cv; 117 1.19 mlelstv bool sc_busy; 118 1.19 mlelstv struct cgd_worker *sc_worker; /* shared worker data */ 119 1.1 elric }; 120 1.1 elric #endif 121 1.1 elric 122 1.1 elric /* XXX XAX XXX elric: check these out properly. */ 123 1.1 elric #define CGDIOCSET _IOWR('F', 18, struct cgd_ioctl) 124 1.1 elric #define CGDIOCCLR _IOW('F', 19, struct cgd_ioctl) 125 1.16 christos #define CGDIOCGET _IOWR('F', 20, struct cgd_user) 126 1.3 thorpej 127 1.13 christos /* Maximum block sized to be used by the ciphers */ 128 1.13 christos #define CGD_MAXBLOCKSIZE 128 129 1.13 christos 130 1.3 thorpej #endif /* _DEV_CGDVAR_H_ */ 131