1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */ 2*4882a593Smuzhiyun #ifndef __SOUND_EMU8000_REG_H 3*4882a593Smuzhiyun #define __SOUND_EMU8000_REG_H 4*4882a593Smuzhiyun /* 5*4882a593Smuzhiyun * Register operations for the EMU8000 6*4882a593Smuzhiyun * 7*4882a593Smuzhiyun * Copyright (C) 1999 Steve Ratcliffe 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun * Based on awe_wave.c by Takashi Iwai 10*4882a593Smuzhiyun */ 11*4882a593Smuzhiyun 12*4882a593Smuzhiyun /* 13*4882a593Smuzhiyun * Data port addresses relative to the EMU base. 14*4882a593Smuzhiyun */ 15*4882a593Smuzhiyun #define EMU8000_DATA0(e) ((e)->port1) 16*4882a593Smuzhiyun #define EMU8000_DATA1(e) ((e)->port2) 17*4882a593Smuzhiyun #define EMU8000_DATA2(e) ((e)->port2+2) 18*4882a593Smuzhiyun #define EMU8000_DATA3(e) ((e)->port3) 19*4882a593Smuzhiyun #define EMU8000_PTR(e) ((e)->port3+2) 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun /* 22*4882a593Smuzhiyun * Make a command from a register and channel. 23*4882a593Smuzhiyun */ 24*4882a593Smuzhiyun #define EMU8000_CMD(reg, chan) ((reg)<<5 | (chan)) 25*4882a593Smuzhiyun 26*4882a593Smuzhiyun /* 27*4882a593Smuzhiyun * Commands to read and write the EMU8000 registers. 28*4882a593Smuzhiyun * These macros should be used for all register accesses. 29*4882a593Smuzhiyun */ 30*4882a593Smuzhiyun #define EMU8000_CPF_READ(emu, chan) \ 31*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(0, (chan))) 32*4882a593Smuzhiyun #define EMU8000_PTRX_READ(emu, chan) \ 33*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(1, (chan))) 34*4882a593Smuzhiyun #define EMU8000_CVCF_READ(emu, chan) \ 35*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(2, (chan))) 36*4882a593Smuzhiyun #define EMU8000_VTFT_READ(emu, chan) \ 37*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(3, (chan))) 38*4882a593Smuzhiyun #define EMU8000_PSST_READ(emu, chan) \ 39*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(6, (chan))) 40*4882a593Smuzhiyun #define EMU8000_CSL_READ(emu, chan) \ 41*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(7, (chan))) 42*4882a593Smuzhiyun #define EMU8000_CCCA_READ(emu, chan) \ 43*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(0, (chan))) 44*4882a593Smuzhiyun #define EMU8000_HWCF4_READ(emu) \ 45*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 9)) 46*4882a593Smuzhiyun #define EMU8000_HWCF5_READ(emu) \ 47*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 10)) 48*4882a593Smuzhiyun #define EMU8000_HWCF6_READ(emu) \ 49*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 13)) 50*4882a593Smuzhiyun #define EMU8000_SMALR_READ(emu) \ 51*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 20)) 52*4882a593Smuzhiyun #define EMU8000_SMARR_READ(emu) \ 53*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 21)) 54*4882a593Smuzhiyun #define EMU8000_SMALW_READ(emu) \ 55*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 22)) 56*4882a593Smuzhiyun #define EMU8000_SMARW_READ(emu) \ 57*4882a593Smuzhiyun snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 23)) 58*4882a593Smuzhiyun #define EMU8000_SMLD_READ(emu) \ 59*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 26)) 60*4882a593Smuzhiyun #define EMU8000_SMRD_READ(emu) \ 61*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(1, 26)) 62*4882a593Smuzhiyun #define EMU8000_WC_READ(emu) \ 63*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(1, 27)) 64*4882a593Smuzhiyun #define EMU8000_HWCF1_READ(emu) \ 65*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 29)) 66*4882a593Smuzhiyun #define EMU8000_HWCF2_READ(emu) \ 67*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 30)) 68*4882a593Smuzhiyun #define EMU8000_HWCF3_READ(emu) \ 69*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 31)) 70*4882a593Smuzhiyun #define EMU8000_INIT1_READ(emu, chan) \ 71*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(2, (chan))) 72*4882a593Smuzhiyun #define EMU8000_INIT2_READ(emu, chan) \ 73*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(2, (chan))) 74*4882a593Smuzhiyun #define EMU8000_INIT3_READ(emu, chan) \ 75*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(3, (chan))) 76*4882a593Smuzhiyun #define EMU8000_INIT4_READ(emu, chan) \ 77*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(3, (chan))) 78*4882a593Smuzhiyun #define EMU8000_ENVVOL_READ(emu, chan) \ 79*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(4, (chan))) 80*4882a593Smuzhiyun #define EMU8000_DCYSUSV_READ(emu, chan) \ 81*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(5, (chan))) 82*4882a593Smuzhiyun #define EMU8000_ENVVAL_READ(emu, chan) \ 83*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(6, (chan))) 84*4882a593Smuzhiyun #define EMU8000_DCYSUS_READ(emu, chan) \ 85*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(7, (chan))) 86*4882a593Smuzhiyun #define EMU8000_ATKHLDV_READ(emu, chan) \ 87*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(4, (chan))) 88*4882a593Smuzhiyun #define EMU8000_LFO1VAL_READ(emu, chan) \ 89*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(5, (chan))) 90*4882a593Smuzhiyun #define EMU8000_ATKHLD_READ(emu, chan) \ 91*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(6, (chan))) 92*4882a593Smuzhiyun #define EMU8000_LFO2VAL_READ(emu, chan) \ 93*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(7, (chan))) 94*4882a593Smuzhiyun #define EMU8000_IP_READ(emu, chan) \ 95*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(0, (chan))) 96*4882a593Smuzhiyun #define EMU8000_IFATN_READ(emu, chan) \ 97*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(1, (chan))) 98*4882a593Smuzhiyun #define EMU8000_PEFE_READ(emu, chan) \ 99*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(2, (chan))) 100*4882a593Smuzhiyun #define EMU8000_FMMOD_READ(emu, chan) \ 101*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(3, (chan))) 102*4882a593Smuzhiyun #define EMU8000_TREMFRQ_READ(emu, chan) \ 103*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(4, (chan))) 104*4882a593Smuzhiyun #define EMU8000_FM2FRQ2_READ(emu, chan) \ 105*4882a593Smuzhiyun snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(5, (chan))) 106*4882a593Smuzhiyun 107*4882a593Smuzhiyun 108*4882a593Smuzhiyun #define EMU8000_CPF_WRITE(emu, chan, val) \ 109*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(0, (chan)), (val)) 110*4882a593Smuzhiyun #define EMU8000_PTRX_WRITE(emu, chan, val) \ 111*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(1, (chan)), (val)) 112*4882a593Smuzhiyun #define EMU8000_CVCF_WRITE(emu, chan, val) \ 113*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(2, (chan)), (val)) 114*4882a593Smuzhiyun #define EMU8000_VTFT_WRITE(emu, chan, val) \ 115*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(3, (chan)), (val)) 116*4882a593Smuzhiyun #define EMU8000_PSST_WRITE(emu, chan, val) \ 117*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(6, (chan)), (val)) 118*4882a593Smuzhiyun #define EMU8000_CSL_WRITE(emu, chan, val) \ 119*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(7, (chan)), (val)) 120*4882a593Smuzhiyun #define EMU8000_CCCA_WRITE(emu, chan, val) \ 121*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(0, (chan)), (val)) 122*4882a593Smuzhiyun #define EMU8000_HWCF4_WRITE(emu, val) \ 123*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 9), (val)) 124*4882a593Smuzhiyun #define EMU8000_HWCF5_WRITE(emu, val) \ 125*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 10), (val)) 126*4882a593Smuzhiyun #define EMU8000_HWCF6_WRITE(emu, val) \ 127*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 13), (val)) 128*4882a593Smuzhiyun /* this register is not documented */ 129*4882a593Smuzhiyun #define EMU8000_HWCF7_WRITE(emu, val) \ 130*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 14), (val)) 131*4882a593Smuzhiyun #define EMU8000_SMALR_WRITE(emu, val) \ 132*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 20), (val)) 133*4882a593Smuzhiyun #define EMU8000_SMARR_WRITE(emu, val) \ 134*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 21), (val)) 135*4882a593Smuzhiyun #define EMU8000_SMALW_WRITE(emu, val) \ 136*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 22), (val)) 137*4882a593Smuzhiyun #define EMU8000_SMARW_WRITE(emu, val) \ 138*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 23), (val)) 139*4882a593Smuzhiyun #define EMU8000_SMLD_WRITE(emu, val) \ 140*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 26), (val)) 141*4882a593Smuzhiyun #define EMU8000_SMRD_WRITE(emu, val) \ 142*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(1, 26), (val)) 143*4882a593Smuzhiyun #define EMU8000_WC_WRITE(emu, val) \ 144*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(1, 27), (val)) 145*4882a593Smuzhiyun #define EMU8000_HWCF1_WRITE(emu, val) \ 146*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 29), (val)) 147*4882a593Smuzhiyun #define EMU8000_HWCF2_WRITE(emu, val) \ 148*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 30), (val)) 149*4882a593Smuzhiyun #define EMU8000_HWCF3_WRITE(emu, val) \ 150*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 31), (val)) 151*4882a593Smuzhiyun #define EMU8000_INIT1_WRITE(emu, chan, val) \ 152*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(2, (chan)), (val)) 153*4882a593Smuzhiyun #define EMU8000_INIT2_WRITE(emu, chan, val) \ 154*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(2, (chan)), (val)) 155*4882a593Smuzhiyun #define EMU8000_INIT3_WRITE(emu, chan, val) \ 156*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(3, (chan)), (val)) 157*4882a593Smuzhiyun #define EMU8000_INIT4_WRITE(emu, chan, val) \ 158*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(3, (chan)), (val)) 159*4882a593Smuzhiyun #define EMU8000_ENVVOL_WRITE(emu, chan, val) \ 160*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(4, (chan)), (val)) 161*4882a593Smuzhiyun #define EMU8000_DCYSUSV_WRITE(emu, chan, val) \ 162*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(5, (chan)), (val)) 163*4882a593Smuzhiyun #define EMU8000_ENVVAL_WRITE(emu, chan, val) \ 164*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(6, (chan)), (val)) 165*4882a593Smuzhiyun #define EMU8000_DCYSUS_WRITE(emu, chan, val) \ 166*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(7, (chan)), (val)) 167*4882a593Smuzhiyun #define EMU8000_ATKHLDV_WRITE(emu, chan, val) \ 168*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(4, (chan)), (val)) 169*4882a593Smuzhiyun #define EMU8000_LFO1VAL_WRITE(emu, chan, val) \ 170*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(5, (chan)), (val)) 171*4882a593Smuzhiyun #define EMU8000_ATKHLD_WRITE(emu, chan, val) \ 172*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(6, (chan)), (val)) 173*4882a593Smuzhiyun #define EMU8000_LFO2VAL_WRITE(emu, chan, val) \ 174*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(7, (chan)), (val)) 175*4882a593Smuzhiyun #define EMU8000_IP_WRITE(emu, chan, val) \ 176*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(0, (chan)), (val)) 177*4882a593Smuzhiyun #define EMU8000_IFATN_WRITE(emu, chan, val) \ 178*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(1, (chan)), (val)) 179*4882a593Smuzhiyun #define EMU8000_PEFE_WRITE(emu, chan, val) \ 180*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(2, (chan)), (val)) 181*4882a593Smuzhiyun #define EMU8000_FMMOD_WRITE(emu, chan, val) \ 182*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(3, (chan)), (val)) 183*4882a593Smuzhiyun #define EMU8000_TREMFRQ_WRITE(emu, chan, val) \ 184*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(4, (chan)), (val)) 185*4882a593Smuzhiyun #define EMU8000_FM2FRQ2_WRITE(emu, chan, val) \ 186*4882a593Smuzhiyun snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(5, (chan)), (val)) 187*4882a593Smuzhiyun 188*4882a593Smuzhiyun #define EMU8000_0080_WRITE(emu, chan, val) \ 189*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(4, (chan)), (val)) 190*4882a593Smuzhiyun #define EMU8000_00A0_WRITE(emu, chan, val) \ 191*4882a593Smuzhiyun snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(5, (chan)), (val)) 192*4882a593Smuzhiyun 193*4882a593Smuzhiyun #endif /* __SOUND_EMU8000_REG_H */ 194