You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
In an effort to run the Cairo bootloader on top of the Cairo VM, I found out that the instruction cache used in vm_core.rs only considers execution from one segment. This hypothesis is not respected when running the bootloader as we can execute code from different segments.
In this situation, the bootloader and the program(s) it attempts to load pollute each other's instruction cache, which typically ends up with a crash of the VM.
Expected behavior
The cache should either be multi-dimensional or just not get in the way. I see several solutions:
Use a HashMap<Relocatable, Option<Instruction>> instead of the vector used right now.
Use a Vec<Vec<Option<Instruction>>: if solution 1 ends up hitting performance too badly, using a 2-D vector could be a solution.
Limit the use of the cache to segment 0: just add a condition to prevent cache conflicts.
What do you think? There's also the option to introduce a caching policy to keep the current caching solution for most cases and use a more complex one when running the bootloader.
What version/commit are you on?
v0.9.1.
The text was updated successfully, but these errors were encountered:
The cache is already side-stepped in main for non-zero segments. We need to make a new release including support for running programs from other segments.
Describe the bug
In an effort to run the Cairo bootloader on top of the Cairo VM, I found out that the instruction cache used in
vm_core.rs
only considers execution from one segment. This hypothesis is not respected when running the bootloader as we can execute code from different segments.In this situation, the bootloader and the program(s) it attempts to load pollute each other's instruction cache, which typically ends up with a crash of the VM.
Expected behavior
The cache should either be multi-dimensional or just not get in the way. I see several solutions:
HashMap<Relocatable, Option<Instruction>>
instead of the vector used right now.Vec<Vec<Option<Instruction>>
: if solution 1 ends up hitting performance too badly, using a 2-D vector could be a solution.What do you think? There's also the option to introduce a caching policy to keep the current caching solution for most cases and use a more complex one when running the bootloader.
What version/commit are you on?
v0.9.1.
The text was updated successfully, but these errors were encountered: