Indentations break the feed.
[SquirrelJME.git] / assets / developer-notes / stephanie-gawroriski / 2019 / 06 / 25.mkd
blobfaeaa390ffd240d1aaddfb9625ccc0ca580d6490
1 # 2019/06/25
3 ## 12:15
5 Okay so doing a fresh build of SummerCoat works but then if I relaunch it
6 it seems to not want to work and gets stuck scanning classes.
8 ## 12:30
10 Okay, it still continues and parses all the libraries (they are initialized)
11 so I guess there is some kind of slowness? 
13 ## 12:33
15 Oh I see, it is actually compiling a huge chunk of the libraries which is
16 where that pause is coming from. So it might be reading some bad memory?
18 ## 12:36
20 But then it fails in JVM load string with a read way off memory. So this is
21 very likely the crash point. I think I definitely need to make RatufaCoat
22 safer when it comes to memory and having protected regions and such. This
23 way the VM will just stop on invalid accesses instead of just randomly
24 crashing.
26 ## 12:44
28 Definitely need something better. So would say I could do the same thing
29 with virtual memory but making it a thing everywhere. It could possibly
30 even allow things to run on DOS with like swapping and such potentially.
32 ## 13:18
34 I believe I need a more complex error state, since I would like to store
35 an error code and a second value as a kind of meaning.
37 ## 13:52
39 Okay, RatufaCoat could use a bit of a refactor. Everything is in a single
40 source file which was fine at first, but it needs to be a bit cleaner and
41 easier to navigate.
43 ## 14:01
45 Also instead of the manual memory maps, I am going to add a virtual
46 memory manager and such to handle read/writes of all of it.
48 ## 15:55
50 I need an actual atomic compare and set instruction otherwise doing
51 monitors and such will be complicated.
53 ## 16:39
55 Switching all the code to use the virtual memory stuff was complicated,
56 but hopefully I did not mess up anywhere. Will find out if I did.
57 Hopefully it is more stable and does not crash randomly since I do know
58 bad memory is being accessed.