NetBSD/sys/dev/marvell/gtidmavar.h

214 lines
6.5 KiB
C
Raw Normal View History

2005-12-11 15:16:03 +03:00
/* $NetBSD: gtidmavar.h,v 1.4 2005/12/11 12:22:16 christos Exp $ */
/*
* Copyright (c) 2002 Allegro Networks, Inc., Wasabi Systems, Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed for the NetBSD Project by
* Allegro Networks, Inc., and Wasabi Systems, Inc.
* 4. The name of Allegro Networks, Inc. may not be used to endorse
* or promote products derived from this software without specific prior
* written permission.
* 5. The name of Wasabi Systems, Inc. may not be used to endorse
* or promote products derived from this software without specific prior
* written permission.
*
* THIS SOFTWARE IS PROVIDED BY ALLEGRO NETWORKS, INC. AND
* WASABI SYSTEMS, INC. ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL EITHER ALLEGRO NETWORKS, INC. OR WASABI SYSTEMS, INC.
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
/*
* idmavar.h -- defines for GT-64260 IDMA driver
*
* creation Wed Aug 15 00:48:10 PDT 2001 cliff
*/
#ifndef _IDMAVAR_H
#define _IDMAVAR_H
/*
* IDMA Overview:
*
* A driver allocates an IDMA channel, registering for callbacks.
* The channel includes descriptors and a pending queue
*
* The driver allocates & details descriptors, then requests start
*
* ... time passes ...
*
2005-02-27 03:26:58 +03:00
* On completion the callback is made, passing the opaque "arg"
* (e.g. a softc), a descriptor handle, and completion status
* The driver callback completes the transaction and frees
* or recycles the descriptor.
*
* If the channel is no longer needed the driver may free it,
* but we expect drivers to hold channels long term
* (i.e till shutdown).
*
* Descriptors:
*
* Hardware descriptors are coupled 1:1 with descriptor handles.
* The descriptors themselves are as defined by GT-64260 spec;
* descriptor handles control descriptor use. They are separate
* to allow efficient packing of descriptors in DMA mapped memory.
*/
2005-02-27 03:26:58 +03:00
/*
* NOTE:
* interrupt priority IPL_IDMA is determined by worst case client driver
* since each IDMA IRQ is shared across 4 channels
* so adjust as needed
*/
#define IPL_IDMA IPL_NET
#define splidma() splraise(IPL_IDMA)
#define IDMA_DMSEG_MAX 1
typedef struct idma_dmamem {
bus_dmamap_t idm_map; /* dmamem'ed memory */
caddr_t idm_kva; /* kva of dmamem memory */
int idm_nsegs; /* # of segment in idm_segs */
int idm_maxsegs; /* maximum # of segments allowed */
size_t idm_size; /* size of memory region */
bus_dma_segment_t idm_segs[IDMA_DMSEG_MAX];
} idma_dmamem_t;
/*
* descriptor handle
*/
typedef enum {
IDH_FREE,
IDH_ALLOC,
IDH_QWAIT,
IDH_PENDING,
IDH_RETRY,
IDH_DONE,
IDH_CANCEL,
IDH_ABORT
} idma_desch_state_t;
typedef enum {
IDS_OK,
IDS_FAIL
} idma_sts_t;
struct idma_chan;
typedef struct idma_desch {
idma_desch_state_t idh_state;
struct idma_desch *idh_next;
struct idma_chan *idh_chan;
u_int32_t idh_hold;
SIMPLEQ_ENTRY(idma_desch) idh_q;
struct idma_desc *idh_desc_va;
struct idma_desc *idh_desc_pa;
void *idh_aux;
u_int64_t tb;
} idma_desch_t;
/*
* descriptor handle queue head
*/
typedef unsigned int idma_chan_state_t;
#define IDC_FREE 0
#define IDC_ALLOC 1
#define IDC_IDLE 2
#define IDC_STOPPED 4
#define IDC_QFULL 8
typedef struct idma_q {
unsigned int idq_depth;
SIMPLEQ_HEAD(, idma_desch) idq_q;
} idma_q_t;
/*
* IDMA channel control
*/
struct idma_softc;
typedef struct idma_chan {
idma_chan_state_t idc_state;
struct idma_softc *idc_sc;
unsigned int idc_chan; /* channel number */
2005-02-04 05:10:35 +03:00
int (*idc_callback)(void *, struct idma_desch *, u_int32_t);
/* completion callback */
void *idc_arg; /* completion callback arg */
idma_q_t idc_q; /* pending transactions */
unsigned int idc_ndesch; /* # descriptor handles */
idma_desch_t *idc_active; /* active transaction */
idma_desch_t *idc_desch_free; /* allocation ptr */
idma_desch_t *idc_desch_done; /* completion ptr */
idma_desch_t *idc_desch; /* descriptor handles */
idma_dmamem_t idc_desc_mem; /* descriptor dmamem */
unsigned long idc_done_count; /* running done count */
unsigned long idc_abort_count; /* running abort count */
} idma_chan_t;
/*
* IDMA driver softc
*/
typedef unsigned int idma_state_t;
#define IDMA_ATTACHED 1
typedef struct idma_softc {
struct device idma_dev;
struct gt_softc *idma_gt;
bus_space_tag_t idma_bustag;
bus_dma_tag_t idma_dmatag;
bus_space_handle_t idma_bushandle;
bus_addr_t idma_reg_base;
bus_size_t idma_reg_size;
u_int32_t idma_ien;
struct callout idma_callout;
unsigned int idma_callout_state;
unsigned int idma_burst_size;
idma_state_t idma_state;
idma_chan_t idma_chan[NIDMA_CHANS];
void *idma_ih[4];
} idma_softc_t;
/*
* IDMA external function prototypes
*/
2005-02-04 05:10:35 +03:00
extern void idma_chan_free(idma_chan_t *);
extern idma_chan_t *idma_chan_alloc(unsigned int,
int (*)(void *, struct idma_desch *, u_int32_t), void *);
2005-02-04 05:10:35 +03:00
extern void idma_desch_free(idma_desch_t *);
extern idma_desch_t *idma_desch_alloc(idma_chan_t *);
extern void idma_desch_list_free(idma_desch_t *);
2005-02-04 05:10:35 +03:00
extern void idma_desc_list_free(idma_desch_t *);
extern idma_desch_t *idma_desch_list_alloc(idma_chan_t *, unsigned int);
2005-02-04 05:10:35 +03:00
extern void idma_intr_enb(idma_chan_t *);
extern void idma_intr_dis(idma_chan_t *);
2005-02-04 05:10:35 +03:00
extern int idma_start(idma_desch_t *);
extern void idma_qflush(idma_chan_t *);
2005-02-04 05:10:35 +03:00
extern void idma_abort(idma_desch_t *, unsigned int, const char *);
/*
* flags for idma_abort()
*/
#define IDMA_ABORT_CANCEL 1 /* don't atempt completion or retry */
#endif /* _IDMAVAR_H */