Mercurial > audlegacy-plugins
diff src/adplug/core/rix.cxx @ 955:4709ce4e209e trunk
[svn] Run indent -ts4 -nut -bli0 -cdw on this messy lot. Upstream is not consistent with whitespace anyway, no loss there.
| author | chainsaw |
|---|---|
| date | Sat, 14 Apr 2007 15:23:50 -0700 |
| parents | ae7e96e44f22 |
| children | be86c72a06c9 |
line wrap: on
line diff
--- a/src/adplug/core/rix.cxx Sat Apr 14 08:48:41 2007 -0700 +++ b/src/adplug/core/rix.cxx Sat Apr 14 15:23:50 2007 -0700 @@ -23,81 +23,108 @@ #include "rix.h" #include "debug.h" -const unsigned char CrixPlayer::adflag[] = {0,0,0,1,1,1,0,0,0,1,1,1,0,0,0,1,1,1}; -const unsigned char CrixPlayer::reg_data[] = {0,1,2,3,4,5,8,9,10,11,12,13,16,17,18,19,20,21}; -const unsigned char CrixPlayer::ad_C0_offs[] = {0,1,2,0,1,2,3,4,5,3,4,5,6,7,8,6,7,8}; -const unsigned char CrixPlayer::modify[] = {0,3,1,4,2,5,6,9,7,10,8,11,12,15,13,16,14,17,12,\ - 15,16,0,14,0,17,0,13,0}; -const unsigned char CrixPlayer::bd_reg_data[] = { - 0x00,0x00,0x00,0x00,0x00,0x00,0x10,0x08,0x04,0x02,0x01, - 0x00,0x01,0x01,0x03,0x0F,0x05,0x00,0x01,0x03,0x0F,0x00, - 0x00,0x00,0x01,0x00,0x00,0x01,0x01,0x0F,0x07,0x00,0x02, - 0x04,0x00,0x00,0x00,0x01,0x00,0x00,0x00,0x00,0x00,0x0A, - 0x04,0x00,0x08,0x0C,0x0B,0x00,0x00,0x00,0x01,0x00,0x00, - 0x00,0x00,0x0D,0x04,0x00,0x06,0x0F,0x00,0x00,0x00,0x00, - 0x01,0x00,0x00,0x0C,0x00,0x0F,0x0B,0x00,0x08,0x05,0x00, - 0x00,0x00,0x00,0x00,0x00,0x00,0x04,0x00,0x0F,0x0B,0x00, - 0x07,0x05,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x00, - 0x0F,0x0B,0x00,0x05,0x05,0x00,0x00,0x00,0x00,0x00,0x00, - 0x00,0x01,0x00,0x0F,0x0B,0x00,0x07,0x05,0x00,0x00,0x00, - 0x00,0x00,0x00}; -unsigned char CrixPlayer::for40reg[] = {0x7F,0x7F,0x7F,0x7F,0x7F,0x7F,0x7F,0x7F,0x7F, - 0x7F,0x7F,0x7F,0x7F,0x7F,0x7F,0x7F,0x7F,0x7F}; -unsigned short CrixPlayer::mus_time = 0x4268; +const unsigned char +CrixPlayer::adflag[] = + { 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 1, 1, 1 }; +const unsigned char +CrixPlayer::reg_data[] = + { 0, 1, 2, 3, 4, 5, 8, 9, 10, 11, 12, 13, 16, 17, 18, 19, 20, 21 }; +const unsigned char +CrixPlayer::ad_C0_offs[] = + { 0, 1, 2, 0, 1, 2, 3, 4, 5, 3, 4, 5, 6, 7, 8, 6, 7, 8 }; +const unsigned char + CrixPlayer::modify[] = + { 0, 3, 1, 4, 2, 5, 6, 9, 7, 10, 8, 11, 12, 15, 13, 16, 14, 17, 12, + 15, 16, 0, 14, 0, 17, 0, 13, 0 +}; +const unsigned char + CrixPlayer::bd_reg_data[] = { + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x08, 0x04, 0x02, 0x01, + 0x00, 0x01, 0x01, 0x03, 0x0F, 0x05, 0x00, 0x01, 0x03, 0x0F, 0x00, + 0x00, 0x00, 0x01, 0x00, 0x00, 0x01, 0x01, 0x0F, 0x07, 0x00, 0x02, + 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0A, + 0x04, 0x00, 0x08, 0x0C, 0x0B, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, + 0x00, 0x00, 0x0D, 0x04, 0x00, 0x06, 0x0F, 0x00, 0x00, 0x00, 0x00, + 0x01, 0x00, 0x00, 0x0C, 0x00, 0x0F, 0x0B, 0x00, 0x08, 0x05, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x04, 0x00, 0x0F, 0x0B, 0x00, + 0x07, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, + 0x0F, 0x0B, 0x00, 0x05, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x01, 0x00, 0x0F, 0x0B, 0x00, 0x07, 0x05, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00 +}; +unsigned char + CrixPlayer::for40reg[] = + { 0x7F, 0x7F, 0x7F, 0x7F, 0x7F, 0x7F, 0x7F, 0x7F, 0x7F, + 0x7F, 0x7F, 0x7F, 0x7F, 0x7F, 0x7F, 0x7F, 0x7F, 0x7F +}; +unsigned short + CrixPlayer::mus_time = 0x4268; /*** public methods *************************************/ -CPlayer *CrixPlayer::factory(Copl *newopl) +CPlayer * +CrixPlayer::factory (Copl * newopl) { - return new CrixPlayer(newopl); + return new CrixPlayer (newopl); } -CrixPlayer::CrixPlayer(Copl *newopl) - : CPlayer(newopl), flag_mkf(0), file_buffer(0), buf_addr(0) +CrixPlayer::CrixPlayer (Copl * newopl):CPlayer (newopl), flag_mkf (0), file_buffer (0), +buf_addr (0) { } -CrixPlayer::~CrixPlayer() +CrixPlayer::~CrixPlayer () { - if(file_buffer) - delete [] file_buffer; + if (file_buffer) + delete[]file_buffer; } -bool CrixPlayer::load(VFSFile *fd, const CFileProvider &fp) +bool +CrixPlayer::load (VFSFile * fd, const CFileProvider & fp) { - binistream *f = fp.open(fd); if(!f) return false; - unsigned long i=0; - std::string filename(fd->uri); + binistream *f = fp.open (fd); + if (!f) + return false; + unsigned long i = 0; + std::string filename (fd->uri); - if(stricmp(filename.substr(filename.length()-4,4).c_str(),".mkf")==0) + if (stricmp (filename.substr (filename.length () - 4, 4).c_str (), ".mkf") + == 0) { - flag_mkf=1; - f->seek(0); - int offset=f->readInt(4); - f->seek(offset); + flag_mkf = 1; + f->seek (0); + int offset = f->readInt (4); + f->seek (offset); + } + if (f->readInt (2) != 0x55aa) + { + fp.close (f); + return false; } - if(f->readInt(2)!=0x55aa){ fp.close(f);return false; } - file_buffer = new unsigned char [fp.filesize(f) + 1]; - f->seek(0); - while(!f->eof()) - file_buffer[i++]=f->readInt(1); - length=i; - fp.close(f); - if(!flag_mkf) - buf_addr=file_buffer; - rewind(0); + file_buffer = new unsigned char[fp.filesize (f) + 1]; + f->seek (0); + while (!f->eof ()) + file_buffer[i++] = f->readInt (1); + length = i; + fp.close (f); + if (!flag_mkf) + buf_addr = file_buffer; + rewind (0); return true; } -bool CrixPlayer::update() +bool +CrixPlayer::update () { - int_08h_entry(); - return !play_end; + int_08h_entry (); + return !play_end; } -void CrixPlayer::rewind(int subsong) +void +CrixPlayer::rewind (int subsong) { - I = 0; T = 0; + I = 0; + T = 0; mus_block = 0; ins_block = 0; rhythm = 0; @@ -109,387 +136,472 @@ bd_modify = 0; sustain = 0; play_end = 0; - pos = index = 0; + pos = index = 0; - memset(f_buffer, 0, sizeof(unsigned short) * 300); - memset(a0b0_data2, 0, sizeof(unsigned short) * 11); - memset(a0b0_data3, 0, 18); - memset(a0b0_data4, 0, 18); - memset(a0b0_data5, 0, 96); - memset(addrs_head, 0, 96); - memset(insbuf, 0, 28 * sizeof(unsigned short)); - memset(displace, 0, 11 * sizeof(unsigned short)); - memset(reg_bufs, 0, 18 * sizeof(ADDT)); + memset (f_buffer, 0, sizeof (unsigned short) * 300); + memset (a0b0_data2, 0, sizeof (unsigned short) * 11); + memset (a0b0_data3, 0, 18); + memset (a0b0_data4, 0, 18); + memset (a0b0_data5, 0, 96); + memset (addrs_head, 0, 96); + memset (insbuf, 0, 28 * sizeof (unsigned short)); + memset (displace, 0, 11 * sizeof (unsigned short)); + memset (reg_bufs, 0, 18 * sizeof (ADDT)); - if(flag_mkf) + if (flag_mkf) { - unsigned int *buf_index=(unsigned int *)file_buffer; - int offset1=buf_index[subsong],offset2; - while((offset2=buf_index[++subsong])==offset1); - length=offset2-offset1+1; - buf_addr=file_buffer+offset1; + unsigned int *buf_index = (unsigned int *) file_buffer; + int offset1 = buf_index[subsong], offset2; + while ((offset2 = buf_index[++subsong]) == offset1); + length = offset2 - offset1 + 1; + buf_addr = file_buffer + offset1; } - opl->init(); - opl->write(1,32); // go to OPL2 mode - set_new_int(); - data_initial(); + opl->init (); + opl->write (1, 32); // go to OPL2 mode + set_new_int (); + data_initial (); } -unsigned int CrixPlayer::getsubsongs() +unsigned int +CrixPlayer::getsubsongs () { - if(flag_mkf) - { - unsigned int *buf_index=(unsigned int *)file_buffer; - int songs=buf_index[0]/4,i=0; - for(i=0;i<songs;i++) - if(buf_index[i+1]==buf_index[i]) - songs--; - return songs; - } - else - return 1; + if (flag_mkf) + { + unsigned int *buf_index = (unsigned int *) file_buffer; + int songs = buf_index[0] / 4, i = 0; + for (i = 0; i < songs; i++) + if (buf_index[i + 1] == buf_index[i]) + songs--; + return songs; + } + else + return 1; } -float CrixPlayer::getrefresh() +float +CrixPlayer::getrefresh () { - return 70.0f; + return 70.0f; } /*------------------Implemention----------------------------*/ -inline void CrixPlayer::set_new_int() +inline void +CrixPlayer::set_new_int () { // if(!ad_initial()) exit(1); - ad_initial(); + ad_initial (); } + /*----------------------------------------------------------*/ -inline void CrixPlayer::Pause() +inline void +CrixPlayer::Pause () { register unsigned short i; pause_flag = 1; - for(i=0;i<11;i++) - switch_ad_bd(i); + for (i = 0; i < 11; i++) + switch_ad_bd (i); } + /*----------------------------------------------------------*/ -inline void CrixPlayer::ad_a0b0l_reg_(unsigned short index,unsigned short p2,unsigned short p3) +inline void +CrixPlayer::ad_a0b0l_reg_ (unsigned short index, unsigned short p2, + unsigned short p3) { // unsigned short i = p2+a0b0_data2[index]; a0b0_data4[index] = p3; a0b0_data3[index] = p2; } -inline void CrixPlayer::data_initial() +inline void +CrixPlayer::data_initial () { rhythm = buf_addr[2]; - mus_block = (buf_addr[0x0D]<<8)+buf_addr[0x0C]; - ins_block = (buf_addr[0x09]<<8)+buf_addr[0x08]; - I = mus_block+1; - if(rhythm != 0) - { - // ad_a0b0_reg(6); - // ad_a0b0_reg(7); - // ad_a0b0_reg(8); - ad_a0b0l_reg_(8,0x18,0); - ad_a0b0l_reg_(7,0x1F,0); - } + mus_block = (buf_addr[0x0D] << 8) + buf_addr[0x0C]; + ins_block = (buf_addr[0x09] << 8) + buf_addr[0x08]; + I = mus_block + 1; + if (rhythm != 0) + { + // ad_a0b0_reg(6); + // ad_a0b0_reg(7); + // ad_a0b0_reg(8); + ad_a0b0l_reg_ (8, 0x18, 0); + ad_a0b0l_reg_ (7, 0x1F, 0); + } bd_modify = 0; - // ad_bd_reg(); - band = 0; music_on = 1; + // ad_bd_reg(); + band = 0; + music_on = 1; } + /*----------------------------------------------------------*/ -inline unsigned short CrixPlayer::ad_initial() +inline unsigned short +CrixPlayer::ad_initial () { - register unsigned short i,j,k = 0; - for(i=0;i<25;i++) + register unsigned short i, j, k = 0; + for (i = 0; i < 25; i++) { - f_buffer[i*12]=(unsigned int)((i*24+10000)*0.27461678223+4)>>3; - for(int t=1;t<12;t++) - f_buffer[i*12+t]=(unsigned int)((double)f_buffer[i*12+t-1]*1.06); + f_buffer[i * 12] = + (unsigned int) ((i * 24 + 10000) * 0.27461678223 + 4) >> 3; + for (int t = 1; t < 12; t++) + f_buffer[i * 12 + t] = + (unsigned int) ((double) f_buffer[i * 12 + t - 1] * 1.06); } - for(i=0;i<8;i++) - for(j=0;j<12;j++) - { - a0b0_data5[k] = i; - addrs_head[k] = j; - k++; - } + for (i = 0; i < 8; i++) + for (j = 0; j < 12; j++) + { + a0b0_data5[k] = i; + addrs_head[k] = j; + k++; + } //ad_bd_reg(); //ad_08_reg(); //for(i=0;i<9;i++) ad_a0b0_reg(i); e0_reg_flag = 0x20; //for(i=0;i<18;i++) ad_bop(0xE0+reg_data[i],0); //ad_bop(1,e0_reg_flag); - return 1;//ad_test(); + return 1; //ad_test(); } + /*----------------------------------------------------------*/ -inline void CrixPlayer::ad_bop(unsigned short reg,unsigned short value) +inline void +CrixPlayer::ad_bop (unsigned short reg, unsigned short value) { - if(reg == 2 || reg == 3) - AdPlug_LogWrite("switch OPL2/3 mode!\n"); - opl->write(reg & 0xff, value & 0xff); + if (reg == 2 || reg == 3) + AdPlug_LogWrite ("switch OPL2/3 mode!\n"); + opl->write (reg & 0xff, value & 0xff); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::int_08h_entry() - { +inline void +CrixPlayer::int_08h_entry () +{ unsigned short band_sus = 1; - while(band_sus) + while (band_sus) + { + if (sustain <= 0) { - if(sustain <= 0) - { - band_sus = rix_proc(); - if(band_sus) sustain += band_sus; - else - { - play_end=1; - break; - } - } + band_sus = rix_proc (); + if (band_sus) + sustain += band_sus; else - { - if(band_sus) sustain -= 14; /* aging */ - break; - } + { + play_end = 1; + break; + } } - } + else + { + if (band_sus) + sustain -= 14; /* aging */ + break; + } + } +} + /*--------------------------------------------------------------*/ -inline unsigned short CrixPlayer::rix_proc() +inline unsigned short +CrixPlayer::rix_proc () { unsigned char ctrl = 0; - if(music_on == 0||pause_flag == 1) return 0; + if (music_on == 0 || pause_flag == 1) + return 0; band = 0; - while(buf_addr[I] != 0x80 && I<length-1) + while (buf_addr[I] != 0x80 && I < length - 1) + { + band_low = buf_addr[I - 1]; + ctrl = buf_addr[I]; + I += 2; + switch (ctrl & 0xF0) { - band_low = buf_addr[I-1]; - ctrl = buf_addr[I]; I+=2; - switch(ctrl&0xF0) - { - case 0x90: rix_get_ins(); rix_90_pro(ctrl&0x0F); break; - case 0xA0: rix_A0_pro(ctrl&0x0F,((unsigned short)band_low)<<6); break; - case 0xB0: rix_B0_pro(ctrl&0x0F,band_low); break; - case 0xC0: switch_ad_bd(ctrl&0x0F); - if(band_low != 0) rix_C0_pro(ctrl&0x0F,band_low); - break; - default: band = (ctrl<<8)+band_low; break; - } - if(band != 0) return band; + case 0x90: + rix_get_ins (); + rix_90_pro (ctrl & 0x0F); + break; + case 0xA0: + rix_A0_pro (ctrl & 0x0F, ((unsigned short) band_low) << 6); + break; + case 0xB0: + rix_B0_pro (ctrl & 0x0F, band_low); + break; + case 0xC0: + switch_ad_bd (ctrl & 0x0F); + if (band_low != 0) + rix_C0_pro (ctrl & 0x0F, band_low); + break; + default: + band = (ctrl << 8) + band_low; + break; } - music_ctrl(); - I = mus_block+1; - band = 0; music_on = 1; + if (band != 0) + return band; + } + music_ctrl (); + I = mus_block + 1; + band = 0; + music_on = 1; return 0; } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::rix_get_ins() +inline void +CrixPlayer::rix_get_ins () { - int i; - unsigned char *baddr = (&buf_addr[ins_block])+(band_low<<6); + int i; + unsigned char *baddr = (&buf_addr[ins_block]) + (band_low << 6); - for(i = 0; i < 28; i++) + for (i = 0; i < 28; i++) insbuf[i] = (baddr[i * 2 + 1] << 8) + baddr[i * 2]; } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::rix_90_pro(unsigned short ctrl_l) +inline void +CrixPlayer::rix_90_pro (unsigned short ctrl_l) +{ + if (rhythm == 0 || ctrl_l < 6) + { + ins_to_reg (modify[ctrl_l * 2], insbuf, insbuf[26]); + ins_to_reg (modify[ctrl_l * 2 + 1], insbuf + 13, insbuf[27]); + return; + } + else if (ctrl_l > 6) + { + ins_to_reg (modify[ctrl_l * 2 + 6], insbuf, insbuf[26]); + return; + } + else + { + ins_to_reg (12, insbuf, insbuf[26]); + ins_to_reg (15, insbuf + 13, insbuf[27]); + return; + } +} + +/*--------------------------------------------------------------*/ +inline void +CrixPlayer::rix_A0_pro (unsigned short ctrl_l, unsigned short index) { - if(rhythm == 0 || ctrl_l < 6) + if (rhythm == 0 || ctrl_l <= 6) + { + prepare_a0b0 (ctrl_l, index > 0x3FFF ? 0x3FFF : index); + ad_a0b0l_reg (ctrl_l, a0b0_data3[ctrl_l], a0b0_data4[ctrl_l]); + } + else + return; +} + +/*--------------------------------------------------------------*/ +inline void +CrixPlayer::prepare_a0b0 (unsigned short index, unsigned short v) /* important ! */ +{ + short high = 0, low = 0; + unsigned int res; + int res1 = (v - 0x2000) * 0x19; + if (res1 == (int) 0xff) + return; + low = res1 / 0x2000; + if (low < 0) + { + low = 0x18 - low; + high = (signed short) low < 0 ? 0xFFFF : 0; + res = high; + res <<= 16; + res += low; + low = ((signed short) res) / (signed short) 0xFFE7; + a0b0_data2[index] = low; + low = res; + res = low - 0x18; + high = (signed short) res % 0x19; + low = (signed short) res / 0x19; + if (high != 0) { - ins_to_reg(modify[ctrl_l*2],insbuf,insbuf[26]); - ins_to_reg(modify[ctrl_l*2+1],insbuf+13,insbuf[27]); - return; - } - else if(ctrl_l > 6) - { - ins_to_reg(modify[ctrl_l*2+6],insbuf,insbuf[26]); - return; - } - else - { - ins_to_reg(12,insbuf,insbuf[26]); - ins_to_reg(15,insbuf+13,insbuf[27]); - return; - } -} -/*--------------------------------------------------------------*/ -inline void CrixPlayer::rix_A0_pro(unsigned short ctrl_l,unsigned short index) -{ - if(rhythm == 0 || ctrl_l <= 6) - { - prepare_a0b0(ctrl_l,index>0x3FFF?0x3FFF:index); - ad_a0b0l_reg(ctrl_l,a0b0_data3[ctrl_l],a0b0_data4[ctrl_l]); + low = 0x19; + low = low - high; } - else return; -} -/*--------------------------------------------------------------*/ -inline void CrixPlayer::prepare_a0b0(unsigned short index,unsigned short v) /* important !*/ -{ - short high = 0,low = 0; unsigned int res; - int res1 = (v-0x2000)*0x19; - if(res1 == (int)0xff) return; - low = res1/0x2000; - if(low < 0) - { - low = 0x18-low; high = (signed short)low<0?0xFFFF:0; - res = high; res<<=16; res+=low; - low = ((signed short)res)/(signed short)0xFFE7; - a0b0_data2[index] = low; - low = res; - res = low - 0x18; - high = (signed short)res%0x19; - low = (signed short)res/0x19; - if(high != 0) {low = 0x19; low = low-high;} - } + } else - { - res = high = low; - low = (signed short)res/(signed short)0x19; - a0b0_data2[index] = low; - res = high; - low = (signed short)res%(signed short)0x19; - } - low = (signed short)low*(signed short)0x18; + { + res = high = low; + low = (signed short) res / (signed short) 0x19; + a0b0_data2[index] = low; + res = high; + low = (signed short) res % (signed short) 0x19; + } + low = (signed short) low *(signed short) 0x18; displace[index] = low; } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::ad_a0b0l_reg(unsigned short index,unsigned short p2,unsigned short p3) +inline void +CrixPlayer::ad_a0b0l_reg (unsigned short index, unsigned short p2, + unsigned short p3) { - unsigned short data; unsigned short i = p2+a0b0_data2[index]; + unsigned short data; + unsigned short i = p2 + a0b0_data2[index]; a0b0_data4[index] = p3; a0b0_data3[index] = p2; - i = ((signed short)i<=0x5F?i:0x5F); - i = ((signed short)i>=0?i:0); - data = f_buffer[addrs_head[i]+displace[index]/2]; - ad_bop(0xA0+index,data); - data = a0b0_data5[i]*4+(p3<1?0:0x20)+((data>>8)&3); - ad_bop(0xB0+index,data); + i = ((signed short) i <= 0x5F ? i : 0x5F); + i = ((signed short) i >= 0 ? i : 0); + data = f_buffer[addrs_head[i] + displace[index] / 2]; + ad_bop (0xA0 + index, data); + data = a0b0_data5[i] * 4 + (p3 < 1 ? 0 : 0x20) + ((data >> 8) & 3); + ad_bop (0xB0 + index, data); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::rix_B0_pro(unsigned short ctrl_l,unsigned short index) +inline void +CrixPlayer::rix_B0_pro (unsigned short ctrl_l, unsigned short index) { register int temp = 0; - if(rhythm == 0 || ctrl_l < 6) temp = modify[ctrl_l*2+1]; + if (rhythm == 0 || ctrl_l < 6) + temp = modify[ctrl_l * 2 + 1]; else - { - temp = ctrl_l > 6?ctrl_l*2:ctrl_l*2+1; - temp = modify[temp+6]; - } - for40reg[temp] = index>0x7F?0x7F:index; - ad_40_reg(temp); + { + temp = ctrl_l > 6 ? ctrl_l * 2 : ctrl_l * 2 + 1; + temp = modify[temp + 6]; + } + for40reg[temp] = index > 0x7F ? 0x7F : index; + ad_40_reg (temp); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::rix_C0_pro(unsigned short ctrl_l,unsigned short index) +inline void +CrixPlayer::rix_C0_pro (unsigned short ctrl_l, unsigned short index) { - register unsigned short i = index>=12?index-12:0; - if(ctrl_l < 6 || rhythm == 0) + register unsigned short i = index >= 12 ? index - 12 : 0; + if (ctrl_l < 6 || rhythm == 0) + { + ad_a0b0l_reg (ctrl_l, i, 1); + return; + } + else + { + if (ctrl_l != 6) { - ad_a0b0l_reg(ctrl_l,i,1); - return; + if (ctrl_l == 8) + { + ad_a0b0l_reg (ctrl_l, i, 0); + ad_a0b0l_reg (7, i + 7, 0); + } } - else - { - if(ctrl_l != 6) - { - if(ctrl_l == 8) - { - ad_a0b0l_reg(ctrl_l,i,0); - ad_a0b0l_reg(7,i+7,0); - } - } - else ad_a0b0l_reg(ctrl_l,i,0); - bd_modify |= bd_reg_data[ctrl_l]; - ad_bd_reg(); - return; - } + else + ad_a0b0l_reg (ctrl_l, i, 0); + bd_modify |= bd_reg_data[ctrl_l]; + ad_bd_reg (); + return; + } } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::switch_ad_bd(unsigned short index) +inline void +CrixPlayer::switch_ad_bd (unsigned short index) { - if(rhythm == 0 || index < 6) ad_a0b0l_reg(index,a0b0_data3[index],0); + if (rhythm == 0 || index < 6) + ad_a0b0l_reg (index, a0b0_data3[index], 0); else - { - bd_modify &= (~bd_reg_data[index]), - ad_bd_reg(); - } + { + bd_modify &= (~bd_reg_data[index]), ad_bd_reg (); + } } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::ins_to_reg(unsigned short index,unsigned short* insb,unsigned short value) +inline void +CrixPlayer::ins_to_reg (unsigned short index, unsigned short *insb, + unsigned short value) { register unsigned short i; - for(i=0;i<13;i++) reg_bufs[index].v[i] = insb[i]; - reg_bufs[index].v[13] = value&3; - ad_bd_reg(),ad_08_reg(), - ad_40_reg(index),ad_C0_reg(index),ad_60_reg(index), - ad_80_reg(index),ad_20_reg(index),ad_E0_reg(index); + for (i = 0; i < 13; i++) + reg_bufs[index].v[i] = insb[i]; + reg_bufs[index].v[13] = value & 3; + ad_bd_reg (), ad_08_reg (), + ad_40_reg (index), ad_C0_reg (index), ad_60_reg (index), + ad_80_reg (index), ad_20_reg (index), ad_E0_reg (index); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::ad_E0_reg(unsigned short index) +inline void +CrixPlayer::ad_E0_reg (unsigned short index) { - unsigned short data = e0_reg_flag == 0?0:(reg_bufs[index].v[13]&3); - ad_bop(0xE0+reg_data[index],data); + unsigned short data = e0_reg_flag == 0 ? 0 : (reg_bufs[index].v[13] & 3); + ad_bop (0xE0 + reg_data[index], data); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::ad_20_reg(unsigned short index) +inline void +CrixPlayer::ad_20_reg (unsigned short index) { - unsigned short data = (reg_bufs[index].v[9] < 1?0:0x80); - data += (reg_bufs[index].v[10] < 1?0:0x40); - data += (reg_bufs[index].v[5] < 1?0:0x20); - data += (reg_bufs[index].v[11] < 1?0:0x10); - data += (reg_bufs[index].v[1]&0x0F); - ad_bop(0x20+reg_data[index],data); + unsigned short data = (reg_bufs[index].v[9] < 1 ? 0 : 0x80); + data += (reg_bufs[index].v[10] < 1 ? 0 : 0x40); + data += (reg_bufs[index].v[5] < 1 ? 0 : 0x20); + data += (reg_bufs[index].v[11] < 1 ? 0 : 0x10); + data += (reg_bufs[index].v[1] & 0x0F); + ad_bop (0x20 + reg_data[index], data); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::ad_80_reg(unsigned short index) +inline void +CrixPlayer::ad_80_reg (unsigned short index) { - unsigned short data = (reg_bufs[index].v[7]&0x0F),temp = reg_bufs[index].v[4]; + unsigned short data = (reg_bufs[index].v[7] & 0x0F), temp = + reg_bufs[index].v[4]; data |= (temp << 4); - ad_bop(0x80+reg_data[index],data); + ad_bop (0x80 + reg_data[index], data); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::ad_60_reg(unsigned short index) +inline void +CrixPlayer::ad_60_reg (unsigned short index) { - unsigned short data = reg_bufs[index].v[6]&0x0F,temp = reg_bufs[index].v[3]; + unsigned short data = reg_bufs[index].v[6] & 0x0F, temp = + reg_bufs[index].v[3]; data |= (temp << 4); - ad_bop(0x60+reg_data[index],data); + ad_bop (0x60 + reg_data[index], data); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::ad_C0_reg(unsigned short index) +inline void +CrixPlayer::ad_C0_reg (unsigned short index) { unsigned short data = reg_bufs[index].v[2]; - if(adflag[index] == 1) return; - data *= 2, - data |= (reg_bufs[index].v[12] < 1?1:0); - ad_bop(0xC0+ad_C0_offs[index],data); + if (adflag[index] == 1) + return; + data *= 2, data |= (reg_bufs[index].v[12] < 1 ? 1 : 0); + ad_bop (0xC0 + ad_C0_offs[index], data); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::ad_40_reg(unsigned short index) +inline void +CrixPlayer::ad_40_reg (unsigned short index) { unsigned int res = 0; - unsigned short data = 0,temp = reg_bufs[index].v[0]; + unsigned short data = 0, temp = reg_bufs[index].v[0]; data = 0x3F - (0x3F & reg_bufs[index].v[8]), - data *= for40reg[index], - data *= 2, - data += 0x7F, - res = data; - data = res/0xFE, - data -= 0x3F, - data = -data, - data |= temp<<6; - ad_bop(0x40+reg_data[index],data); + data *= for40reg[index], data *= 2, data += 0x7F, res = data; + data = res / 0xFE, data -= 0x3F, data = -data, data |= temp << 6; + ad_bop (0x40 + reg_data[index], data); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::ad_bd_reg() +inline void +CrixPlayer::ad_bd_reg () { - unsigned short data = rhythm < 1? 0:0x20; + unsigned short data = rhythm < 1 ? 0 : 0x20; data |= bd_modify; - ad_bop(0xBD,data); + ad_bop (0xBD, data); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::ad_a0b0_reg(unsigned short index) +inline void +CrixPlayer::ad_a0b0_reg (unsigned short index) { - ad_bop(0xA0+index,0); - ad_bop(0xB0+index,0); + ad_bop (0xA0 + index, 0); + ad_bop (0xB0 + index, 0); } + /*--------------------------------------------------------------*/ -inline void CrixPlayer::music_ctrl() +inline void +CrixPlayer::music_ctrl () { register int i; - for(i=0;i<11;i++) - switch_ad_bd(i); + for (i = 0; i < 11; i++) + switch_ad_bd (i); }
