Update of /cvsroot/alsa/alsa-driver/pci/au88x0/test In directory sc8-pr-cvs1:/tmp/cvs-serv6563/pci/au88x0/test
Added Files: au88x0_a3d.c au88x0_a3d.h Log Message: Manuel Jander <[EMAIL PROTECTED]>: added Aureal au88x0 drivers: snd-au8810, snd-au8820 and snd-au8830. --- NEW FILE: au88x0_a3d.c --- /*************************************************************************** * au88x0_a3d.c * * Fri Jul 18 14:16:22 2003 * Copyright 2003 mjander * [EMAIL PROTECTED] * * A3D. You may think i'm crazy, but this may work someday. Who knows... ****************************************************************************/ /* CA3dSourceHw */ void Asp4A3DTopology::MakeConnections(void) { if (this_34 == 0) { /* Connect A3DOUT to MIXIN */ Asp4Topology::Route((int) 1, (uchar) this_0c->this_0c, (uchar) this_08->this_04, (uchar) this_10 + 0x50, (uchar) this_14+0x50); /* Connect MIXIN's this_10 and this_14 to MIXOUT this_18 */ (CAsp4Mix)this_18::EnableInput(int this_10); (CAsp4Mix)this_18::EnableInput(int this_14); /* Connect MIXOUT this_18 to SRCIN this_0c */ Asp4Topology::Route((int) 1, (uchar) this_0c, (uchar) this_18->this_08 + 0x30, (uchar) this_0c + 0x40); /* Connect SRCOUT this_0c to A3DIN this_20 */ Asp4Topology::Route((int) 1, (uchar) 0x11, (uchar) this_0c->this0c + 0x20, (uchar) this_20 + 0x70); } else { if (this_08) { /* Connect this_08 to SRCIN this_0c */ Asp4Topology::Route((int) 1, (uchar) this_0c, (uchar) this_08->this_04, (uchar) this_0c + 0x40); /* Connect SRCOUT this_0c to A3DIN this_20 */ Asp4Topology::Route((int) 1, (uchar) 0x11, (uchar) this_0c->this0c + 0x20, (uchar) this_20 + 0x70); } else { // I'm tired. I going to sleep now . } } } void CA3dSourceHw::CA3dSourceHw(CAsp4HwIO *hwio, int a,int b) { CA3dSourceHw->this00 = hwio; CA3dSourceHw->this04 = a; CA3dSourceHw->this08 = b; } void CA3dSourceHw::Initialize(int a, int b) { CA3dSourceHw->this04 = a; CA3dSourceHw->this08 = b; CA3dSourceHw::ZeroState(void); } #define addr(a,b,c) (a + (c << 0xd) + (d*(1 + (8*4 - 3)*8))*4) void CA3dSourceHw::SetTimeConsts(short a, short b, short c, short d) { hwwrite(vortex->mmio, addr(0x1837C, this04, this08), a); hwwrite(vortex->mmio, addr(0x18388, this04, this08), b); hwwrite(vortex->mmio, addr(0x18380, this04, this08), c); hwwrite(vortex->mmio, addr(0x18384, this04, this08), d); } void CA3dSourceHw::GetTimeConsts(short a, short b, short c, short d) { } /* Atmospheric absorbtion. */ void CA3dSourceHw::SetAtmosTarget(short a,short b,short c,short d,short e) { hwwrite(vortex->mmio, addr(0x190Ec, this04, this08), (e << 0x10) | d); hwwrite(vortex->mmio, addr(0x190F4, this04, this08), (b << 0x10) | a); hwwrite(vortex->mmio, addr(0x190FC, this04, this08), c); } void CA3dSourceHw::SetAtmosTarget(short *a,short *b,short *c,short *d,short *e) { } void CA3dSourceHw::SetAtmosCurrent(short a,short b,short c,short d,short e) { hwwrite(vortex->mmio, addr(0x190E8, this04, this08), (e << 0x10) | d); hwwrite(vortex->mmio, addr(0x190f0, this04, this08), (b << 0x10) | a); hwwrite(vortex->mmio, addr(0x190f8, this04, this08), c); } void CA3dSourceHw::GetAtmosCurrent(short *a,short *b,short *c,short *d,short *e) { *d = hwread(vortex->mmio, addr(0x180e8, this04, this08)); *e = hwread(vortex->mmio, addr(0x190e8, this04, this08)); *b = hwread(vortex->mmio, addr(0x180f0, this04, this08)); *a = hwread(vortex->mmio, addr(0x190f0, this04, this08)); *c = hwread(vortex->mmio, addr(0x180f8, this04, this08)); } void CA3dSourceHw::SetAtmosState(short a,short b,short c,short d) { hwwrite(vortex->mmio, addr(0x1838C, this04, this08), a); hwwrite(vortex->mmio, addr(0x18390, this04, this08), b); hwwrite(vortex->mmio, addr(0x18394, this04, this08), c); hwwrite(vortex->mmio, addr(0x18398, this04, this08), d); } void CA3dSourceHw::GetAtmosState(short a,short b,short c,short d) { } #define addr2(a,b,c, i) (a + (((this08<<0xb)+i)<<2) + (this04*(5*9*2 - 1)*4*2)) void CA3dSourceHw::SetHrtfTarget(short const *a,short const *b) { int i; for (i=0; i<0x38; i++) hwwrite(vortex->mmio, addr2(0x19100, this04, this08, i), (b[i]<<0x10) | a[i]); } void CA3dSourceHw::GetHrtfTarget(short const *a,short const *b) { } void CA3dSourceHw::SetHrtfCurrent(short const *a,short const *b) { int i; for (i=0; i<0x38; i++) hwwrite(vortex->mmio, addr2(0x19000, this04, this08, i), (b[i]<<0x10) | a[i]); } void CA3dSourceHw::GetHrtfCurrent(short const *a,short const *b) { int i; // FIXME: verify this! for (i=0; i<0x38; i++) a[i] = hwread(vortex->mmio, addr2(0, this04+0xc, this08, i)); for (i=0; i<0x38; i++) b[i] = hwread(vortex->mmio, addr2(0x19000, this04, this08, i)); } void CA3dSourceHw::SetHrtfState(short const *a,short const *b) { int i; for (i=0; i<0x38; i++) hwwrite(vortex->mmio, addr2(0x191e8, this04, this08, i), (b[i]<<0x10) | a[i]); } void CA3dSourceHw::GetHrtfState(short const *a,short const *b) { int i; // FIXME: verify this! for (i=0; i<0x38; i++) a[i] = hwread(vortex->mmio, addr2(0, this04+0x6a, this08, i)); for (i=0; i<0x38; i++) b[i] = hwread(vortex->mmio, addr2(0x191e8, this04, this08, i)); } void CA3dSourceHw::GetHrtfOutput(short *left,short *right) { *left = hwread(vortex->mmio, addr(0x1839C, this04, this08)); *right = hwread(vortex->mmio, addr(0x183A0, this04, this08)); } void CA3dSourceHw::SetHrtfOutput(short left,short right) { hwwrite(vortex->mmio, addr(0x1839C, this04, this08), left); hwwrite(vortex->mmio, addr(0x183a0, this04, this08), right); } /* Interaural Time Difference. * "The other main clue that humans use to locate sounds, is called * Interaural Time Difference (ITD). The differences in distance from * the sound source to a listeners ears means that the sound will * reach one ear slightly before the other...." */ void CA3dSourceHw::SetItdTarget(short litd,short ritd) { if (litd < 0) litd = 0; if (litd > 0x57FF) litd = 0x57FF; if (ritd < 0) ritd = 0; if (ritd > 0x57FF) ritd = 0x57FF; hwwrite(vortex->mmio, addr(0x191DF+5, this04, this08), (ritd<<0x10)|litd); } void CA3dSourceHw::GetItdTarget(short *litd, short *ritd) { *ritd = hwread(vortex->mmio, addr(0x181E4, this04, this08)); *litd = hwread(vortex->mmio, addr(0x191E4, this04, this08)); } void CA3dSourceHw::SetItdCurrent(short litd, short ritd) { litd = 0; if (litd > 0x57FF) litd = 0x57FF; if (ritd < 0) ritd = 0; if (ritd > 0x57FF) ritd = 0x57FF; hwwrite(vortex->mmio, addr(0x191DF+1, this04, this08), (ritd<<0x10)|litd); } void CA3dSourceHw::GetItdCurrent(short *litd,short *ritd) { *ritd = hwread(vortex->mmio, addr(0x181E0, this04, this08)); *litd = hwread(vortex->mmio, addr(0x191E0, this04, this08)); } void CA3dSourceHw::SetItdDline(short const *dline) { int i; for (i=0; i<0x28; i++) hwwrite(vortex->mmio, addr2(0x182C8, this04, this08, i), dline[i]) } void CA3dSourceHw::GetItdDline(short *dline) { int i; for (i=0; i<0x28; i++) dline[i] = hwwrite(vortex->mmio, addr2(0x182C8, this04, this08, i)); } /* This is maybe used for IID Interaural Intensity Difference. */ void CA3dSourceHw::SetGainTarget(short a,short b) { hwwrite(vortex->mmio, addr(0x190E4, this04, this08), (b<<0x10)|a); } void CA3dSourceHw::GetGainTarget(short *,short *) { *b = hwread(vortex->mmio, addr(0x180e4, this04, this08)); *a = hwread(vortex->mmio, addr(0x190e4, this04, this08)); } void CA3dSourceHw::SetGainCurrent(short a,short b) { hwwrite(vortex->mmio, addr(0x190DC+4, this04, this08), (b<<0x10)|a); } void CA3dSourceHw::GetGainCurrent(short *a,short *b) { *b = hwread(vortex->mmio, addr(0x180e0, this04, this08)); *a = hwread(vortex->mmio, addr(0x190e0, this04, this08)); } /* Generic A3D stuff */ void CA3dSourceHw::SetA3DSampleRate(int sr) { int esp0 = 0; esp0 = (((esp0 & 0x7fffffff)|0xB8000000)&0x7) | ((sr&0x1f)<<3); hwwrite(vortex->mmio, 0x19C38 + (this08<<0xd), esp0); } void CA3dSourceHw::GetA3DSampleRate(int *sr) { *sr = ((hwread(vortex->mmio, 0x19C38 + (this08<<0xd))>>3)&0x1f); } void CA3dSourceHw::EnableA3D(void) { hwwrite(vortex->mmio, 19C38 + (this08<<0xd), 0xF0000001); } void CA3dSourceHw::DisableA3D(void) { hwwrite(vortex->mmio, 19C38 + (this08<<0xd), 0xF0000000); } void CA3dSourceHw::SetA3DControlReg(unsigned long ctrl) { hwwrite(vortex->mmio, 19C38 + (this08<<0xd), ctrl); } void CA3dSourceHw::GetA3DControlReg(unsigned long *ctrl) { *ctrl = hwread(vortex->mmio, 19C38 + (this08<<0xd)); } void CA3dSourceHw::SetA3DPointerReg(unsigned long ptr) { hwwrite(vortex->mmio, 19c40 + (this08<<0xd), ctrl); } void CA3dSourceHw::GetA3DPointerReg(unsigned long *ptr) { *ptr = hwread(vortex->mmio, 19C40 + (this08<<0xd)); } void CA3dSourceHw::ZeroSliceIO(void) { int i; for (i=0; i<8; i++) hwwrite(vortex->mmio, 0x19C00 + (((this08<<0xb)+i)*4), 0); for (i=0; i<4; i++) hwwrite(vortex->mmio, 0x19C20 + (((this08<<0xb)+i)*4), 0); } void CA3dSourceHw::ZeroState(void) { int i; CA3dSourceHw::SetAtmosState(0,0,0,0); CA3dSourceHw::SetHrtfState(A3dHrirZeros, A3dHrirZeros); CA3dSourceHw::SetItdDline(A3dItdDlineZeros, A3dItdDlineZeros); CA3dSourceHw::SetHrtfOutput(0, 0); CA3dSourceHw::SetTimeConsts(0,0,0,0); CA3dSourceHw::SetAtmosCurrent(0,0,0,0,0); CA3dSourceHw::SetAtmosTarget(0,0,0,0,0); CA3dSourceHw::SetItdCurrent(0,0); CA3dSourceHw::SetItdTarget(0,0); CA3dSourceHw::SetGainCurrent(0,0); /* The person who originally wrote this surely was smoking crack ... /* (or his/her compiler) */ CA3dIO::WriteReg(190E4 + (this08<<0xd) + (this04*5*9*2 - this04)*8,0,0); CA3dSourceHw::SetHrtfCurrent(A3dHrirZeros, A3dHrirZeros); CA3dSourceHw::SetHrtfTarget(A3dHrirZeros, A3dHrirZeros) } void CA3dSourceHw::ZeroStateA3D(void) { int i, ii, var, var2; CA3dSourceHw::SetA3DControlReg(0); CA3dSourceHw::SetA3DPointerReg(0); var = this08; var2 = this04; // ?? for (ii=0; ii<4; ii++) { this08 = ii; CA3dSourceHw::ZeroSliceIO(void); CA3dSourceHw::ZeroState(void); } this04 = var2; this08 = var; } /* Program A3D block as pass through */ void CA3dSourceHw::ProgramPipe(void) { CA3dSourceHw::SetTimeConsts(0,0,0,0); CA3dSourceHw::SetAtmosCurrent(0, 0x4000, 0,0,0); CA3dSourceHw::SetAtmosTarget(0x4000,0,0,0,0); CA3dSourceHw::SetItdCurrent(0,0); CA3dSourceHw::SetItdTarget(0,0); CA3dSourceHw::SetGainCurrent(0x7fff,0x7fff); CA3dSourceHw::SetGainTarget(0x7fff,0x7fff); CA3dSourceHw::SetHrtfCurrent(A3dHrirImpulse, A3dHrirImpulse); CA3dSourceHw::SetHrtfTarget(A3dHrirImpulse, A3dHrirImpulse); } /* VDB = Vortex audio Dataflow Bus */ void CA3dSourceHw::ClearVDBData(unsigned long a) { hwwrite(vortex->mmio, 0x19c00 + (((a>>2)*255*4)+a)*8, 0); hwwrite(vortex->mmio, 0x19c04 + (((a>>2)*255*4)+a)*8, 0); } /*CA3dIO*/ void CA3dIO::WriteReg(unsigned long addr, short a, short b) { hwwrite(vortex->mmio, addr, (a<<0x10)|b); } /* CHrtf */ void CHrtf::CHrtf(void) { this_00 = 0; this_04 = 0; this_08 = 0; } void CHrtf::Initialize(int arg_0 ,int arg_4 ,short *arg_8) { this_04 = arg_0; this_00 = arg_4; this_08 = *arg_8; } void CHrtf::InterpolateHrtf(short *arg_0, short *arg_4, short *arg_8) { } /* CVort3dRend */ void CVort3DRend::CVort3DRend(class CAsp4Core *core, class CAsp4HwIO *hwio) { this00 = core; this04 = hwio; this08 = 0; } void CVort3DRend::~CVort3DRend(void) { if (this08) operator delete(this08); } int CVort3DRend::Initialize(unsigned short a) { if (this00 == 0) return -1; this14 = a; CXtalkHw = operator new(4); CXtalkHw::CXtalkHw(this04); CXtalkHw::SetGains(XtalkGainsAllChan); if (this14) { if (this08==0xffff) { /* Speaker type 1 ? */ CXtalkHw::ProgramXtalkNarrow(void); } else{ /* Speaker type 2 ? */ CXtalkHw::ProgramXtalkWide(void) } } else { /* Headphones ? */ CXtalkHw::ProgramPipe(void); } CXtalkHw::SetSampleRate(0x11); CXtalkHw::Enable(void); } int CVort3DRend::SetGlobalControl(struct _XTALKctrl *xtctrl) { if (xtctrl==0) return 0; this0c->this04 = xtctrl->this04; this0c->this08 = xtctrl->this08; this0c->this0c = xtctrl->this0c; this0c = xtctrl->this00; CXtalkHw = this08; if (this14) { if (this08==0xffff) CXtalkHw::ProgramXtalkNarrow(void); else CXtalkHw::ProgramXtalkWide(void) } else { CXtalkHw::ProgramPipe(void); } } int CVort3DRend::GetGlobalControl(struct _XTALKctrl *xtctrl) { } int CVort3DRend::AddBuffer(class CVort3dWave *a) { return 0; } int CVort3DRend::RemoveBuffer(class CVort3dWave *a) { return 0; } /* CVort3dWave */ void CVort3dWave::CVort3dWave(class CAsp4Core *,class CAsp4HwIO *,class CHrtfMgr *) { } //174743 void CVort3dWave::Initialize(struct _ASPWAVEFORMAT * arg_0, void (__stdcall *)(class CAuWave *,char *,unsigned long,int,unsigned long,unsigned long),unsigned long arg_4 ,void *arg_c) { a3dsource_t a3d; CWave::Initialize(_ASPWAVEFORMAT *arg_0 ,ASPDIRECTION 0,void (*)(CAuWave *,char *,ulong ,int,ulong,ulong) arg_4,void *arg_c, ulong 1); this_320 = 0; this_324 = 0; this_334 = (short)0xffff; this_338 = (short)0x8000; this_328 = 0; this_77c = 0; this_790 = 0; this_794 = 0; this_7a4 = 0; this_7c8 = 0; /* struct ? */ this_79c = 0; this_7a0 = 0; this_7b4 = 0; this_7c0 = 0; this_7b0 = 0; this_7bc = 0; this_788 = 0; this_7cc = 0; if ((a3d = CAdbTopology::GetA3DSource(void)) < 0) { (CAsp4Core)this_318::GetProperty((COREPROPERTY) 4, void *arg_c, (ulong) 4); if (arg_c == 1) return 8007000E; } else { if (this_340 == 0) { operator new((uint) 0xc, (_POOL_TYPE) 0, (ulong) 44334143); } } } void CVort3DWave::SetLRGains(void) { } int CVort3dWave::Set3dParms(unsigned long offset, unsigned long arg4, void * arg8) { if (offset) return 80070057; if (arg4 == 0xf6) { CVort3dWave::Anzio3dToSuperCtrl((Anzio3d *) arg8, (A3DCTRL_SRC_SUPER *) this_370); CVort3dWave::Set3dParms((A3DCTRL_SRC_SUPER *) this_370); return 0; } if (arg4 == 0x40) { CVort3dWave::Set3dParms((A3DCTRL_SRC_SUPER *) arg8) } } int CVort3dWave::Set3dParms(struct A3DCTRL_SRC_SUPER *) { int var14; struct var0 { int a; short b; char c; }; CAsp4Core = this_318; CAsp4Core::GetProperty((COREPROPERTY) 4, (void *) &var14, (ulong) 4); CAsp4Core::GetProperty((COREPROPERTY) 1, (void *) &var0+0x10, (ulong) 0x10); if ((var0.b != this_354)||(var14 != this_350)) { this_354 = var0.b; this_350 = var14; CHrtfMgr = this_344; if (var14 == 1) { if (var0.b) CHrtfMgr::Initialize((ulong) 0xBB80, (ulong) 0x3a, (ulong) 0x102) else CHrtfMgr::Initialize((ulong) 0xBB80, (ulong) 2, (ulong) 0x101); } else CHrtfMgr::Initialize((ulong) 0xBB80, (ulong) 0x38, (ulong) 0); } if (var14 == 1) { if (var0.b == 0) CVort3dWave::RenderQuadPan((A3DCTRL_SRC_SUPER *) arg0); else CVort3dWave::RenderSuperQuad((A3DCTRL_SRC_SUPER *) arg0); return 0; } eax = CAdbTopology::GetA3DSource(void); if (eax >= 0) CVort3dWave::Render3d((A3DCTRL_SRC_SUPER *) arg0); else CVort3dWave::Render2d((A3DCTRL_SRC_SUPER *) arg0); return 0; } void CVort3dWave::Render2d(struct A3DCTRL_SRC_SUPER *) { CVort3dWave::Calc2d(A3DCTRL_EAR *,A3DCTRL_EAR *,float,ulong *,_ASPVOLUME *); CVort3dWave::SetLRGains(void); CAdbTopology::SetFilter(ulong); } void CVort3dWave::Render3d(struct A3DCTRL_SRC_SUPER *) { CA3dSourceHw::SetAtmosTarget(short,short,short,short,short); CA3dSourceHw::SetAtmosCurrent(short,short,short,short,short); CVort3dWave::SetLRGains(void); CA3dSourceHw::SetHrtfTarget(short const *,short const *); CA3dSourceHw::SetHrtfCurrent(short const *,short const *) CA3dSourceHw::SetItdTarget(short,short); } void CVort3dWave::RenderQuadPan(struct A3DCTRL_SRC_SUPER *) { } void CAdbTopology::SetFilter(unsigned long a) { int eax; if (this_1E0 == 0) return; // "CAdbTopology::SetFilter - m_pWtDma not available\n" if (a) { if (a & 0xFFFF0000) eax = 0xcf; else { a <<= 0x10; eax = 0xc; while (((a & 0x80000000) == 0)&&(eax > 0)) { a <<= 1; eax--; } if (eax) a << 1; eax <<= 4; a >>= 0x1c; eax |= a; } } else eax = 0; this_1E4 = (this_1E4 & 0xFFFFFF) | (eax << 0x18); this_1E8 = this_1E4 | 1; AuWt::WriteReg(0x204 + (this_1DC << 4), this_1E8); AuWt::WriteReg(0x200 + (this_1DC << 4), this_1E4); } void AuWt::WriteReg(unsigned long addr, unsigned long data) { hwwrite(vortex->mmio, (this_04 << 0xf) + addr, data); } int AuWt::ReadReg(unsigned long addr) { return hwread(vortex->mmio, (this_04 << 0xf) + addr); } --- NEW FILE: au88x0_a3d.h --- /*************************************************************************** * au88x0_a3d.h * * Fri Jul 18 14:16:03 2003 * Copyright 2003 mjander * [EMAIL PROTECTED] ****************************************************************************/ typedef struct { ulong this00; // CAsp4hwIO ulong this04; ulong this08; // A3D module Index } CA3dSourceHw_t; short A3dHrirZeros[0x1C] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; short A3dItdDlineZeros[0x16] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; short A3dHrirImpulse[0x1c] = {7FFFh,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; ------------------------------------------------------- This sf.net email is sponsored by:ThinkGeek Welcome to geek heaven. http://thinkgeek.com/sf _______________________________________________ Alsa-cvslog mailing list [EMAIL PROTECTED] https://lists.sourceforge.net/lists/listinfo/alsa-cvslog