diff options
author | David Li <li.davidm96@gmail.com> | 2015-12-27 10:01:43 -0700 |
---|---|---|
committer | David Li <li.davidm96@gmail.com> | 2015-12-27 10:01:43 -0700 |
commit | 8102cfe7d5cdfd0f2001d257af11686809c22bb9 (patch) | |
tree | 9c4976f9266a14446b4902044057b380f2d604d9 /src/lib.rs | |
parent | 6fbeb4e5ec5f12916853f9a168d6a730992dd63e (diff) |
Fix and test cache address parsing
Diffstat (limited to 'src/lib.rs')
-rw-r--r-- | src/lib.rs | 14 |
1 files changed, 14 insertions, 0 deletions
@@ -15,3 +15,17 @@ fn it_works() { Err(err) => println!("Error: {:?}", err), } } + +#[test] +fn cache_address_parsing() { + let dm_cache_word = memory::Cache::new(4, 1, 1); + let dm_cache_doubleword = memory::Cache::new(4, 1, 2); + let fa_cache_doubleword = memory::Cache::new(1, 4, 2); + + assert_eq!(dm_cache_word.parse_address(0xFFFFFFFD), + (0xFFFFFFF, 3, 1)); + assert_eq!(dm_cache_doubleword.parse_address(0xFFFFFFFD), + (0x7FFFFFF, 3, 5)); + assert_eq!(fa_cache_doubleword.parse_address(0xFFFFFFFD), + (0x1FFFFFFF, 0, 5)); +} |