Clear Control Register
This commit is contained in:
		| @@ -5,26 +5,26 @@ | |||||||
|  |  | ||||||
| namespace SPU { | namespace SPU { | ||||||
|     namespace Port { |     namespace Port { | ||||||
|         enum struct SweepMode { |         enum struct Mode { | ||||||
|             Linear      = 0, |             Linear      = 0, | ||||||
|             Exponential = 1, |             Exponential = 1, | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         enum struct SweepDirection { |         enum struct Direction { | ||||||
|             Increase = 0, |             Increase = 0, | ||||||
|             Decrease = 1, |             Decrease = 1, | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         enum struct SweepPhase { |         enum struct Phase { | ||||||
|             Posititve = 0, |             Posititve = 0, | ||||||
|             Negative  = 1, |             Negative  = 1, | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         //0..0x1F = Fast..Slow |         //0..0x1F = Fast..Slow | ||||||
|         typedef uint8_t SweepShift; |         typedef uint8_t Shift; | ||||||
|  |  | ||||||
|         //0..3 = +7, +6, +5, +4 or -6, -7, -6, -5 |         //0..3 = +7, +6, +5, +4 or -6, -7, -6, -5 | ||||||
|         typedef uint8_t SweepStep; |         typedef uint8_t Step; | ||||||
|  |  | ||||||
|         struct __no_align SampleRate : public IOPort<uint16_t> { |         struct __no_align SampleRate : public IOPort<uint16_t> { | ||||||
|             __io_port_inherit(SampleRate); |             __io_port_inherit(SampleRate); | ||||||
| @@ -41,32 +41,32 @@ namespace SPU { | |||||||
|             __io_port_inherit(SweepVolume); |             __io_port_inherit(SweepVolume); | ||||||
|  |  | ||||||
|             // For Volume Mode |             // For Volume Mode | ||||||
|             static constexpr Bit<int16_t>      ModeBit     = 15; // 0 Volume Mode; 1 Sweep Mode |             static constexpr Bit<int16_t>      SweepEnable = 15; // 0 Volume Mode; 1 Sweep Mode | ||||||
|             static constexpr BitRange<int16_t> VolumeRange = BitRange<int16_t>::from_to(0, 14); |             static constexpr BitRange<int16_t> Volume      = BitRange<int16_t>::from_to(0, 14); | ||||||
|  |  | ||||||
|             // For Sweep Mode |             // For Sweep Mode | ||||||
|             static constexpr Bit<SweepMode>       SweepModeBit      = 14; |             static constexpr Bit<Mode>       SweepMode      = 14; | ||||||
|             static constexpr Bit<SweepDirection>  SweepDirectionBit = 13; |             static constexpr Bit<Direction>  SweepDirection = 13; | ||||||
|             static constexpr Bit<SweepPhase>      SweepPhaseBit     = 12; |             static constexpr Bit<Phase>      SweepPhase     = 12; | ||||||
|             static constexpr BitRange<SweepShift> SweepShiftRange   = BitRange<SweepShift>::from_to(2, 6); |             static constexpr BitRange<Shift> SweepShift     = BitRange<Shift>::from_to(2, 6); | ||||||
|             static constexpr BitRange<SweepStep>  SweepStepRange    = BitRange<SweepStep>::from_to(0, 1); |             static constexpr BitRange<Step>  SweepStep      = BitRange<Step>::from_to(0, 1); | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         struct __no_align SR : public IOPort<uint16_t> { |         struct __no_align SR : public IOPort<uint16_t> { | ||||||
|             static constexpr Bit<SweepMode>       SustainModeBit      = (31 - 16); |             static constexpr Bit<Mode>       SustainMode      = (31 - 16); | ||||||
|             static constexpr Bit<SweepDirection>  SustainDirectionBit = (30 - 16); |             static constexpr Bit<Direction>  SustainDirection = (30 - 16); | ||||||
|             static constexpr BitRange<SweepShift> SustainShiftRange   = BitRange<SweepShift>::from_to((24 - 16), (28 - 16)); |             static constexpr BitRange<Shift> SustainShift     = BitRange<Shift>::from_to((24 - 16), (28 - 16)); | ||||||
|             static constexpr BitRange<SweepStep>  SustainStepRange    = BitRange<SweepStep>::from_to((22 - 16), (23 - 16)); |             static constexpr BitRange<Step>  SustainStep      = BitRange<Step>::from_to((22 - 16), (23 - 16)); | ||||||
|             static constexpr Bit<SweepMode>       ReleaseModeBit      = (21 - 16); |             static constexpr Bit<Mode>       ReleaseMode      = (21 - 16); | ||||||
|             static constexpr BitRange<SweepShift> ReleaseShiftRange   = BitRange<SweepShift>::from_to((16 - 16), (20 - 16)); |             static constexpr BitRange<Shift> ReleaseShift     = BitRange<Shift>::from_to((16 - 16), (20 - 16)); | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         struct __no_align AD : public IOPort<uint16_t> { |         struct __no_align AD : public IOPort<uint16_t> { | ||||||
|             static constexpr Bit<SweepMode>       AttackModeBit     = 15; |             static constexpr Bit<Mode>          AttackMode   = 15; | ||||||
|             static constexpr BitRange<SweepShift> AttackShiftRange  = BitRange<SweepShift>::from_to(10, 14); |             static constexpr BitRange<Shift>    AttackShift  = BitRange<Shift>::from_to(10, 14); | ||||||
|             static constexpr BitRange<SweepStep>  AttackStepRange   = BitRange<SweepStep>::from_to(8, 9); |             static constexpr BitRange<Step>     AttackStep   = BitRange<Step>::from_to(8, 9); | ||||||
|             static constexpr BitRange<SweepShift> DecayShiftRange   = BitRange<SweepShift>::from_to(4, 7); |             static constexpr BitRange<Shift>    DecayShift   = BitRange<Shift>::from_to(4, 7); | ||||||
|             static constexpr BitRange<uint16_t>   SustainLevelRange = BitRange<uint16_t>::from_to(0, 3); |             static constexpr BitRange<uint16_t> SustainLevel = BitRange<uint16_t>::from_to(0, 3); | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         struct __no_align Voice { |         struct __no_align Voice { | ||||||
| @@ -80,6 +80,29 @@ namespace SPU { | |||||||
|             IOPort<uint16_t>    repeatAdr; |             IOPort<uint16_t>    repeatAdr; | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|  |         struct __no_align ControlRegister : public IOPort<uint16_t> { | ||||||
|  |             __io_port_inherit(ControlRegister); | ||||||
|  |  | ||||||
|  |             enum RAMTransferMode { | ||||||
|  |                 Stop        = 0, | ||||||
|  |                 ManualWrite = 1, | ||||||
|  |                 DMAWrite    = 2, | ||||||
|  |                 DMARead     = 3 | ||||||
|  |             }; | ||||||
|  |  | ||||||
|  |             static constexpr Bit<uint16_t>             Enable              = 15; | ||||||
|  |             static constexpr Bit<uint16_t>             Mute                = 14; | ||||||
|  |             static constexpr BitRange<Shift>           NoiseFrequcenyShift = BitRange<Shift>::from_to(10, 13); | ||||||
|  |             static constexpr BitRange<Step>            NoiseFrequcenyStep  = BitRange<Step>::from_to(8, 9); | ||||||
|  |             static constexpr Bit<uint16_t>             ReverbMasterEnable  = 7; | ||||||
|  |             static constexpr Bit<uint16_t>             IRQ9Enable          = 6; | ||||||
|  |             static constexpr BitRange<RAMTransferMode> TransferMode        = BitRange<RAMTransferMode>::from_to(4, 5); | ||||||
|  |             static constexpr Bit<uint16_t>             ExternalAudioReverb = 3; | ||||||
|  |             static constexpr Bit<uint16_t>             CDAudioReverb       = 2; | ||||||
|  |             static constexpr Bit<uint16_t>             ExternalAudioEnable = 1; | ||||||
|  |             static constexpr Bit<uint16_t>             CDAudioEnable       = 0; | ||||||
|  |         }; | ||||||
|  |  | ||||||
|         namespace Key { |         namespace Key { | ||||||
|             __declare_io_port_global(ubus32_t, on,     0x1F801D88); |             __declare_io_port_global(ubus32_t, on,     0x1F801D88); | ||||||
|             __declare_io_port_global(ubus32_t, off,    0x1F801D8C); |             __declare_io_port_global(ubus32_t, off,    0x1F801D8C); | ||||||
| @@ -90,6 +113,8 @@ namespace SPU { | |||||||
|             __declare_io_port_global(SweepVolume, left,  0x1F801D80); |             __declare_io_port_global(SweepVolume, left,  0x1F801D80); | ||||||
|             __declare_io_port_global(SweepVolume, right, 0x1F801D82); |             __declare_io_port_global(SweepVolume, right, 0x1F801D82); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         __declare_io_port_global(ControlRegister, Control, 0x1F801DAA); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,14 +9,19 @@ namespace SPU { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     static void clear_main_volume() { |     static void clear_main_volume() { | ||||||
|         static constexpr auto StartVol = SweepVolume().clear_bit(SweepVolume::ModeBit).set_value(static_cast<int16_t>(I16_MAX >> 2), SweepVolume::VolumeRange); |         static constexpr auto StartVol = SweepVolume().clear_bit(SweepVolume::SweepEnable).set_value(static_cast<int16_t>(I16_MAX >> 2), SweepVolume::Volume); | ||||||
|  |  | ||||||
|         MainVolume::left.write(StartVol); |         MainVolume::left.write(StartVol); | ||||||
|         MainVolume::right.write(StartVol); |         MainVolume::right.write(StartVol); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     static void clear_control_register() { | ||||||
|  |         Control.write(ControlRegister()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     void setup() { |     void setup() { | ||||||
|         clear_key(); |         clear_key(); | ||||||
|         clear_main_volume(); |         clear_main_volume(); | ||||||
|  |         clear_control_register(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
		Reference in New Issue
	
	Block a user