[BACK]Return to noctvar.h CVS log [TXT][DIR] Up to [local] / sys / dev / pci

Annotation of sys/dev/pci/noctvar.h, Revision 1.1.1.1

1.1       nbrk        1: /*     $OpenBSD: noctvar.h,v 1.7 2003/06/02 19:08:58 jason Exp $       */
                      2:
                      3: /*
                      4:  * Copyright (c) 2002 Jason L. Wright (jason@thought.net)
                      5:  * All rights reserved.
                      6:  *
                      7:  * Redistribution and use in source and binary forms, with or without
                      8:  * modification, are permitted provided that the following conditions
                      9:  * are met:
                     10:  * 1. Redistributions of source code must retain the above copyright
                     11:  *    notice, this list of conditions and the following disclaimer.
                     12:  * 2. Redistributions in binary form must reproduce the above copyright
                     13:  *    notice, this list of conditions and the following disclaimer in the
                     14:  *    documentation and/or other materials provided with the distribution.
                     15:  *
                     16:  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
                     17:  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
                     18:  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
                     19:  * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
                     20:  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
                     21:  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
                     22:  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
                     23:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
                     24:  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
                     25:  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
                     26:  * POSSIBILITY OF SUCH DAMAGE.
                     27:  *
                     28:  * Effort sponsored in part by the Defense Advanced Research Projects
                     29:  * Agency (DARPA) and Air Force Research Laboratory, Air Force
                     30:  * Materiel Command, USAF, under agreement number F30602-01-2-0537.
                     31:  *
                     32:  */
                     33:
                     34: #define        NOCT_RNG_QLEN           15
                     35: #define        NOCT_RNG_ENTRIES        (1 << NOCT_RNG_QLEN)
                     36: #define        NOCT_RNG_BUFSIZE        (NOCT_RNG_ENTRIES * sizeof(u_int64_t))
                     37:
                     38: #define        NOCT_PKH_QLEN           15
                     39: #define        NOCT_PKH_ENTRIES        (1 << NOCT_PKH_QLEN)
                     40: #define        NOCT_PKH_BUFSIZE        (NOCT_PKH_ENTRIES * sizeof(union noct_pkh_cmd))
                     41:
                     42: #define        NOCT_EA_QLEN            15
                     43: #define        NOCT_EA_ENTRIES         (1 << NOCT_EA_QLEN)
                     44: #define        NOCT_EA_BUFSIZE         (NOCT_EA_ENTRIES * sizeof(struct noct_ea_cmd))
                     45:
                     46: #define        NOCT_BN_CACHE_SIZE      ((256) * (128 / 8))
                     47:
                     48: struct noct_workq {
                     49:        SIMPLEQ_ENTRY(noct_workq)       q_next;
                     50:        struct cryptop                  *q_crp;
                     51:        bus_dmamap_t                    q_dmamap;
                     52:        bus_dma_segment_t               q_dmaseg;
                     53:        caddr_t                         q_buf;
                     54:        u_int8_t                        q_macbuf[20];
                     55: };
                     56:
                     57: struct noct_softc;
                     58:
                     59: struct noct_bnc_sw {
                     60:        u_long bn_off;                  /* cache offset */
                     61:        u_long bn_siz;                  /* cache size */
                     62:        void (*bn_callback)(struct noct_softc *, u_int32_t, int);
                     63:        struct cryptkop *bn_krp;
                     64: };
                     65:
                     66: struct noct_softc {
                     67:        struct device sc_dv;
                     68:        bus_space_tag_t sc_st;
                     69:        bus_space_handle_t sc_sh;
                     70:        bus_dma_tag_t sc_dmat;
                     71:        void *sc_ih;
                     72:        bus_size_t sc_rar_last, sc_waw_last;
                     73:        u_int sc_ramsize;
                     74:        int32_t sc_cid;                 /* cryptodev id */
                     75:
                     76:        u_int64_t *sc_rngbuf;
                     77:        bus_dmamap_t sc_rngmap;
                     78:        struct timeout sc_rngto;
                     79:        int sc_rngtick;
                     80:
                     81:        bus_dmamap_t sc_pkhmap;         /* pkh buffer map */
                     82:        bus_dmamap_t sc_bnmap;          /* bignumber cache map */
                     83:        union noct_pkh_cmd *sc_pkhcmd;  /* pkh command buffers */
                     84:        u_int8_t *sc_bncache;           /* bignumber cache buffer */
                     85:        u_int32_t sc_pkhwp;             /* pkh write pointer */
                     86:        u_int32_t sc_pkhrp;             /* pkh read pointer */
                     87:        struct extent *sc_pkh_bn;       /* pkh big number cache usage */
                     88:        struct noct_bnc_sw      sc_pkh_bnsw[NOCT_PKH_ENTRIES];
                     89:
                     90:        bus_dmamap_t sc_eamap;          /* ea buffer map */
                     91:        u_int32_t sc_eawp;              /* ea write pointer */
                     92:        u_int32_t sc_earp;              /* ea read pointer */
                     93:        struct noct_ea_cmd *sc_eacmd;   /* ea command buffers */
                     94:
                     95:        SIMPLEQ_HEAD(,noct_workq)       sc_inq;
                     96:        SIMPLEQ_HEAD(,noct_workq)       sc_chipq;
                     97:        SIMPLEQ_HEAD(,noct_workq)       sc_outq;
                     98: };
                     99:
                    100: #define        NOCT_READ_4(sc,r)       noct_read_4((sc), (r))
                    101: #define        NOCT_WRITE_4(sc,r,v)    noct_write_4((sc), (r), (v))
                    102: #define        NOCT_READ_8(sc,r)       noct_read_8((sc), (r))
                    103: #define        NOCT_WRITE_8(sc,r,v)    noct_write_8((sc), (r), (v))
                    104:
                    105: #define        NOCT_CARD(sid)          (((sid) & 0xf0000000) >> 28)
                    106: #define        NOCT_SESSION(sid)       ( (sid) & 0x0fffffff)
                    107: #define        NOCT_SID(crd, sesn)     (((crd) << 28) | ((sesn) & 0x0fffffff))
                    108:
                    109: #define        NOCT_WAKEUP(sc) wakeup(&(sc)->sc_eawp)
                    110: #define        NOCT_SLEEP(sc)  tsleep(&(sc)->sc_eawp, PWAIT, "noctea", 0)
                    111:

CVSweb