iopaauvar.h revision 1.4.6.2 1 1.4.6.2 jdolecek /* $NetBSD: iopaauvar.h,v 1.4.6.2 2002/09/06 08:33:14 jdolecek Exp $ */
2 1.4.6.2 jdolecek
3 1.4.6.2 jdolecek /*
4 1.4.6.2 jdolecek * Copyright (c) 2002 Wasabi Systems, Inc.
5 1.4.6.2 jdolecek * All rights reserved.
6 1.4.6.2 jdolecek *
7 1.4.6.2 jdolecek * Written by Jason R. Thorpe for Wasabi Systems, Inc.
8 1.4.6.2 jdolecek *
9 1.4.6.2 jdolecek * Redistribution and use in source and binary forms, with or without
10 1.4.6.2 jdolecek * modification, are permitted provided that the following conditions
11 1.4.6.2 jdolecek * are met:
12 1.4.6.2 jdolecek * 1. Redistributions of source code must retain the above copyright
13 1.4.6.2 jdolecek * notice, this list of conditions and the following disclaimer.
14 1.4.6.2 jdolecek * 2. Redistributions in binary form must reproduce the above copyright
15 1.4.6.2 jdolecek * notice, this list of conditions and the following disclaimer in the
16 1.4.6.2 jdolecek * documentation and/or other materials provided with the distribution.
17 1.4.6.2 jdolecek * 3. All advertising materials mentioning features or use of this software
18 1.4.6.2 jdolecek * must display the following acknowledgement:
19 1.4.6.2 jdolecek * This product includes software developed for the NetBSD Project by
20 1.4.6.2 jdolecek * Wasabi Systems, Inc.
21 1.4.6.2 jdolecek * 4. The name of Wasabi Systems, Inc. may not be used to endorse
22 1.4.6.2 jdolecek * or promote products derived from this software without specific prior
23 1.4.6.2 jdolecek * written permission.
24 1.4.6.2 jdolecek *
25 1.4.6.2 jdolecek * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND
26 1.4.6.2 jdolecek * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
27 1.4.6.2 jdolecek * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28 1.4.6.2 jdolecek * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL WASABI SYSTEMS, INC
29 1.4.6.2 jdolecek * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30 1.4.6.2 jdolecek * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31 1.4.6.2 jdolecek * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 1.4.6.2 jdolecek * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33 1.4.6.2 jdolecek * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34 1.4.6.2 jdolecek * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35 1.4.6.2 jdolecek * POSSIBILITY OF SUCH DAMAGE.
36 1.4.6.2 jdolecek */
37 1.4.6.2 jdolecek
38 1.4.6.2 jdolecek #ifndef _XSCALE_IOPAAUVAR_H_
39 1.4.6.2 jdolecek #define _XSCALE_IOPAAUVAR_H_
40 1.4.6.2 jdolecek
41 1.4.6.2 jdolecek #include <sys/pool.h>
42 1.4.6.2 jdolecek #include <dev/dmover/dmovervar.h>
43 1.4.6.2 jdolecek
44 1.4.6.2 jdolecek #define AAU_MAX_INPUTS 8
45 1.4.6.2 jdolecek
46 1.4.6.2 jdolecek /*
47 1.4.6.2 jdolecek * Due to the way the AAU's descriptors work, the DMA segments for
48 1.4.6.2 jdolecek * the inputs and output must all be the same length. For now, we
49 1.4.6.2 jdolecek * will enforce this by requiring all I/O to be page aligned, and
50 1.4.6.2 jdolecek * and not let it cross a page boundary.
51 1.4.6.2 jdolecek *
52 1.4.6.2 jdolecek * We could easily shrink this to any power of two.
53 1.4.6.2 jdolecek */
54 1.4.6.2 jdolecek #define AAU_IO_BOUNDARY 4096
55 1.4.6.2 jdolecek
56 1.4.6.2 jdolecek struct iopaau_softc {
57 1.4.6.2 jdolecek struct device sc_dev;
58 1.4.6.2 jdolecek struct dmover_backend sc_dmb;
59 1.4.6.2 jdolecek
60 1.4.6.2 jdolecek struct dmover_request *sc_running;
61 1.4.6.2 jdolecek
62 1.4.6.2 jdolecek bus_space_tag_t sc_st;
63 1.4.6.2 jdolecek bus_space_handle_t sc_sh;
64 1.4.6.2 jdolecek bus_dma_tag_t sc_dmat;
65 1.4.6.2 jdolecek
66 1.4.6.2 jdolecek void *sc_firstdesc;
67 1.4.6.2 jdolecek void *sc_lastdesc;
68 1.4.6.2 jdolecek uint32_t sc_firstdesc_pa;
69 1.4.6.2 jdolecek
70 1.4.6.2 jdolecek bus_dmamap_t sc_map_out;
71 1.4.6.2 jdolecek bus_dmamap_t sc_map_in[AAU_MAX_INPUTS];
72 1.4.6.2 jdolecek };
73 1.4.6.2 jdolecek
74 1.4.6.2 jdolecek struct iopaau_function {
75 1.4.6.2 jdolecek int (*af_setup)(struct iopaau_softc *, struct dmover_request *);
76 1.4.6.2 jdolecek struct pool_cache *af_desc_cache;
77 1.4.6.2 jdolecek };
78 1.4.6.2 jdolecek
79 1.4.6.2 jdolecek extern struct pool_cache iopaau_desc_4_cache;
80 1.4.6.2 jdolecek extern struct pool_cache iopaau_desc_8_cache;
81 1.4.6.2 jdolecek
82 1.4.6.2 jdolecek void iopaau_attach(struct iopaau_softc *);
83 1.4.6.2 jdolecek void iopaau_process(struct dmover_backend *);
84 1.4.6.2 jdolecek int iopaau_intr(void *);
85 1.4.6.2 jdolecek
86 1.4.6.2 jdolecek int iopaau_func_zero_setup(struct iopaau_softc *,
87 1.4.6.2 jdolecek struct dmover_request *);
88 1.4.6.2 jdolecek int iopaau_func_fill8_setup(struct iopaau_softc *,
89 1.4.6.2 jdolecek struct dmover_request *);
90 1.4.6.2 jdolecek int iopaau_func_xor_setup(struct iopaau_softc *,
91 1.4.6.2 jdolecek struct dmover_request *);
92 1.4.6.2 jdolecek
93 1.4.6.2 jdolecek void iopaau_desc_free(struct pool_cache *, void *);
94 1.4.6.2 jdolecek
95 1.4.6.2 jdolecek #endif /* _XSCALE_IOPAAUVAR_H_ */
96