gemba 0.1.1 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (285) hide show
  1. checksums.yaml +4 -4
  2. data/THIRD_PARTY_NOTICES +37 -2
  3. data/assets/placeholder_boxart.png +0 -0
  4. data/bin/gemba +2 -2
  5. data/ext/gemba/extconf.rb +23 -1
  6. data/ext/gemba/gemba_ext.c +436 -2
  7. data/ext/gemba/gemba_ext.h +2 -0
  8. data/gemba.gemspec +5 -3
  9. data/lib/gemba/achievements/achievement.rb +23 -0
  10. data/lib/gemba/achievements/backend.rb +186 -0
  11. data/lib/gemba/achievements/cache.rb +70 -0
  12. data/lib/gemba/achievements/credentials_presenter.rb +142 -0
  13. data/lib/gemba/achievements/fake_backend.rb +205 -0
  14. data/lib/gemba/achievements/null_backend.rb +11 -0
  15. data/lib/gemba/achievements/offline_backend.rb +168 -0
  16. data/lib/gemba/achievements/retro_achievements/backend.rb +453 -0
  17. data/lib/gemba/achievements/retro_achievements/cli_sync_requester.rb +64 -0
  18. data/lib/gemba/achievements/retro_achievements/ping_worker.rb +27 -0
  19. data/lib/gemba/achievements.rb +19 -0
  20. data/lib/gemba/achievements_window.rb +556 -0
  21. data/lib/gemba/app_controller.rb +1015 -0
  22. data/lib/gemba/bios.rb +54 -0
  23. data/lib/gemba/boxart_fetcher/libretro_backend.rb +39 -0
  24. data/lib/gemba/boxart_fetcher/null_backend.rb +12 -0
  25. data/lib/gemba/boxart_fetcher.rb +79 -0
  26. data/lib/gemba/bus_emitter.rb +13 -0
  27. data/lib/gemba/child_window.rb +24 -1
  28. data/lib/gemba/cli/commands/config_cmd.rb +83 -0
  29. data/lib/gemba/cli/commands/decode.rb +154 -0
  30. data/lib/gemba/cli/commands/patch.rb +78 -0
  31. data/lib/gemba/cli/commands/play.rb +78 -0
  32. data/lib/gemba/cli/commands/record.rb +114 -0
  33. data/lib/gemba/cli/commands/replay.rb +161 -0
  34. data/lib/gemba/cli/commands/retro_achievements.rb +213 -0
  35. data/lib/gemba/cli/commands/version.rb +22 -0
  36. data/lib/gemba/cli.rb +52 -364
  37. data/lib/gemba/config.rb +134 -1
  38. data/lib/gemba/data/gb_games.json +1 -0
  39. data/lib/gemba/data/gb_md5.json +1 -0
  40. data/lib/gemba/data/gba_games.json +1 -0
  41. data/lib/gemba/data/gba_md5.json +1 -0
  42. data/lib/gemba/data/gbc_games.json +1 -0
  43. data/lib/gemba/data/gbc_md5.json +1 -0
  44. data/lib/gemba/emulator_frame.rb +1060 -0
  45. data/lib/gemba/event_bus.rb +48 -0
  46. data/lib/gemba/frame_stack.rb +60 -0
  47. data/lib/gemba/game_index.rb +84 -0
  48. data/lib/gemba/game_picker_frame.rb +268 -0
  49. data/lib/gemba/gamepad_map.rb +103 -0
  50. data/lib/gemba/headless.rb +6 -5
  51. data/lib/gemba/headless_player.rb +33 -3
  52. data/lib/gemba/help_window.rb +61 -0
  53. data/lib/gemba/hotkey_map.rb +3 -1
  54. data/lib/gemba/input_recorder.rb +107 -0
  55. data/lib/gemba/input_replayer.rb +119 -0
  56. data/lib/gemba/keyboard_map.rb +90 -0
  57. data/lib/gemba/locales/en.yml +97 -5
  58. data/lib/gemba/locales/ja.yml +97 -5
  59. data/lib/gemba/main_window.rb +56 -0
  60. data/lib/gemba/modal_stack.rb +81 -0
  61. data/lib/gemba/patcher_window.rb +223 -0
  62. data/lib/gemba/platform/gb.rb +21 -0
  63. data/lib/gemba/platform/gba.rb +21 -0
  64. data/lib/gemba/platform/gbc.rb +23 -0
  65. data/lib/gemba/platform.rb +20 -0
  66. data/lib/gemba/platform_open.rb +19 -0
  67. data/lib/gemba/recorder.rb +4 -3
  68. data/lib/gemba/replay_player.rb +691 -0
  69. data/lib/gemba/rom_info.rb +57 -0
  70. data/lib/gemba/rom_info_window.rb +16 -3
  71. data/lib/gemba/rom_library.rb +106 -0
  72. data/lib/gemba/rom_overrides.rb +47 -0
  73. data/lib/gemba/rom_patcher/bps.rb +161 -0
  74. data/lib/gemba/rom_patcher/ips.rb +101 -0
  75. data/lib/gemba/rom_patcher/ups.rb +118 -0
  76. data/lib/gemba/rom_patcher.rb +109 -0
  77. data/lib/gemba/{rom_loader.rb → rom_resolver.rb} +7 -6
  78. data/lib/gemba/runtime.rb +59 -26
  79. data/lib/gemba/save_state_manager.rb +4 -7
  80. data/lib/gemba/save_state_picker.rb +17 -4
  81. data/lib/gemba/session_logger.rb +64 -0
  82. data/lib/gemba/settings/audio_tab.rb +77 -0
  83. data/lib/gemba/settings/gamepad_tab.rb +351 -0
  84. data/lib/gemba/settings/hotkeys_tab.rb +259 -0
  85. data/lib/gemba/settings/paths.rb +11 -0
  86. data/lib/gemba/settings/recording_tab.rb +83 -0
  87. data/lib/gemba/settings/save_states_tab.rb +91 -0
  88. data/lib/gemba/settings/system_tab.rb +362 -0
  89. data/lib/gemba/settings/video_tab.rb +318 -0
  90. data/lib/gemba/settings_window.rb +162 -1036
  91. data/lib/gemba/version.rb +1 -1
  92. data/lib/gemba/virtual_keyboard.rb +19 -0
  93. data/lib/gemba.rb +2 -12
  94. data/test/achievements_window/test_bulk_sync.rb +218 -0
  95. data/test/achievements_window/test_bus_events.rb +125 -0
  96. data/test/achievements_window/test_close_confirmation.rb +201 -0
  97. data/test/achievements_window/test_initial_state.rb +164 -0
  98. data/test/achievements_window/test_sorting.rb +227 -0
  99. data/test/achievements_window/test_tree_rendering.rb +133 -0
  100. data/test/fixtures/fake_bios.bin +0 -0
  101. data/test/fixtures/pong.gba +0 -0
  102. data/test/fixtures/test.gb +0 -0
  103. data/test/fixtures/test.gbc +0 -0
  104. data/test/fixtures/test_quicksave.ss +0 -0
  105. data/test/screenshots/no_focus.png +0 -0
  106. data/test/shared/teek_test_worker.rb +17 -1
  107. data/test/shared/tk_test_helper.rb +91 -4
  108. data/test/support/achievements_window_helpers.rb +18 -0
  109. data/test/support/fake_core.rb +25 -0
  110. data/test/support/fake_ra_runtime.rb +74 -0
  111. data/test/support/fake_requester.rb +68 -0
  112. data/test/support/player_helpers.rb +20 -5
  113. data/test/test_achievement.rb +32 -0
  114. data/test/{test_player.rb → test_app_controller.rb} +353 -85
  115. data/test/test_bios.rb +123 -0
  116. data/test/test_boxart_fetcher.rb +150 -0
  117. data/test/test_cli.rb +17 -265
  118. data/test/test_cli_config.rb +64 -0
  119. data/test/test_cli_decode.rb +97 -0
  120. data/test/test_cli_patch.rb +58 -0
  121. data/test/test_cli_play.rb +213 -0
  122. data/test/test_cli_ra.rb +175 -0
  123. data/test/test_cli_record.rb +69 -0
  124. data/test/test_cli_replay.rb +72 -0
  125. data/test/test_cli_sync_requester.rb +152 -0
  126. data/test/test_cli_version.rb +27 -0
  127. data/test/test_config.rb +2 -3
  128. data/test/test_config_ra.rb +69 -0
  129. data/test/test_core.rb +62 -1
  130. data/test/test_credentials_presenter.rb +192 -0
  131. data/test/test_event_bus.rb +100 -0
  132. data/test/test_fake_backend_achievements.rb +130 -0
  133. data/test/test_fake_backend_auth.rb +68 -0
  134. data/test/test_game_index.rb +77 -0
  135. data/test/test_game_picker_frame.rb +310 -0
  136. data/test/test_gamepad_map.rb +1 -3
  137. data/test/test_headless_player.rb +17 -3
  138. data/test/test_help_window.rb +82 -0
  139. data/test/test_hotkey_map.rb +22 -1
  140. data/test/test_input_recorder.rb +179 -0
  141. data/test/test_input_replay_determinism.rb +113 -0
  142. data/test/test_input_replayer.rb +162 -0
  143. data/test/test_keyboard_map.rb +1 -3
  144. data/test/test_libretro_backend.rb +41 -0
  145. data/test/test_locale.rb +1 -1
  146. data/test/test_logging.rb +123 -0
  147. data/test/test_null_backend.rb +42 -0
  148. data/test/test_offline_backend.rb +116 -0
  149. data/test/test_overlay_renderer.rb +1 -1
  150. data/test/test_platform.rb +149 -0
  151. data/test/test_ra_backend.rb +313 -0
  152. data/test/test_ra_backend_unlock_gate.rb +56 -0
  153. data/test/test_recorder.rb +0 -3
  154. data/test/test_replay_player.rb +316 -0
  155. data/test/test_rom_info.rb +149 -0
  156. data/test/test_rom_overrides.rb +86 -0
  157. data/test/test_rom_patcher.rb +382 -0
  158. data/test/{test_rom_loader.rb → test_rom_resolver.rb} +25 -26
  159. data/test/test_save_state_manager.rb +2 -4
  160. data/test/test_settings_audio.rb +107 -0
  161. data/test/test_settings_hotkeys.rb +83 -66
  162. data/test/test_settings_recording.rb +49 -0
  163. data/test/test_settings_save_states.rb +97 -0
  164. data/test/test_settings_system.rb +133 -0
  165. data/test/test_settings_video.rb +450 -0
  166. data/test/test_settings_window.rb +76 -507
  167. data/test/test_tip_service.rb +6 -6
  168. data/test/test_toast_overlay.rb +1 -1
  169. data/test/test_virtual_events.rb +156 -0
  170. data/test/test_virtual_keyboard.rb +1 -1
  171. data/vendor/rcheevos/CHANGELOG.md +495 -0
  172. data/vendor/rcheevos/LICENSE +21 -0
  173. data/vendor/rcheevos/Package.swift +33 -0
  174. data/vendor/rcheevos/README.md +67 -0
  175. data/vendor/rcheevos/include/module.modulemap +70 -0
  176. data/vendor/rcheevos/include/rc_api_editor.h +296 -0
  177. data/vendor/rcheevos/include/rc_api_info.h +280 -0
  178. data/vendor/rcheevos/include/rc_api_request.h +77 -0
  179. data/vendor/rcheevos/include/rc_api_runtime.h +417 -0
  180. data/vendor/rcheevos/include/rc_api_user.h +262 -0
  181. data/vendor/rcheevos/include/rc_client.h +877 -0
  182. data/vendor/rcheevos/include/rc_client_raintegration.h +101 -0
  183. data/vendor/rcheevos/include/rc_consoles.h +138 -0
  184. data/vendor/rcheevos/include/rc_error.h +59 -0
  185. data/vendor/rcheevos/include/rc_export.h +100 -0
  186. data/vendor/rcheevos/include/rc_hash.h +200 -0
  187. data/vendor/rcheevos/include/rc_runtime.h +148 -0
  188. data/vendor/rcheevos/include/rc_runtime_types.h +452 -0
  189. data/vendor/rcheevos/include/rc_util.h +51 -0
  190. data/vendor/rcheevos/include/rcheevos.h +8 -0
  191. data/vendor/rcheevos/src/rapi/rc_api_common.c +1379 -0
  192. data/vendor/rcheevos/src/rapi/rc_api_common.h +88 -0
  193. data/vendor/rcheevos/src/rapi/rc_api_editor.c +625 -0
  194. data/vendor/rcheevos/src/rapi/rc_api_info.c +587 -0
  195. data/vendor/rcheevos/src/rapi/rc_api_runtime.c +901 -0
  196. data/vendor/rcheevos/src/rapi/rc_api_user.c +483 -0
  197. data/vendor/rcheevos/src/rc_client.c +6941 -0
  198. data/vendor/rcheevos/src/rc_client_external.c +281 -0
  199. data/vendor/rcheevos/src/rc_client_external.h +177 -0
  200. data/vendor/rcheevos/src/rc_client_external_versions.h +171 -0
  201. data/vendor/rcheevos/src/rc_client_internal.h +409 -0
  202. data/vendor/rcheevos/src/rc_client_raintegration.c +566 -0
  203. data/vendor/rcheevos/src/rc_client_raintegration_internal.h +61 -0
  204. data/vendor/rcheevos/src/rc_client_types.natvis +396 -0
  205. data/vendor/rcheevos/src/rc_compat.c +251 -0
  206. data/vendor/rcheevos/src/rc_compat.h +121 -0
  207. data/vendor/rcheevos/src/rc_libretro.c +915 -0
  208. data/vendor/rcheevos/src/rc_libretro.h +98 -0
  209. data/vendor/rcheevos/src/rc_util.c +199 -0
  210. data/vendor/rcheevos/src/rc_version.c +11 -0
  211. data/vendor/rcheevos/src/rc_version.h +32 -0
  212. data/vendor/rcheevos/src/rcheevos/alloc.c +312 -0
  213. data/vendor/rcheevos/src/rcheevos/condition.c +754 -0
  214. data/vendor/rcheevos/src/rcheevos/condset.c +777 -0
  215. data/vendor/rcheevos/src/rcheevos/consoleinfo.c +1215 -0
  216. data/vendor/rcheevos/src/rcheevos/format.c +330 -0
  217. data/vendor/rcheevos/src/rcheevos/lboard.c +287 -0
  218. data/vendor/rcheevos/src/rcheevos/memref.c +805 -0
  219. data/vendor/rcheevos/src/rcheevos/operand.c +607 -0
  220. data/vendor/rcheevos/src/rcheevos/rc_internal.h +390 -0
  221. data/vendor/rcheevos/src/rcheevos/rc_runtime_types.natvis +541 -0
  222. data/vendor/rcheevos/src/rcheevos/rc_validate.c +1406 -0
  223. data/vendor/rcheevos/src/rcheevos/rc_validate.h +18 -0
  224. data/vendor/rcheevos/src/rcheevos/richpresence.c +922 -0
  225. data/vendor/rcheevos/src/rcheevos/runtime.c +852 -0
  226. data/vendor/rcheevos/src/rcheevos/runtime_progress.c +1073 -0
  227. data/vendor/rcheevos/src/rcheevos/trigger.c +344 -0
  228. data/vendor/rcheevos/src/rcheevos/value.c +935 -0
  229. data/vendor/rcheevos/src/rhash/aes.c +480 -0
  230. data/vendor/rcheevos/src/rhash/aes.h +49 -0
  231. data/vendor/rcheevos/src/rhash/cdreader.c +838 -0
  232. data/vendor/rcheevos/src/rhash/hash.c +1402 -0
  233. data/vendor/rcheevos/src/rhash/hash_disc.c +1340 -0
  234. data/vendor/rcheevos/src/rhash/hash_encrypted.c +566 -0
  235. data/vendor/rcheevos/src/rhash/hash_rom.c +426 -0
  236. data/vendor/rcheevos/src/rhash/hash_zip.c +460 -0
  237. data/vendor/rcheevos/src/rhash/md5.c +382 -0
  238. data/vendor/rcheevos/src/rhash/md5.h +91 -0
  239. data/vendor/rcheevos/src/rhash/rc_hash_internal.h +116 -0
  240. data/vendor/rcheevos/test/libretro.h +205 -0
  241. data/vendor/rcheevos/test/rapi/test_rc_api_common.c +941 -0
  242. data/vendor/rcheevos/test/rapi/test_rc_api_editor.c +931 -0
  243. data/vendor/rcheevos/test/rapi/test_rc_api_info.c +545 -0
  244. data/vendor/rcheevos/test/rapi/test_rc_api_runtime.c +2213 -0
  245. data/vendor/rcheevos/test/rapi/test_rc_api_user.c +998 -0
  246. data/vendor/rcheevos/test/rcheevos/mock_memory.h +32 -0
  247. data/vendor/rcheevos/test/rcheevos/test_condition.c +570 -0
  248. data/vendor/rcheevos/test/rcheevos/test_condset.c +5170 -0
  249. data/vendor/rcheevos/test/rcheevos/test_consoleinfo.c +203 -0
  250. data/vendor/rcheevos/test/rcheevos/test_format.c +112 -0
  251. data/vendor/rcheevos/test/rcheevos/test_lboard.c +746 -0
  252. data/vendor/rcheevos/test/rcheevos/test_memref.c +520 -0
  253. data/vendor/rcheevos/test/rcheevos/test_operand.c +692 -0
  254. data/vendor/rcheevos/test/rcheevos/test_rc_validate.c +502 -0
  255. data/vendor/rcheevos/test/rcheevos/test_richpresence.c +1564 -0
  256. data/vendor/rcheevos/test/rcheevos/test_runtime.c +1667 -0
  257. data/vendor/rcheevos/test/rcheevos/test_runtime_progress.c +1821 -0
  258. data/vendor/rcheevos/test/rcheevos/test_timing.c +166 -0
  259. data/vendor/rcheevos/test/rcheevos/test_trigger.c +2521 -0
  260. data/vendor/rcheevos/test/rcheevos/test_value.c +870 -0
  261. data/vendor/rcheevos/test/rcheevos-test.sln +46 -0
  262. data/vendor/rcheevos/test/rcheevos-test.vcxproj +239 -0
  263. data/vendor/rcheevos/test/rcheevos-test.vcxproj.filters +335 -0
  264. data/vendor/rcheevos/test/rhash/data.c +657 -0
  265. data/vendor/rcheevos/test/rhash/data.h +32 -0
  266. data/vendor/rcheevos/test/rhash/mock_filereader.c +236 -0
  267. data/vendor/rcheevos/test/rhash/mock_filereader.h +31 -0
  268. data/vendor/rcheevos/test/rhash/test_cdreader.c +920 -0
  269. data/vendor/rcheevos/test/rhash/test_hash.c +310 -0
  270. data/vendor/rcheevos/test/rhash/test_hash_disc.c +1450 -0
  271. data/vendor/rcheevos/test/rhash/test_hash_rom.c +899 -0
  272. data/vendor/rcheevos/test/rhash/test_hash_zip.c +551 -0
  273. data/vendor/rcheevos/test/test.c +113 -0
  274. data/vendor/rcheevos/test/test_framework.h +205 -0
  275. data/vendor/rcheevos/test/test_rc_client.c +10509 -0
  276. data/vendor/rcheevos/test/test_rc_client_external.c +2197 -0
  277. data/vendor/rcheevos/test/test_rc_client_raintegration.c +441 -0
  278. data/vendor/rcheevos/test/test_rc_libretro.c +952 -0
  279. data/vendor/rcheevos/test/test_types.natvis +9 -0
  280. data/vendor/rcheevos/validator/validator.c +658 -0
  281. data/vendor/rcheevos/validator/validator.vcxproj +152 -0
  282. data/vendor/rcheevos/validator/validator.vcxproj.filters +82 -0
  283. metadata +274 -11
  284. data/lib/gemba/input_mappings.rb +0 -214
  285. data/lib/gemba/player.rb +0 -1525
