Home | History | Annotate | Line # | Download | only in dev
      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