#ifndef _DEV_PCI_EMU10K1VAR_H_
#define _DEV_PCI_EMU10K1VAR_H_
#define EMU_PCI_CBIO 0x10
#define EMU_SUBSYS_APS 0x40011102
struct dmamem {
bus_dma_tag_t dmat;
bus_size_t size;
bus_size_t align;
bus_size_t bound;
bus_dma_segment_t *segs;
int nsegs;
int rsegs;
caddr_t kaddr;
bus_dmamap_t map;
};
#define KERNADDR(ptr) ((void *)((ptr)->kaddr))
#define DMASEGADDR(ptr, segno) ((ptr)->segs[segno].ds_addr)
#define DMAADDR(ptr) DMASEGADDR(ptr, 0)
#define DMASIZE(ptr) ((ptr)->size)
#define EMU_PTESIZE 4096
#define EMU_MAXPTE ((EMU_CHAN_PSST_LOOPSTARTADDR_MASK + 1) / \
EMU_PTESIZE)
#define EMU_NUMCHAN 64
#define EMU_NUMRECSRCS 3
#define EMU_DMA_ALIGN 4096
#define EMU_DMAMEM_NSEG 1
struct emuxki_mem {
LIST_ENTRY(emuxki_mem) next;
struct dmamem *dmamem;
u_int16_t ptbidx;
#define EMU_RMEM 0xFFFF
};
struct emuxki_chanparms_fxsend {
struct {
u_int8_t level, dest;
} a, b, c, d, e, f, g, h;
};
struct emuxki_chanparms_pitch {
u_int16_t initial;
u_int16_t current;
u_int16_t target;
u_int8_t envelope_amount;
};
struct emuxki_chanparms_envelope {
u_int16_t current_state;
u_int8_t hold_time;
u_int8_t attack_time;
u_int8_t sustain_level;
u_int8_t decay_time;
};
struct emuxki_chanparms_volume {
u_int16_t current, target;
struct emuxki_chanparms_envelope envelope;
};
struct emuxki_chanparms_filter {
u_int16_t initial_cutoff_frequency;
u_int16_t current_cutoff_frequency;
u_int16_t target_cutoff_frequency;
u_int8_t lowpass_resonance_height;
u_int8_t interpolation_ROM;
u_int8_t envelope_amount;
u_int8_t LFO_modulation_depth;
};
struct emuxki_chanparms_loop {
u_int32_t start;
u_int32_t end;
};
struct emuxki_chanparms_modulation {
struct emuxki_chanparms_envelope envelope;
u_int16_t LFO_state;
};
struct emuxki_chanparms_vibrato_LFO {
u_int16_t state;
u_int8_t modulation_depth;
u_int8_t vibrato_depth;
u_int8_t frequency;
};
struct emuxki_channel {
u_int8_t num;
struct emuxki_voice *voice;
struct emuxki_chanparms_fxsend fxsend;
struct emuxki_chanparms_pitch pitch;
u_int16_t initial_attenuation;
struct emuxki_chanparms_volume volume;
struct emuxki_chanparms_filter filter;
struct emuxki_chanparms_loop loop;
struct emuxki_chanparms_modulation modulation;
struct emuxki_chanparms_vibrato_LFO vibrato_LFO;
u_int8_t tremolo_depth;
};
typedef enum {
EMU_RECSRC_MIC = 0,
EMU_RECSRC_ADC,
EMU_RECSRC_FX,
EMU_RECSRC_NOTSET
} emuxki_recsrc_t;
struct emuxki_voice {
struct emuxki_softc *sc;
u_int8_t use;
#define EMU_VOICE_USE_PLAY (1 << 0)
u_int8_t state;
#define EMU_VOICE_STATE_STARTED (1 << 0)
u_int8_t stereo;
#define EMU_VOICE_STEREO_NOTSET 0xFF
u_int8_t b16;
u_int32_t sample_rate;
union {
struct emuxki_channel *chan[2];
emuxki_recsrc_t source;
} dataloc;
struct emuxki_mem *buffer;
u_int16_t blksize;
u_int16_t trigblk;
u_int16_t blkmod;
u_int16_t timerate;
void (*inth) (void *);
void *inthparam;
LIST_ENTRY(emuxki_voice) next;
};
#if 0
struct emuxki_stream {
struct emu10k1 *emu;
u_int8_t nmono;
u_int8_t nstereo;
struct emuxki_voice *mono;
struct emuxki_voice *stereo;
LIST_ENTRY(emuxki_stream) next;
};
#endif
struct emuxki_softc {
struct device sc_dev;
bus_space_tag_t sc_iot;
bus_space_handle_t sc_ioh;
bus_addr_t sc_iob;
bus_size_t sc_ios;
pci_chipset_tag_t sc_pc;
bus_dma_tag_t sc_dmat;
void *sc_ih;
LIST_HEAD(, emuxki_mem) mem;
struct dmamem *ptb;
struct dmamem *silentpage;
struct emuxki_channel *channel[EMU_NUMCHAN];
struct emuxki_voice *recsrc[EMU_NUMRECSRCS];
LIST_HEAD(, emuxki_voice) voices;
u_int8_t timerstate;
#define EMU_TIMER_STATE_ENABLED 1
struct ac97_host_if hostif;
struct ac97_codec_if *codecif;
struct device *sc_audev;
struct emuxki_voice *pvoice, *rvoice, *lvoice;
int sc_flags;
#define EMUXKI_SBLIVE 0x0001
#define EMUXKI_AUDIGY 0x0002
#define EMUXKI_AUDIGY2 0x0004
#define EMUXKI_SBLIVE51 0x0008
#define EMUXKI_APS 0x0010
#define EMUXKI_CA0108 0x0020
#define EMUXKI_CA0151 0x0040
};
#endif