@@ -0,0 +1,520 @@
1
+ #include "rc_internal.h"
2
+
3
+ #include "../test_framework.h"
4
+ #include "mock_memory.h"
5
+
6
+ #include <float.h>
7
+ #include <math.h> /* pow */
8
+
9
+ static void test_mask(char size, uint32_t expected)
10
+ {
11
+ ASSERT_NUM_EQUALS(rc_memref_mask(size), expected);
12
+ }
13
+
14
+ static void test_shared_masks(void)
15
+ {
16
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_8_BITS, 0x000000ff);
17
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_BIT_0, 0x00000001);
18
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_BIT_1, 0x00000002);
19
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_BIT_2, 0x00000004);
20
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_BIT_3, 0x00000008);
21
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_BIT_4, 0x00000010);
22
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_BIT_5, 0x00000020);
23
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_BIT_6, 0x00000040);
24
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_BIT_7, 0x00000080);
25
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_LOW, 0x0000000f);
26
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_HIGH, 0x000000f0);
27
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_BITCOUNT, 0x000000ff);
28
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_16_BITS, 0x0000ffff);
29
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_16_BITS_BE, 0x0000ffff);
30
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_24_BITS, 0x00ffffff);
31
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_24_BITS_BE, 0x00ffffff);
32
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_32_BITS, 0xffffffff);
33
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_32_BITS_BE, 0xffffffff);
34
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_FLOAT, 0xffffffff);
35
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_FLOAT_BE, 0xffffffff);
36
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_DOUBLE32, 0xffffffff);
37
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_DOUBLE32_BE, 0xffffffff);
38
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_MBF32, 0xffffffff);
39
+ TEST_PARAMS2(test_mask, RC_MEMSIZE_VARIABLE, 0xffffffff);
40
+ }
41
+
42
+ static void test_shared_size(char size, char expected)
43
+ {
44
+ ASSERT_NUM_EQUALS(rc_memref_shared_size(size), expected);
45
+ }
46
+
47
+ static void test_shared_sizes(void)
48
+ {
49
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_8_BITS, RC_MEMSIZE_8_BITS);
50
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_BIT_0, RC_MEMSIZE_8_BITS);
51
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_BIT_1, RC_MEMSIZE_8_BITS);
52
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_BIT_2, RC_MEMSIZE_8_BITS);
53
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_BIT_3, RC_MEMSIZE_8_BITS);
54
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_BIT_4, RC_MEMSIZE_8_BITS);
55
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_BIT_5, RC_MEMSIZE_8_BITS);
56
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_BIT_6, RC_MEMSIZE_8_BITS);
57
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_BIT_7, RC_MEMSIZE_8_BITS);
58
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_LOW, RC_MEMSIZE_8_BITS);
59
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_HIGH, RC_MEMSIZE_8_BITS);
60
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_BITCOUNT, RC_MEMSIZE_8_BITS);
61
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_16_BITS, RC_MEMSIZE_16_BITS);
62
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_16_BITS_BE, RC_MEMSIZE_16_BITS);
63
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_24_BITS, RC_MEMSIZE_32_BITS);
64
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_24_BITS_BE, RC_MEMSIZE_32_BITS);
65
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_32_BITS, RC_MEMSIZE_32_BITS);
66
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_32_BITS_BE, RC_MEMSIZE_32_BITS);
67
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_FLOAT, RC_MEMSIZE_32_BITS);
68
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_FLOAT_BE, RC_MEMSIZE_32_BITS);
69
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_DOUBLE32, RC_MEMSIZE_32_BITS);
70
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_DOUBLE32_BE, RC_MEMSIZE_32_BITS);
71
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_MBF32, RC_MEMSIZE_32_BITS);
72
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_MBF32_LE, RC_MEMSIZE_32_BITS);
73
+ TEST_PARAMS2(test_shared_size, RC_MEMSIZE_VARIABLE, RC_MEMSIZE_32_BITS);
74
+ }
75
+
76
+ static void test_transform(uint32_t value, uint8_t size, uint32_t expected)
77
+ {
78
+ rc_typed_value_t typed_value;
79
+ typed_value.type = RC_VALUE_TYPE_UNSIGNED;
80
+ typed_value.value.u32 = value;
81
+ rc_transform_memref_value(&typed_value, size);
82
+ ASSERT_NUM_EQUALS(typed_value.value.u32, expected);
83
+ }
84
+
85
+ static void test_transform_float(uint32_t value, uint8_t size, double expected)
86
+ {
87
+ rc_typed_value_t typed_value;
88
+ typed_value.type = RC_VALUE_TYPE_UNSIGNED;
89
+ typed_value.value.u32 = value;
90
+ rc_transform_memref_value(&typed_value, size);
91
+ ASSERT_FLOAT_EQUALS(typed_value.value.f32, expected);
92
+ }
93
+
94
+ static double rc_round(double n)
95
+ {
96
+ return floor(n + 0.5); /* no round() in c89 */
97
+ }
98
+
99
+ static void test_transform_double32(uint32_t value, uint8_t size, double expected)
100
+ {
101
+ rc_typed_value_t typed_value;
102
+ typed_value.type = RC_VALUE_TYPE_UNSIGNED;
103
+ typed_value.value.u32 = value;
104
+ rc_transform_memref_value(&typed_value, size);
105
+
106
+ /* a 20-bit mantissa only has 6 digits of precision. round to 6 digits, then do a float comparison. */
107
+ if (fabs(expected) != 0.0) {
108
+ const double digits = floor(log10(fabs(expected))) + 1;
109
+ const double expected_pow = pow(10, 6 - digits);
110
+ expected = rc_round(expected * expected_pow) / expected_pow;
111
+ typed_value.value.f32 = (float)(rc_round(typed_value.value.f32 * expected_pow) / expected_pow);
112
+ }
113
+
114
+ ASSERT_FLOAT_EQUALS(typed_value.value.f32, expected);
115
+ }
116
+
117
+ static void test_transform_float_inf(uint32_t value, uint8_t size)
118
+ {
119
+ /* C89 does not provide defines for NAN and INFINITY, nor does it provide isnan() or isinf() functions */
120
+ rc_typed_value_t typed_value;
121
+ typed_value.type = RC_VALUE_TYPE_UNSIGNED;
122
+ typed_value.value.u32 = value;
123
+ rc_transform_memref_value(&typed_value, size);
124
+
125
+ if (typed_value.value.f32 < FLT_MAX) {
126
+ /* infinity will be greater than max float value */
127
+ ASSERT_FAIL("result of transform is not infinity")
128
+ }
129
+ }
130
+
131
+ static void test_transform_float_nan(uint32_t value, uint8_t size)
132
+ {
133
+ /* C89 does not provide defines for NAN and INFINITY, nor does it provide isnan() or isinf() functions */
134
+ rc_typed_value_t typed_value;
135
+ typed_value.type = RC_VALUE_TYPE_UNSIGNED;
136
+ typed_value.value.u32 = value;
137
+ rc_transform_memref_value(&typed_value, size);
138
+
139
+ if (typed_value.value.f32 == typed_value.value.f32) {
140
+ /* NaN cannot be compared, will fail equality check with itself */
141
+ ASSERT_FAIL("result of transform is not NaN")
142
+ }
143
+ }
144
+
145
+ static void test_transforms(void)
146
+ {
147
+ TEST_PARAMS3(test_transform, 0x12345678, RC_MEMSIZE_8_BITS, 0x00000078);
148
+ TEST_PARAMS3(test_transform, 0x12345678, RC_MEMSIZE_16_BITS, 0x00005678);
149
+ TEST_PARAMS3(test_transform, 0x12345678, RC_MEMSIZE_24_BITS, 0x00345678);
150
+ TEST_PARAMS3(test_transform, 0x12345678, RC_MEMSIZE_32_BITS, 0x12345678);
151
+ TEST_PARAMS3(test_transform, 0x12345678, RC_MEMSIZE_LOW, 0x00000008);
152
+ TEST_PARAMS3(test_transform, 0x12345678, RC_MEMSIZE_HIGH, 0x00000007);
153
+ TEST_PARAMS3(test_transform, 0x12345678, RC_MEMSIZE_BITCOUNT, 0x00000004); /* only counts bits in lowest byte */
154
+ TEST_PARAMS3(test_transform, 0x12345678, RC_MEMSIZE_16_BITS_BE, 0x00007856);
155
+ TEST_PARAMS3(test_transform, 0x12345678, RC_MEMSIZE_24_BITS_BE, 0x00785634);
156
+ TEST_PARAMS3(test_transform, 0x12345678, RC_MEMSIZE_32_BITS_BE, 0x78563412);
157
+
158
+ TEST_PARAMS3(test_transform, 0x00000001, RC_MEMSIZE_BIT_0, 0x00000001);
159
+ TEST_PARAMS3(test_transform, 0x00000002, RC_MEMSIZE_BIT_1, 0x00000001);
160
+ TEST_PARAMS3(test_transform, 0x00000004, RC_MEMSIZE_BIT_2, 0x00000001);
161
+ TEST_PARAMS3(test_transform, 0x00000008, RC_MEMSIZE_BIT_3, 0x00000001);
162
+ TEST_PARAMS3(test_transform, 0x00000010, RC_MEMSIZE_BIT_4, 0x00000001);
163
+ TEST_PARAMS3(test_transform, 0x00000020, RC_MEMSIZE_BIT_5, 0x00000001);
164
+ TEST_PARAMS3(test_transform, 0x00000040, RC_MEMSIZE_BIT_6, 0x00000001);
165
+ TEST_PARAMS3(test_transform, 0x00000080, RC_MEMSIZE_BIT_7, 0x00000001);
166
+
167
+ TEST_PARAMS3(test_transform, 0x000000FE, RC_MEMSIZE_BIT_0, 0x00000000);
168
+ TEST_PARAMS3(test_transform, 0x000000FD, RC_MEMSIZE_BIT_1, 0x00000000);
169
+ TEST_PARAMS3(test_transform, 0x000000FB, RC_MEMSIZE_BIT_2, 0x00000000);
170
+ TEST_PARAMS3(test_transform, 0x000000F7, RC_MEMSIZE_BIT_3, 0x00000000);
171
+ TEST_PARAMS3(test_transform, 0x000000EF, RC_MEMSIZE_BIT_4, 0x00000000);
172
+ TEST_PARAMS3(test_transform, 0x000000DF, RC_MEMSIZE_BIT_5, 0x00000000);
173
+ TEST_PARAMS3(test_transform, 0x000000BF, RC_MEMSIZE_BIT_6, 0x00000000);
174
+ TEST_PARAMS3(test_transform, 0x0000007F, RC_MEMSIZE_BIT_7, 0x00000000);
175
+
176
+ TEST_PARAMS3(test_transform_float, 0x3F800000, RC_MEMSIZE_FLOAT, 1.0);
177
+ TEST_PARAMS3(test_transform_float, 0x41460000, RC_MEMSIZE_FLOAT, 12.375);
178
+ TEST_PARAMS3(test_transform_float, 0x42883EFA, RC_MEMSIZE_FLOAT, 68.123);
179
+ TEST_PARAMS3(test_transform_float, 0x00000000, RC_MEMSIZE_FLOAT, 0.0);
180
+ TEST_PARAMS3(test_transform_float, 0x80000000, RC_MEMSIZE_FLOAT, -0.0);
181
+ TEST_PARAMS3(test_transform_float, 0xC0000000, RC_MEMSIZE_FLOAT, -2.0);
182
+ TEST_PARAMS3(test_transform_float, 0x40490FDB, RC_MEMSIZE_FLOAT, 3.14159274101257324);
183
+ TEST_PARAMS3(test_transform_float, 0x3EAAAAAB, RC_MEMSIZE_FLOAT, 0.333333334326744076);
184
+ TEST_PARAMS3(test_transform_float, 0x429A4492, RC_MEMSIZE_FLOAT, 77.133926);
185
+ TEST_PARAMS3(test_transform_float, 0x4350370A, RC_MEMSIZE_FLOAT, 208.214996);
186
+ TEST_PARAMS3(test_transform_float, 0x45AE36E9, RC_MEMSIZE_FLOAT, 5574.863770);
187
+ TEST_PARAMS3(test_transform_float, 0x58635FA9, RC_MEMSIZE_FLOAT, 1000000000000000.0);
188
+ TEST_PARAMS3(test_transform_float, 0x24E69595, RC_MEMSIZE_FLOAT, 0.0000000000000001);
189
+ TEST_PARAMS3(test_transform_float, 0x000042B4, RC_MEMSIZE_FLOAT, 2.39286e-41);
190
+ TEST_PARAMS2(test_transform_float_inf, 0x7F800000, RC_MEMSIZE_FLOAT);
191
+ TEST_PARAMS2(test_transform_float_nan, 0x7FFFFFFF, RC_MEMSIZE_FLOAT);
192
+
193
+ TEST_PARAMS3(test_transform_double32, 0x3FF00000, RC_MEMSIZE_DOUBLE32, 1.0);
194
+ TEST_PARAMS3(test_transform_double32, 0x4028C000, RC_MEMSIZE_DOUBLE32, 12.375);
195
+ TEST_PARAMS3(test_transform_double32, 0x405107DF, RC_MEMSIZE_DOUBLE32, 68.123);
196
+ TEST_PARAMS3(test_transform_double32, 0x00000000, RC_MEMSIZE_DOUBLE32, 0.0);
197
+ TEST_PARAMS3(test_transform_double32, 0x80000000, RC_MEMSIZE_DOUBLE32, -0.0);
198
+ TEST_PARAMS3(test_transform_double32, 0xC0000000, RC_MEMSIZE_DOUBLE32, -2.0);
199
+ TEST_PARAMS3(test_transform_double32, 0x400921FB, RC_MEMSIZE_DOUBLE32, 3.14159274101257324);
200
+ TEST_PARAMS3(test_transform_double32, 0x3FD55555, RC_MEMSIZE_DOUBLE32, 0.333333334326744076);
201
+ TEST_PARAMS3(test_transform_double32, 0x40534892, RC_MEMSIZE_DOUBLE32, 77.133926);
202
+ TEST_PARAMS3(test_transform_double32, 0x406A06E1, RC_MEMSIZE_DOUBLE32, 208.214996);
203
+ TEST_PARAMS3(test_transform_double32, 0x40B5C6DD, RC_MEMSIZE_DOUBLE32, 5574.863770);
204
+ TEST_PARAMS3(test_transform_double32, 0x430C6BF5, RC_MEMSIZE_DOUBLE32, 1000000000000000.0);
205
+ TEST_PARAMS3(test_transform_double32, 0x3C9CD2B2, RC_MEMSIZE_DOUBLE32, 0.0000000000000001);
206
+ TEST_PARAMS3(test_transform_double32, 0x3780AD01, RC_MEMSIZE_DOUBLE32, 2.39286e-41);
207
+ TEST_PARAMS3(test_transform_double32, 0x3FF3C0CA, RC_MEMSIZE_DOUBLE32, 1.234568);
208
+ TEST_PARAMS2(test_transform_float_inf, 0x7FF00000, RC_MEMSIZE_DOUBLE32);
209
+ TEST_PARAMS2(test_transform_float_nan, 0x7FFFFFFF, RC_MEMSIZE_DOUBLE32);
210
+
211
+ TEST_PARAMS3(test_transform_double32, 0x000000C0, RC_MEMSIZE_DOUBLE32_BE, -2.0);
212
+ TEST_PARAMS3(test_transform_double32, 0x00003840, RC_MEMSIZE_DOUBLE32_BE, 24.0);
213
+ TEST_PARAMS3(test_transform_double32, 0xCAC0F33F, RC_MEMSIZE_DOUBLE32_BE, 1.234568);
214
+ TEST_PARAMS3(test_transform_double32, 0xFB210940, RC_MEMSIZE_DOUBLE32_BE, 3.14159274101257324);
215
+
216
+ TEST_PARAMS3(test_transform_float, 0x0000803F, RC_MEMSIZE_FLOAT_BE, 1.0);
217
+ TEST_PARAMS3(test_transform_float, 0x00004641, RC_MEMSIZE_FLOAT_BE, 12.375);
218
+ TEST_PARAMS3(test_transform_float, 0xFA3E8842, RC_MEMSIZE_FLOAT_BE, 68.123);
219
+ TEST_PARAMS3(test_transform_float, 0x00000000, RC_MEMSIZE_FLOAT_BE, 0.0);
220
+ TEST_PARAMS3(test_transform_float, 0x00000080, RC_MEMSIZE_FLOAT_BE, -0.0);
221
+ TEST_PARAMS3(test_transform_float, 0x000000C0, RC_MEMSIZE_FLOAT_BE, -2.0);
222
+ TEST_PARAMS3(test_transform_float, 0xDB0F4940, RC_MEMSIZE_FLOAT_BE, 3.14159274101257324);
223
+ TEST_PARAMS3(test_transform_float, 0xABAAAA3E, RC_MEMSIZE_FLOAT_BE, 0.333333334326744076);
224
+ TEST_PARAMS3(test_transform_float, 0x92449A42, RC_MEMSIZE_FLOAT_BE, 77.133926);
225
+ TEST_PARAMS3(test_transform_float, 0x0A375043, RC_MEMSIZE_FLOAT_BE, 208.214996);
226
+ TEST_PARAMS3(test_transform_float, 0xE936AE45, RC_MEMSIZE_FLOAT_BE, 5574.863770);
227
+ TEST_PARAMS3(test_transform_float, 0xA95F6358, RC_MEMSIZE_FLOAT_BE, 1000000000000000.0);
228
+ TEST_PARAMS3(test_transform_float, 0x9595E624, RC_MEMSIZE_FLOAT_BE, 0.0000000000000001);
229
+ TEST_PARAMS3(test_transform_float, 0xB4420000, RC_MEMSIZE_FLOAT_BE, 2.39286e-41);
230
+ TEST_PARAMS2(test_transform_float_inf, 0x0000807F, RC_MEMSIZE_FLOAT_BE);
231
+ TEST_PARAMS2(test_transform_float_nan, 0xFFFFFF7F, RC_MEMSIZE_FLOAT_BE);
232
+
233
+ /* MBF values are stored big endian (at least on Apple II), so will be byteswapped
234
+ * when passed to rc_transform_memref_value. MBF doesn't support infinity or NaN. */
235
+ TEST_PARAMS3(test_transform_float, 0x00000081, RC_MEMSIZE_MBF32, 1.0); /* 81 00 00 00 */
236
+ TEST_PARAMS3(test_transform_float, 0x00002084, RC_MEMSIZE_MBF32, 10.0); /* 84 20 00 00 */
237
+ TEST_PARAMS3(test_transform_float, 0x00004687, RC_MEMSIZE_MBF32, 99.0); /* 87 46 00 00 */
238
+ TEST_PARAMS3(test_transform_float, 0x00000000, RC_MEMSIZE_MBF32, 0.0); /* 00 00 00 00 */
239
+ TEST_PARAMS3(test_transform_float, 0x00000080, RC_MEMSIZE_MBF32, 0.5); /* 80 00 00 00 */
240
+ TEST_PARAMS3(test_transform_float, 0x00008082, RC_MEMSIZE_MBF32, -2.0); /* 82 80 00 00 */
241
+ TEST_PARAMS3(test_transform_float, 0xF3043581, RC_MEMSIZE_MBF32, 1.41421354); /* 81 34 04 F3 */
242
+ TEST_PARAMS3(test_transform_float, 0xDA0F4982, RC_MEMSIZE_MBF32, 3.14159256); /* 82 49 0F DA */
243
+ TEST_PARAMS3(test_transform_float, 0xDB0F4983, RC_MEMSIZE_MBF32, 6.28318548); /* 83 49 0F DB */
244
+
245
+ /* Some flavors of BASIC (notably Locomotive BASIC on the Amstrad CPC) use the native endian-ness of
246
+ * the system for their MBF values, so we support both MBF32 (big endian) and MBF32_LE (little endian).
247
+ * Also note that Amstrad BASIC and Apple II BASIC both use MBF40, but since MBF40 just adds 8 extra bits
248
+ * of significance as the end of the MBF32 value, we can discard those as we convert to a 32-bit float. */
249
+ TEST_PARAMS3(test_transform_float, 0x81000000, RC_MEMSIZE_MBF32_LE, 1.0); /* 00 00 00 81 */
250
+ TEST_PARAMS3(test_transform_float, 0x84200000, RC_MEMSIZE_MBF32_LE, 10.0); /* 00 00 20 84 */
251
+ TEST_PARAMS3(test_transform_float, 0x87460000, RC_MEMSIZE_MBF32_LE, 99.0); /* 00 00 46 87 */
252
+ TEST_PARAMS3(test_transform_float, 0x00000000, RC_MEMSIZE_MBF32_LE, 0.0); /* 00 00 00 00 */
253
+ TEST_PARAMS3(test_transform_float, 0x80000000, RC_MEMSIZE_MBF32_LE, 0.5); /* 00 00 00 80 */
254
+ TEST_PARAMS3(test_transform_float, 0x82800000, RC_MEMSIZE_MBF32_LE, -2.0); /* 00 00 80 82 */
255
+ TEST_PARAMS3(test_transform_float, 0x813504F3, RC_MEMSIZE_MBF32_LE, 1.41421354); /* F3 04 34 81 */
256
+ TEST_PARAMS3(test_transform_float, 0x82490FDA, RC_MEMSIZE_MBF32_LE, 3.14159256); /* DA 0F 49 82 */
257
+ TEST_PARAMS3(test_transform_float, 0x83490FDB, RC_MEMSIZE_MBF32_LE, 6.28318548); /* DB 0F 49 83 */
258
+ }
259
+
260
+ static int get_memref_count(rc_parse_state_t* parse) {
261
+ return rc_memrefs_count_memrefs(parse->memrefs) + rc_memrefs_count_modified_memrefs(parse->memrefs);
262
+ }
263
+
264
+ static void test_allocate_shared_address() {
265
+ rc_parse_state_t parse;
266
+ rc_memrefs_t memrefs;
267
+ rc_init_parse_state(&parse, NULL);
268
+ rc_init_parse_state_memrefs(&parse, &memrefs);
269
+
270
+ rc_alloc_memref(&parse, 1, RC_MEMSIZE_8_BITS);
271
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 1);
272
+
273
+ rc_alloc_memref(&parse, 1, RC_MEMSIZE_16_BITS); /* differing size will not match */
274
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 2);
275
+
276
+ rc_alloc_memref(&parse, 1, RC_MEMSIZE_LOW); /* differing size will not match */
277
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 3);
278
+
279
+ rc_alloc_memref(&parse, 1, RC_MEMSIZE_BIT_2); /* differing size will not match */
280
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 4);
281
+
282
+ rc_alloc_memref(&parse, 2, RC_MEMSIZE_8_BITS); /* differing address will not match */
283
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 5);
284
+
285
+ rc_alloc_memref(&parse, 1, RC_MEMSIZE_8_BITS); /* match */
286
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 5);
287
+
288
+ rc_alloc_memref(&parse, 1, RC_MEMSIZE_16_BITS); /* match */
289
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 5);
290
+
291
+ rc_alloc_memref(&parse, 1, RC_MEMSIZE_BIT_2); /* match */
292
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 5);
293
+
294
+ rc_alloc_memref(&parse, 2, RC_MEMSIZE_8_BITS); /* match */
295
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 5);
296
+
297
+ rc_destroy_parse_state(&parse);
298
+ }
299
+
300
+ static void test_allocate_shared_address2() {
301
+ rc_parse_state_t parse;
302
+ rc_memrefs_t memrefs;
303
+ rc_memref_t* memref1;
304
+ rc_memref_t* memref2;
305
+ rc_memref_t* memref3;
306
+ rc_memref_t* memref4;
307
+ rc_memref_t* memref5;
308
+ rc_memref_t* memrefX;
309
+ rc_init_parse_state(&parse, NULL);
310
+ rc_init_parse_state_memrefs(&parse, &memrefs);
311
+
312
+ memref1 = rc_alloc_memref(&parse, 1, RC_MEMSIZE_8_BITS);
313
+ ASSERT_NUM_EQUALS(memref1->address, 1);
314
+ ASSERT_NUM_EQUALS(memref1->value.size, RC_MEMSIZE_8_BITS);
315
+ ASSERT_NUM_EQUALS(memref1->value.memref_type, RC_MEMREF_TYPE_MEMREF);
316
+ ASSERT_NUM_EQUALS(memref1->value.type, RC_VALUE_TYPE_UNSIGNED);
317
+ ASSERT_NUM_EQUALS(memref1->value.value, 0);
318
+ ASSERT_NUM_EQUALS(memref1->value.changed, 0);
319
+ ASSERT_NUM_EQUALS(memref1->value.prior, 0);
320
+
321
+ memref2 = rc_alloc_memref(&parse, 1, RC_MEMSIZE_16_BITS); /* differing size will not match */
322
+ memref3 = rc_alloc_memref(&parse, 1, RC_MEMSIZE_LOW); /* differing size will not match */
323
+ memref4 = rc_alloc_memref(&parse, 1, RC_MEMSIZE_BIT_2); /* differing size will not match */
324
+ memref5 = rc_alloc_memref(&parse, 2, RC_MEMSIZE_8_BITS); /* differing address will not match */
325
+
326
+ memrefX = rc_alloc_memref(&parse, 1, RC_MEMSIZE_8_BITS); /* match */
327
+ ASSERT_PTR_EQUALS(memrefX, memref1);
328
+
329
+ memrefX = rc_alloc_memref(&parse, 1, RC_MEMSIZE_16_BITS); /* match */
330
+ ASSERT_PTR_EQUALS(memrefX, memref2);
331
+
332
+ memrefX = rc_alloc_memref(&parse, 1, RC_MEMSIZE_LOW); /* match */
333
+ ASSERT_PTR_EQUALS(memrefX, memref3);
334
+
335
+ memrefX = rc_alloc_memref(&parse, 1, RC_MEMSIZE_BIT_2); /* match */
336
+ ASSERT_PTR_EQUALS(memrefX, memref4);
337
+
338
+ memrefX = rc_alloc_memref(&parse, 2, RC_MEMSIZE_8_BITS); /* match */
339
+ ASSERT_PTR_EQUALS(memrefX, memref5);
340
+
341
+ rc_destroy_parse_state(&parse);
342
+ }
343
+
344
+ static void test_allocate_shared_indirect_address() {
345
+ rc_parse_state_t parse;
346
+ rc_memrefs_t memrefs;
347
+ rc_memref_t* parent_memref1, *parent_memref2;
348
+ rc_operand_t parent1, parent2, delta1, intermediate2;
349
+ rc_modified_memref_t* child1, *child2, *child3, *child4;
350
+ rc_operand_t offset0, offset4;
351
+ rc_operand_set_const(&offset0, 0);
352
+ rc_operand_set_const(&offset4, 4);
353
+
354
+ rc_init_parse_state(&parse, NULL);
355
+ rc_init_parse_state_memrefs(&parse, &memrefs);
356
+
357
+ parent1.value.memref = parent_memref1 = rc_alloc_memref(&parse, 88, RC_MEMSIZE_16_BITS);
358
+ parent1.type = RC_OPERAND_ADDRESS;
359
+ parent1.size = RC_MEMSIZE_16_BITS;
360
+ parent2.value.memref = parent_memref2 = rc_alloc_memref(&parse, 99, RC_MEMSIZE_16_BITS);
361
+ parent2.type = RC_OPERAND_ADDRESS;
362
+ parent2.size = RC_MEMSIZE_16_BITS;
363
+ delta1.value.memref = parent_memref1;
364
+ delta1.type = RC_OPERAND_DELTA;
365
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 2);
366
+
367
+ child1 = rc_alloc_modified_memref(&parse, RC_MEMSIZE_8_BITS, &parent1, RC_OPERATOR_INDIRECT_READ, &offset0);
368
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 3);
369
+
370
+ /* differing size will not match */
371
+ child2 = rc_alloc_modified_memref(&parse, RC_MEMSIZE_16_BITS, &parent1, RC_OPERATOR_INDIRECT_READ, &offset0);
372
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 4);
373
+
374
+ /* differing parent will not match */
375
+ child3 = rc_alloc_modified_memref(&parse, RC_MEMSIZE_8_BITS, &parent2, RC_OPERATOR_INDIRECT_READ, &offset0);
376
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 5);
377
+
378
+ /* differing parent type will not match */
379
+ child4 = rc_alloc_modified_memref(&parse, RC_MEMSIZE_8_BITS, &delta1, RC_OPERATOR_INDIRECT_READ, &offset0);
380
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 6);
381
+
382
+ /* differing offset will not match */
383
+ child4 = rc_alloc_modified_memref(&parse, RC_MEMSIZE_8_BITS, &parent1, RC_OPERATOR_INDIRECT_READ, &offset4);
384
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 7);
385
+
386
+ /* exact match to first */
387
+ ASSERT_PTR_EQUALS(rc_alloc_modified_memref(&parse, RC_MEMSIZE_8_BITS, &parent1, RC_OPERATOR_INDIRECT_READ, &offset0), child1);
388
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 7);
389
+
390
+ /* exact match to differing parent */
391
+ ASSERT_PTR_EQUALS(rc_alloc_modified_memref(&parse, RC_MEMSIZE_8_BITS, &parent2, RC_OPERATOR_INDIRECT_READ, &offset0), child3);
392
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 7);
393
+
394
+ /* exact match to differing offset */
395
+ ASSERT_PTR_EQUALS(rc_alloc_modified_memref(&parse, RC_MEMSIZE_8_BITS, &parent1, RC_OPERATOR_INDIRECT_READ, &offset4), child4);
396
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 7);
397
+
398
+ /* intermediate parent */
399
+ intermediate2.value.memref = &child2->memref;
400
+ intermediate2.type = RC_OPERAND_ADDRESS;
401
+ intermediate2.size = RC_MEMSIZE_32_BITS;
402
+ intermediate2.memref_access_type = RC_OPERAND_ADDRESS;
403
+ child4 = rc_alloc_modified_memref(&parse, RC_MEMSIZE_8_BITS, &intermediate2, RC_OPERATOR_INDIRECT_READ, &offset0);
404
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 8);
405
+
406
+ ASSERT_PTR_EQUALS(rc_alloc_modified_memref(&parse, RC_MEMSIZE_8_BITS, &intermediate2, RC_OPERATOR_INDIRECT_READ, &offset0), child4);
407
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 8);
408
+
409
+ rc_destroy_parse_state(&parse);
410
+ }
411
+
412
+ static void test_sizing_mode_grow_buffer() {
413
+ int i;
414
+ rc_parse_state_t parse;
415
+ rc_memrefs_t memrefs;
416
+ rc_init_parse_state(&parse, NULL);
417
+ rc_init_parse_state_memrefs(&parse, &memrefs);
418
+
419
+ /* memrefs are allocated 16 at a time */
420
+ for (i = 0; i < 100; i++) {
421
+ rc_alloc_memref(&parse, i, RC_MEMSIZE_8_BITS);
422
+ }
423
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 100);
424
+
425
+ /* 100 have been allocated, make sure we can still access items at various addresses without allocating more */
426
+ rc_alloc_memref(&parse, 1, RC_MEMSIZE_8_BITS);
427
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 100);
428
+
429
+ rc_alloc_memref(&parse, 25, RC_MEMSIZE_8_BITS);
430
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 100);
431
+
432
+ rc_alloc_memref(&parse, 50, RC_MEMSIZE_8_BITS);
433
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 100);
434
+
435
+ rc_alloc_memref(&parse, 75, RC_MEMSIZE_8_BITS);
436
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 100);
437
+
438
+ rc_alloc_memref(&parse, 99, RC_MEMSIZE_8_BITS);
439
+ ASSERT_NUM_EQUALS(get_memref_count(&parse), 100);
440
+
441
+ rc_destroy_parse_state(&parse);
442
+ }
443
+
444
+ static void test_update_memref_values() {
445
+ rc_parse_state_t parse;
446
+ rc_memrefs_t memrefs;
447
+ rc_memref_t* memref1;
448
+ rc_memref_t* memref2;
449
+
450
+ uint8_t ram[] = { 0x00, 0x12, 0x34, 0xAB, 0x56 };
451
+ memory_t memory;
452
+ memory.ram = ram;
453
+ memory.size = sizeof(ram);
454
+
455
+ rc_init_parse_state(&parse, NULL);
456
+ rc_init_parse_state_memrefs(&parse, &memrefs);
457
+
458
+ memref1 = rc_alloc_memref(&parse, 1, RC_MEMSIZE_8_BITS);
459
+ memref2 = rc_alloc_memref(&parse, 2, RC_MEMSIZE_8_BITS);
460
+
461
+ rc_update_memref_values(&memrefs, peek, &memory);
462
+
463
+ ASSERT_NUM_EQUALS(memref1->value.value, 0x12);
464
+ ASSERT_NUM_EQUALS(memref1->value.changed, 1);
465
+ ASSERT_NUM_EQUALS(memref1->value.prior, 0);
466
+ ASSERT_NUM_EQUALS(memref2->value.value, 0x34);
467
+ ASSERT_NUM_EQUALS(memref2->value.changed, 1);
468
+ ASSERT_NUM_EQUALS(memref2->value.prior, 0);
469
+
470
+ ram[1] = 3;
471
+ rc_update_memref_values(&memrefs, peek, &memory);
472
+
473
+ ASSERT_NUM_EQUALS(memref1->value.value, 3);
474
+ ASSERT_NUM_EQUALS(memref1->value.changed, 1);
475
+ ASSERT_NUM_EQUALS(memref1->value.prior, 0x12);
476
+ ASSERT_NUM_EQUALS(memref2->value.value, 0x34);
477
+ ASSERT_NUM_EQUALS(memref2->value.changed, 0);
478
+ ASSERT_NUM_EQUALS(memref2->value.prior, 0);
479
+
480
+ ram[1] = 5;
481
+ rc_update_memref_values(&memrefs, peek, &memory);
482
+
483
+ ASSERT_NUM_EQUALS(memref1->value.value, 5);
484
+ ASSERT_NUM_EQUALS(memref1->value.changed, 1);
485
+ ASSERT_NUM_EQUALS(memref1->value.prior, 3);
486
+ ASSERT_NUM_EQUALS(memref2->value.value, 0x34);
487
+ ASSERT_NUM_EQUALS(memref2->value.changed, 0);
488
+ ASSERT_NUM_EQUALS(memref2->value.prior, 0);
489
+
490
+ ram[2] = 7;
491
+ rc_update_memref_values(&memrefs, peek, &memory);
492
+
493
+ ASSERT_NUM_EQUALS(memref1->value.value, 5);
494
+ ASSERT_NUM_EQUALS(memref1->value.changed, 0);
495
+ ASSERT_NUM_EQUALS(memref1->value.prior, 3);
496
+ ASSERT_NUM_EQUALS(memref2->value.value, 7);
497
+ ASSERT_NUM_EQUALS(memref2->value.changed, 1);
498
+ ASSERT_NUM_EQUALS(memref2->value.prior, 0x34);
499
+
500
+ rc_destroy_parse_state(&parse);
501
+ }
502
+
503
+ void test_memref(void) {
504
+ TEST_SUITE_BEGIN();
505
+
506
+ test_shared_masks();
507
+ test_shared_sizes();
508
+ test_transforms();
509
+
510
+ TEST(test_allocate_shared_address);
511
+ TEST(test_allocate_shared_address2);
512
+ TEST(test_allocate_shared_indirect_address);
513
+
514
+ TEST(test_sizing_mode_grow_buffer);
515
+ TEST(test_update_memref_values);
516
+
517
+ /* rc_parse_memref is thoroughly tested by rc_parse_operand tests */
518
+
519
+ TEST_SUITE_END();
520
+ }