Skip to content
Snippets Groups Projects
Verified Commit 936d768e authored by João Magalhães's avatar João Magalhães :rocket:
Browse files

Merge branch 'master' into joamag/audio-ch4

parents 400bf7b1 8376919f
No related branches found
No related tags found
1 merge request!21Initial working version of Audio CH4
Pipeline #2401 passed
...@@ -17,7 +17,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ...@@ -17,7 +17,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Fixed ### Fixed
* * Major JoyPad issue with Action/Select read in register
## [0.7.2] - 2023-03-04 ## [0.7.2] - 2023-03-04
......
...@@ -20,12 +20,14 @@ ...@@ -20,12 +20,14 @@
* [GitHub - LIJI32/SameBoy (C)](https://github.com/LIJI32/SameBoy) * [GitHub - LIJI32/SameBoy (C)](https://github.com/LIJI32/SameBoy)
* [GitHub - binji/binjgb (C)](https://github.com/binji/binjgb) * [GitHub - binji/binjgb (C)](https://github.com/binji/binjgb)
* [GitHub - 7thSamurai/Azayaka (C++)](https://github.com/7thSamurai/Azayaka)
* [GitHub - feo-boy/feo-boy (Rust)](https://github.com/feo-boy/feo-boy) * [GitHub - feo-boy/feo-boy (Rust)](https://github.com/feo-boy/feo-boy)
* [GitHub - Rodrigodd/gameroy (Rust)](https://github.com/Rodrigodd/gameroy) * [GitHub - Rodrigodd/gameroy (Rust)](https://github.com/Rodrigodd/gameroy)
* [GitHub - simias/gb-rs (Rust)](https://github.com/simias/gb-rs) * [GitHub - simias/gb-rs (Rust)](https://github.com/simias/gb-rs)
* [GitHub - RubenG123/frosty (Rust)](https://github.com/RubenG123/frosty) * [GitHub - RubenG123/frosty (Rust)](https://github.com/RubenG123/frosty)
* [GitHub - calvinbaart/gameboy (TypeScript)](https://github.com/calvinbaart/gameboy) * [GitHub - calvinbaart/gameboy (TypeScript)](https://github.com/calvinbaart/gameboy)
* [GitHub - djhworld/gomeboycolor-wasm (Go)](https://github.com/djhworld/gomeboycolor-wasm) * [GitHub - djhworld/gomeboycolor-wasm (Go)](https://github.com/djhworld/gomeboycolor-wasm)
* [GitHub - torch2424/wasmboy (WASM)](https://github.com/torch2424/wasmboy)
## Videos ## Videos
......
...@@ -5,6 +5,7 @@ use crate::warnln; ...@@ -5,6 +5,7 @@ use crate::warnln;
#[derive(Clone, Copy, PartialEq, Eq)] #[derive(Clone, Copy, PartialEq, Eq)]
pub enum PadSelection { pub enum PadSelection {
None,
Action, Action,
Direction, Direction,
} }
...@@ -45,7 +46,7 @@ impl Pad { ...@@ -45,7 +46,7 @@ impl Pad {
select: false, select: false,
b: false, b: false,
a: false, a: false,
selection: PadSelection::Action, selection: PadSelection::None,
int_pad: false, int_pad: false,
} }
} }
...@@ -70,15 +71,12 @@ impl Pad { ...@@ -70,15 +71,12 @@ impl Pad {
| if self.up { 0x00 } else { 0x04 } | if self.up { 0x00 } else { 0x04 }
| if self.down { 0x00 } else { 0x08 }) | if self.down { 0x00 } else { 0x08 })
} }
PadSelection::None => 0x0f,
}; };
value |= if self.selection == PadSelection::Direction { value |= match self.selection {
0x10 PadSelection::Action => 0x10,
} else { PadSelection::Direction => 0x20,
0x00 PadSelection::None => 0x30,
} | if self.selection == PadSelection::Action {
0x20
} else {
0x00
}; };
value value
} }
...@@ -92,11 +90,12 @@ impl Pad { ...@@ -92,11 +90,12 @@ impl Pad {
pub fn write(&mut self, addr: u16, value: u8) { pub fn write(&mut self, addr: u16, value: u8) {
match addr & 0x00ff { match addr & 0x00ff {
0x0000 => { 0x0000 => {
self.selection = if value & 0x10 == 0x00 { self.selection = match value & 0x30 {
PadSelection::Direction 0x10 => PadSelection::Action,
} else { 0x20 => PadSelection::Direction,
PadSelection::Action 0x30 => PadSelection::None,
} _ => PadSelection::None,
};
} }
_ => warnln!("Writing to unknown Pad location 0x{:04x}", addr), _ => warnln!("Writing to unknown Pad location 0x{:04x}", addr),
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment