Lines Matching refs:F2608

3295 INLINE void YM2608IRQFlagWrite(FM_OPN *OPN, YM2608 *F2608, int v)  in YM2608IRQFlagWrite()  argument
3303 F2608->flagmask = (~(v&0x1f)); in YM2608IRQFlagWrite()
3304 FM_IRQMASK_SET(&OPN->ST, (F2608->irqmask & F2608->flagmask) ); in YM2608IRQFlagWrite()
3309 INLINE void YM2608IRQMaskWrite(FM_OPN *OPN, YM2608 *F2608, int v) in YM2608IRQMaskWrite() argument
3320 F2608->irqmask = v&0x1f; in YM2608IRQMaskWrite()
3321 FM_IRQMASK_SET(&OPN->ST, (F2608->irqmask & F2608->flagmask) ); in YM2608IRQMaskWrite()
3327 YM2608 *F2608 = (YM2608 *)chip; in ym2608_update_one() local
3328 FM_OPN *OPN = &F2608->OPN; in ym2608_update_one()
3329 YM_DELTAT *DELTAT = &F2608->deltaT; in ym2608_update_one()
3339 cch[0] = &F2608->CH[0]; in ym2608_update_one()
3340 cch[1] = &F2608->CH[1]; in ym2608_update_one()
3341 cch[2] = &F2608->CH[2]; in ym2608_update_one()
3342 cch[3] = &F2608->CH[3]; in ym2608_update_one()
3343 cch[4] = &F2608->CH[4]; in ym2608_update_one()
3344 cch[5] = &F2608->CH[5]; in ym2608_update_one()
3393 if( DELTAT->portstate&0x80 && ! F2608->MuteDeltaT ) in ym2608_update_one()
3399 if( F2608->adpcm[j].flag ) in ym2608_update_one()
3400 ADPCMA_calc_chan( F2608, &F2608->adpcm[j]); in ym2608_update_one()
3487 YM2608 *F2608 = (YM2608 *)chip; in ym2608_postload() local
3491 OPNPrescaler_w(&F2608->OPN,1,2); in ym2608_postload()
3492 F2608->deltaT.freqbase = F2608->OPN.ST.freqbase; in ym2608_postload()
3494 YM2608IRQMaskWrite(&F2608->OPN, F2608, F2608->REGS[0x29]); in ym2608_postload()
3498 (*F2608->OPN.ST.SSG->write)(F2608->OPN.ST.param,0,r); in ym2608_postload()
3499 (*F2608->OPN.ST.SSG->write)(F2608->OPN.ST.param,1,F2608->REGS[r]); in ym2608_postload()
3507 OPNWriteReg(&F2608->OPN,r,F2608->REGS[r]); in ym2608_postload()
3508 OPNWriteReg(&F2608->OPN,r|0x100,F2608->REGS[r|0x100]); in ym2608_postload()
3514 OPNWriteReg(&F2608->OPN,r,F2608->REGS[r]); in ym2608_postload()
3515 OPNWriteReg(&F2608->OPN,r|0x100,F2608->REGS[r|0x100]); in ym2608_postload()
3520 FM_ADPCMAWrite(F2608,1,F2608->REGS[0x111]); in ym2608_postload()
3522 FM_ADPCMAWrite(F2608,r,F2608->REGS[r+0x110]); in ym2608_postload()
3524 YM_DELTAT_postload(&F2608->deltaT , &F2608->REGS[0x100] ); in ym2608_postload()
3528 static void YM2608_save_state(YM2608 *F2608, const device_config *device) in YM2608_save_state() argument
3530 state_save_register_device_item_array(device, 0, F2608->REGS); in YM2608_save_state()
3531 FMsave_state_st(device,&F2608->OPN.ST); in YM2608_save_state()
3532 FMsave_state_channel(device,F2608->CH,6); in YM2608_save_state()
3534 state_save_register_device_item_array(device, 0, F2608->OPN.SL3.fc); in YM2608_save_state()
3535 state_save_register_device_item(device, 0, F2608->OPN.SL3.fn_h); in YM2608_save_state()
3536 state_save_register_device_item_array(device, 0, F2608->OPN.SL3.kcode); in YM2608_save_state()
3538 state_save_register_device_item(device, 0, F2608->addr_A1); in YM2608_save_state()
3540 FMsave_state_adpcma(device,F2608->adpcm); in YM2608_save_state()
3542 YM_DELTAT_savestate(device,&F2608->deltaT); in YM2608_save_state()
3548 YM2608 *F2608 = (YM2608 *)chip; in YM2608_deltat_status_set() local
3549 FM_STATUS_SET(&(F2608->OPN.ST), changebits); in YM2608_deltat_status_set()
3553 YM2608 *F2608 = (YM2608 *)chip; in YM2608_deltat_status_reset() local
3554 FM_STATUS_RESET(&(F2608->OPN.ST), changebits); in YM2608_deltat_status_reset()
3563 YM2608 *F2608; in ym2608_init() local
3566 if( (F2608 = (YM2608 *)malloc(sizeof(YM2608)))==NULL) in ym2608_init()
3569 memset(F2608,0,sizeof(YM2608)); in ym2608_init()
3573 free( F2608 ); in ym2608_init()
3577 F2608->OPN.ST.param = param; in ym2608_init()
3578 F2608->OPN.type = TYPE_YM2608; in ym2608_init()
3579 F2608->OPN.P_CH = F2608->CH; in ym2608_init()
3581 F2608->OPN.ST.clock = clock; in ym2608_init()
3582 F2608->OPN.ST.rate = rate; in ym2608_init()
3585 F2608->OPN.ST.timer_handler = timer_handler; in ym2608_init()
3586 F2608->OPN.ST.IRQ_Handler = IRQHandler; in ym2608_init()
3587 F2608->OPN.ST.SSG = ssg; in ym2608_init()
3592 F2608->deltaT.memory = NULL; in ym2608_init()
3593 F2608->deltaT.memory_size = 0x00; in ym2608_init()
3594 F2608->deltaT.memory_mask = 0x00; in ym2608_init()
3599 F2608->deltaT.status_set_handler = YM2608_deltat_status_set; in ym2608_init()
3600 F2608->deltaT.status_reset_handler = YM2608_deltat_status_reset; in ym2608_init()
3601 F2608->deltaT.status_change_which_chip = F2608; in ym2608_init()
3602 F2608->deltaT.status_change_EOS_bit = 0x04; /* status flag: set bit2 on End Of Sample */ in ym2608_init()
3603 F2608->deltaT.status_change_BRDY_bit = 0x08; /* status flag: set bit3 on BRDY */ in ym2608_init()
3604F2608->deltaT.status_change_ZERO_bit = 0x10; /* status flag: set bit4 if silence continues for mor… in ym2608_init()
3607 F2608->pcmbuf = (UINT8*)YM2608_ADPCM_ROM; in ym2608_init()
3608 F2608->pcm_size = 0x2000; in ym2608_init()
3613 YM2608_save_state(F2608, device); in ym2608_init()
3615 return F2608; in ym2608_init()
3621 YM2608 *F2608 = (YM2608 *)chip; in ym2608_shutdown() local
3623 free(F2608->deltaT.memory); F2608->deltaT.memory = NULL; in ym2608_shutdown()
3626 free(F2608); in ym2608_shutdown()
3633 YM2608 *F2608 = (YM2608 *)chip; in ym2608_reset_chip() local
3634 FM_OPN *OPN = &F2608->OPN; in ym2608_reset_chip()
3635 YM_DELTAT *DELTAT = &F2608->deltaT; in ym2608_reset_chip()
3639 F2608->deltaT.freqbase = OPN->ST.freqbase; in ym2608_reset_chip()
3648 YM2608IRQMaskWrite(OPN, F2608, 0x1f ); /* default value for D4-D0 is 1 */ in ym2608_reset_chip()
3651 …YM2608IRQFlagWrite(OPN, F2608, 0x1c ); /* default: enable timer A and B, disable EOS, BRDY and ZER… in ym2608_reset_chip()
3660 reset_channels( &OPN->ST , F2608->CH , 6 ); in ym2608_reset_chip()
3678F2608->adpcm[i].step = (UINT32)((float)(1<<ADPCM_SHIFT)*((float)F2608->OPN.ST.freqbase)/3.0); in ym2608_reset_chip()
3680F2608->adpcm[i].step = (UINT32)((float)(1<<ADPCM_SHIFT)*((float)F2608->OPN.ST.freqbase)/6.0); in ym2608_reset_chip()
3682 F2608->adpcm[i].start = YM2608_ADPCM_ROM_addr[i*2]; in ym2608_reset_chip()
3683 F2608->adpcm[i].end = YM2608_ADPCM_ROM_addr[i*2+1]; in ym2608_reset_chip()
3685 F2608->adpcm[i].now_addr = 0; in ym2608_reset_chip()
3686 F2608->adpcm[i].now_step = 0; in ym2608_reset_chip()
3688 F2608->adpcm[i].vol_mul = 0; in ym2608_reset_chip()
3689 F2608->adpcm[i].pan = &OPN->out_adpcm[OUTD_CENTER]; /* default center */ in ym2608_reset_chip()
3690 F2608->adpcm[i].flagMask = 0; in ym2608_reset_chip()
3691 F2608->adpcm[i].flag = 0; in ym2608_reset_chip()
3692 F2608->adpcm[i].adpcm_acc = 0; in ym2608_reset_chip()
3693 F2608->adpcm[i].adpcm_step= 0; in ym2608_reset_chip()
3694 F2608->adpcm[i].adpcm_out = 0; in ym2608_reset_chip()
3696 F2608->adpcmTL = 0x3f; in ym2608_reset_chip()
3698 F2608->adpcm_arrivedEndAddress = 0; /* not used */ in ym2608_reset_chip()
3714 YM2608 *F2608 = (YM2608 *)chip; in ym2608_write() local
3715 FM_OPN *OPN = &F2608->OPN; in ym2608_write()
3725 F2608->addr_A1 = 0; in ym2608_write()
3734 F2608->deltaT.freqbase = OPN->ST.freqbase; in ym2608_write()
3739 if (F2608->addr_A1 != 0) in ym2608_write()
3743 F2608->REGS[addr] = v; in ym2608_write()
3752 FM_ADPCMAWrite(F2608,addr-0x10,v); in ym2608_write()
3758 YM2608IRQMaskWrite(OPN, F2608, v); in ym2608_write()
3773 F2608->addr_A1 = 1; in ym2608_write()
3777 if (F2608->addr_A1 != 1) in ym2608_write()
3781 F2608->REGS[addr | 0x100] = v; in ym2608_write()
3795 YM_DELTAT_ADPCM_Write(&F2608->deltaT,addr,v); in ym2608_write()
3801 YM2608IRQFlagWrite(OPN, F2608, v); in ym2608_write()
3813 YM2608 *F2608 = (YM2608 *)chip; in ym2608_read() local
3814 int addr = F2608->OPN.ST.address; in ym2608_read()
3821 ret = FM_STATUS_FLAG(&F2608->OPN.ST) & 0x83; in ym2608_read()
3825 if( addr < 16 ) ret = (*F2608->OPN.ST.SSG->read)(F2608->OPN.ST.param); in ym2608_read()
3831 …ret = (FM_STATUS_FLAG(&F2608->OPN.ST) & (F2608->flagmask|0x80)) | ((F2608->deltaT.PCM_BSY & 1)<<5)… in ym2608_read()
3837 ret = YM_DELTAT_ADPCM_Read(&F2608->deltaT); in ym2608_read()
3856 YM2608 *F2608 = (YM2608 *)chip; in ym2608_timer_over() local
3863 YM_DELTAT_BRDY_callback( &F2608->deltaT ); in ym2608_timer_over()
3869 TimerBOver( &(F2608->OPN.ST) ); in ym2608_timer_over()
3874 ym2608_update_req(F2608->OPN.ST.param); in ym2608_timer_over()
3876 TimerAOver( &(F2608->OPN.ST) ); in ym2608_timer_over()
3878 if( F2608->OPN.ST.mode & 0x80 ) in ym2608_timer_over()
3880 CSMKeyControll( F2608->OPN.type, &(F2608->CH[2]) ); in ym2608_timer_over()
3888 return F2608->OPN.ST.irq; in ym2608_timer_over()
3894 YM2608 *F2608 = (YM2608 *)chip; in ym2608_write_pcmrom() local
3902 if (F2608->deltaT.memory_size != ROMSize) in ym2608_write_pcmrom()
3904 F2608->deltaT.memory = (UINT8*)realloc(F2608->deltaT.memory, ROMSize); in ym2608_write_pcmrom()
3905 F2608->deltaT.memory_size = ROMSize; in ym2608_write_pcmrom()
3906 memset(F2608->deltaT.memory, 0xFF, ROMSize); in ym2608_write_pcmrom()
3907 YM_DELTAT_calc_mem_mask(&F2608->deltaT); in ym2608_write_pcmrom()
3914 memcpy(F2608->deltaT.memory + DataStart, ROMData, DataLength); in ym2608_write_pcmrom()
3923 YM2608 *F2608 = (YM2608 *)chip; in ym2608_set_mutemask() local
3927 F2608->CH[CurChn].Muted = (MuteMask >> CurChn) & 0x01; in ym2608_set_mutemask()
3929 F2608->adpcm[CurChn].Muted = (MuteMask >> (CurChn + 6)) & 0x01; in ym2608_set_mutemask()
3930 F2608->MuteDeltaT = (MuteMask >> 12) & 0x01; in ym2608_set_mutemask()