Annotation of sys/dev/pci/emuxkivar.h, Revision 1.1
1.1 ! nbrk 1: /* $OpenBSD: emuxkivar.h,v 1.7 2005/11/30 22:17:47 brad Exp $ */
! 2: /* $NetBSD: emuxkivar.h,v 1.1 2001/10/17 18:39:41 jdolecek Exp $ */
! 3:
! 4: /*-
! 5: * Copyright (c) 2001 The NetBSD Foundation, Inc.
! 6: * All rights reserved.
! 7: *
! 8: * This code is derived from software contributed to The NetBSD Foundation
! 9: * by Yannick Montulet.
! 10: *
! 11: * Redistribution and use in source and binary forms, with or without
! 12: * modification, are permitted provided that the following conditions
! 13: * are met:
! 14: * 1. Redistributions of source code must retain the above copyright
! 15: * notice, this list of conditions and the following disclaimer.
! 16: * 2. Redistributions in binary form must reproduce the above copyright
! 17: * notice, this list of conditions and the following disclaimer in the
! 18: * documentation and/or other materials provided with the distribution.
! 19: * 3. All advertising materials mentioning features or use of this software
! 20: * must display the following acknowledgement:
! 21: * This product includes software developed by the NetBSD
! 22: * Foundation, Inc. and its contributors.
! 23: * 4. Neither the name of The NetBSD Foundation nor the names of its
! 24: * contributors may be used to endorse or promote products derived
! 25: * from this software without specific prior written permission.
! 26: *
! 27: * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
! 28: * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
! 29: * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
! 30: * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
! 31: * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
! 32: * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
! 33: * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
! 34: * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
! 35: * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
! 36: * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
! 37: * POSSIBILITY OF SUCH DAMAGE.
! 38: */
! 39:
! 40: #ifndef _DEV_PCI_EMU10K1VAR_H_
! 41: #define _DEV_PCI_EMU10K1VAR_H_
! 42:
! 43: #define EMU_PCI_CBIO 0x10
! 44: #define EMU_SUBSYS_APS 0x40011102
! 45:
! 46: /*
! 47: * dma memory management
! 48: */
! 49:
! 50: struct dmamem {
! 51: bus_dma_tag_t dmat;
! 52: bus_size_t size;
! 53: bus_size_t align;
! 54: bus_size_t bound;
! 55: bus_dma_segment_t *segs;
! 56: int nsegs;
! 57: int rsegs;
! 58: caddr_t kaddr;
! 59: bus_dmamap_t map;
! 60: };
! 61:
! 62: #define KERNADDR(ptr) ((void *)((ptr)->kaddr))
! 63: #define DMASEGADDR(ptr, segno) ((ptr)->segs[segno].ds_addr)
! 64: #define DMAADDR(ptr) DMASEGADDR(ptr, 0)
! 65: #define DMASIZE(ptr) ((ptr)->size)
! 66:
! 67: /*
! 68: * Emu10k1 hardware limits
! 69: */
! 70:
! 71: #define EMU_PTESIZE 4096
! 72: #define EMU_MAXPTE ((EMU_CHAN_PSST_LOOPSTARTADDR_MASK + 1) / \
! 73: EMU_PTESIZE)
! 74: #define EMU_NUMCHAN 64
! 75: #define EMU_NUMRECSRCS 3
! 76:
! 77: #define EMU_DMA_ALIGN 4096
! 78: #define EMU_DMAMEM_NSEG 1
! 79:
! 80: /*
! 81: * Emu10k1 memory management
! 82: */
! 83:
! 84: struct emuxki_mem {
! 85: LIST_ENTRY(emuxki_mem) next;
! 86: struct dmamem *dmamem;
! 87: u_int16_t ptbidx;
! 88: #define EMU_RMEM 0xFFFF /* recording memory */
! 89: };
! 90:
! 91: /*
! 92: * Emu10k1 play channel params
! 93: */
! 94:
! 95: struct emuxki_chanparms_fxsend {
! 96: struct {
! 97: u_int8_t level, dest;
! 98: } a, b, c, d, e, f, g, h;
! 99: };
! 100:
! 101: struct emuxki_chanparms_pitch {
! 102: u_int16_t initial;/* 4 bits of octave, 12 bits of fractional
! 103: * octave */
! 104: u_int16_t current;/* 0x4000 == unity pitch shift */
! 105: u_int16_t target; /* 0x4000 == unity pitch shift */
! 106: u_int8_t envelope_amount; /* Signed 2's complement, +/-
! 107: * one octave peak extremes */
! 108: };
! 109:
! 110: struct emuxki_chanparms_envelope {
! 111: u_int16_t current_state; /* 0x8000-n == 666*n usec delay */
! 112: u_int8_t hold_time; /* 127-n == n*(volume ? 88.2 :
! 113: * 42)msec */
! 114: u_int8_t attack_time; /* 0 = infinite, 1 = (volume ? 11 :
! 115: * 10.9) msec, 0x7f = 5.5msec */
! 116: u_int8_t sustain_level; /* 127 = full, 0 = off, 0.75dB
! 117: * increments */
! 118: u_int8_t decay_time; /* 0 = 43.7msec, 1 = 21.8msec, 0x7f =
! 119: * 22msec */
! 120: };
! 121:
! 122: struct emuxki_chanparms_volume {
! 123: u_int16_t current, target;
! 124: struct emuxki_chanparms_envelope envelope;
! 125: };
! 126:
! 127: struct emuxki_chanparms_filter {
! 128: u_int16_t initial_cutoff_frequency;
! 129: /*
! 130: * 6 most significant bits are semitones, 2 least significant bits
! 131: * are fractions
! 132: */
! 133: u_int16_t current_cutoff_frequency;
! 134: u_int16_t target_cutoff_frequency;
! 135: u_int8_t lowpass_resonance_height;
! 136: u_int8_t interpolation_ROM; /* 1 = full band, 7 = low
! 137: * pass */
! 138: u_int8_t envelope_amount; /* Signed 2's complement, +/-
! 139: * six octaves peak extremes */
! 140: u_int8_t LFO_modulation_depth; /* Signed 2's complement, +/-
! 141: * three octave extremes */
! 142: };
! 143:
! 144: struct emuxki_chanparms_loop {
! 145: u_int32_t start; /* index in the PTB (in samples) */
! 146: u_int32_t end; /* index in the PTB (in samples) */
! 147: };
! 148:
! 149: struct emuxki_chanparms_modulation {
! 150: struct emuxki_chanparms_envelope envelope;
! 151: u_int16_t LFO_state; /* 0x8000-n = 666*n usec delay */
! 152: };
! 153:
! 154: struct emuxki_chanparms_vibrato_LFO {
! 155: u_int16_t state; /* 0x8000-n == 666*n usec delay */
! 156: u_int8_t modulation_depth; /* Signed 2's complement, +/-
! 157: * one octave extremes */
! 158: u_int8_t vibrato_depth; /* Signed 2's complement, +/- one
! 159: * octave extremes */
! 160: u_int8_t frequency; /* 0.039Hz steps, maximum of 9.85 Hz */
! 161: };
! 162:
! 163: struct emuxki_channel {
! 164: u_int8_t num; /* voice number */
! 165: struct emuxki_voice *voice;
! 166: struct emuxki_chanparms_fxsend fxsend;
! 167: struct emuxki_chanparms_pitch pitch;
! 168: u_int16_t initial_attenuation; /* 0.375dB steps */
! 169: struct emuxki_chanparms_volume volume;
! 170: struct emuxki_chanparms_filter filter;
! 171: struct emuxki_chanparms_loop loop;
! 172: struct emuxki_chanparms_modulation modulation;
! 173: struct emuxki_chanparms_vibrato_LFO vibrato_LFO;
! 174: u_int8_t tremolo_depth;
! 175: };
! 176:
! 177: /*
! 178: * Voices, streams
! 179: */
! 180:
! 181: typedef enum {
! 182: EMU_RECSRC_MIC = 0,
! 183: EMU_RECSRC_ADC,
! 184: EMU_RECSRC_FX,
! 185: EMU_RECSRC_NOTSET
! 186: } emuxki_recsrc_t;
! 187:
! 188: struct emuxki_voice {
! 189: struct emuxki_softc *sc; /* our softc */
! 190:
! 191: u_int8_t use;
! 192: #define EMU_VOICE_USE_PLAY (1 << 0)
! 193: u_int8_t state;
! 194: #define EMU_VOICE_STATE_STARTED (1 << 0)
! 195: u_int8_t stereo;
! 196: #define EMU_VOICE_STEREO_NOTSET 0xFF
! 197: u_int8_t b16;
! 198: u_int32_t sample_rate;
! 199: union {
! 200: struct emuxki_channel *chan[2];
! 201: emuxki_recsrc_t source;
! 202: } dataloc;
! 203: struct emuxki_mem *buffer;
! 204: u_int16_t blksize;/* in samples */
! 205: u_int16_t trigblk;/* blk on which to trigger inth */
! 206: u_int16_t blkmod; /* Modulo value to wrap trigblk */
! 207: u_int16_t timerate;
! 208: void (*inth) (void *);
! 209: void *inthparam;
! 210: LIST_ENTRY(emuxki_voice) next;
! 211: };
! 212:
! 213: #if 0 /* Not yet */
! 214: /*
! 215: * I intend this to be able to manage things like AC-3
! 216: */
! 217: struct emuxki_stream {
! 218: struct emu10k1 *emu;
! 219: u_int8_t nmono;
! 220: u_int8_t nstereo;
! 221: struct emuxki_voice *mono;
! 222: struct emuxki_voice *stereo;
! 223: LIST_ENTRY(emuxki_stream) next;
! 224: };
! 225: #endif /* Not yet */
! 226:
! 227: struct emuxki_softc {
! 228: struct device sc_dev;
! 229: struct audio_device sc_audv;
! 230: enum {
! 231: EMUXKI_SBLIVE = 0x00, EMUXKI_AUDIGY = 0x01, EMUXKI_AUDIGY2 = 0x02,
! 232: EMUXKI_LIVE_5_1 = 0x04, EMUXKI_APS = 0x08
! 233: } sc_type;
! 234:
! 235: /* Autoconfig parameters */
! 236: bus_space_tag_t sc_iot;
! 237: bus_space_handle_t sc_ioh;
! 238: bus_addr_t sc_iob;
! 239: bus_size_t sc_ios;
! 240: pci_chipset_tag_t sc_pc; /* PCI tag */
! 241: bus_dma_tag_t sc_dmat;
! 242: void *sc_ih; /* interrupt handler */
! 243:
! 244: /* EMU10k1 device structures */
! 245: LIST_HEAD(, emuxki_mem) mem;
! 246:
! 247: struct dmamem *ptb;
! 248: struct dmamem *silentpage;
! 249:
! 250: struct emuxki_channel *channel[EMU_NUMCHAN];
! 251: struct emuxki_voice *recsrc[EMU_NUMRECSRCS];
! 252:
! 253: LIST_HEAD(, emuxki_voice) voices;
! 254: /* LIST_HEAD(, emuxki_stream) streams; */
! 255:
! 256: u_int8_t timerstate;
! 257: #define EMU_TIMER_STATE_ENABLED 1
! 258:
! 259: struct ac97_host_if hostif;
! 260: struct ac97_codec_if *codecif;
! 261: struct device *sc_audev;
! 262:
! 263: struct emuxki_voice *pvoice, *rvoice, *lvoice;
! 264: };
! 265:
! 266: #endif /* !_DEV_PCI_EMU10K1VAR_H_ */
CVSweb