[Vm-dev] VM Maker: Cog-eem.376.mcz
commits at source.squeak.org
commits at source.squeak.org
Sun Dec 15 20:23:02 UTC 2019
Eliot Miranda uploaded a new version of Cog to project VM Maker:
http://source.squeak.org/VMMaker/Cog-eem.376.mcz
==================== Summary ====================
Name: Cog-eem.376
Author: eem
Time: 15 December 2019, 12:23:00.268258 pm
UUID: 330b467e-b08a-42c1-a2f8-1097f3598342
Ancestors: Cog-eem.375
We don't need no steenkin' execution simulation category...
=============== Diff against Cog-eem.375 ===============
Item was changed:
+ ----- Method: GdbARMAlien>>simulateCallOf:nextpc:memory: (in category 'execution') -----
- ----- Method: GdbARMAlien>>simulateCallOf:nextpc:memory: (in category 'execution simulation') -----
simulateCallOf: address nextpc: nextpc memory: aMemory
"Simulate a frame-building call of address. Build a frame since
a) this is used for calls into the run-time which are unlikely to be leaf-calls"
"This method builds a stack frame as expected by the simulator, not as defined by ARM aapcs-abi.
In ARM aapcs, every method can define for itself, wether it wants to push lr (nextpc), and wether it
uses a frame pointer. The standard never mentions a fp. It merely defines r4-r11 to be callee-saved."
self pushWord: self lr in: aMemory.
self pushWord: self fp in: aMemory.
self fp: self sp.
PostBuildStackDelta ~= 0 ifTrue:
[self sp: self sp - PostBuildStackDelta]. "In order to satisfy the CStackAlignment check by cogit, which is only valid on IA32 platforms."
self pc: address!
Item was changed:
+ ----- Method: GdbARMAlien>>simulateJumpCallOf:memory: (in category 'execution') -----
- ----- Method: GdbARMAlien>>simulateJumpCallOf:memory: (in category 'execution simulation') -----
simulateJumpCallOf: address memory: aMemory
"Simulate a frame-building jump of address. Build a frame since
a) this is used for calls into the run-time which are unlikely to be leaf-calls"
"This method builds a stack frame as expected by the simulator, not as defined by ARM aapcs-abi.
In ARM aapcs, every method can define for itself, wether it wants to push lr (nextpc), and wether it
uses a frame pointer. The standard never mentions a fp. It merely defines r4-r11 to be callee-saved."
self assert: self sp \\ 8 = 0. "This check ensures, that we conform with ARM abi. Before doing anything to the stack, we ensure 2-word alignment."
self pushWord: self lr in: aMemory.
self pushWord: self fp in: aMemory.
self fp: self sp.
PostBuildStackDelta ~= 0 ifTrue:
[self sp: self sp - PostBuildStackDelta]. "In order to satisfy the CStackAlignment check by cogit, which is only valid on IA32 platforms."
self pc: address!
Item was changed:
+ ----- Method: GdbARMAlien>>simulateLeafCallOf:nextpc:memory: (in category 'execution') -----
- ----- Method: GdbARMAlien>>simulateLeafCallOf:nextpc:memory: (in category 'execution simulation') -----
simulateLeafCallOf: address nextpc: nextpc memory: aMemory
self lr: nextpc.
self pc: address!
Item was changed:
+ ----- Method: GdbARMAlien>>simulateLeafReturnIn: (in category 'execution') -----
- ----- Method: GdbARMAlien>>simulateLeafReturnIn: (in category 'execution simulation') -----
simulateLeafReturnIn: aMemory
self pc: self lr!
Item was changed:
+ ----- Method: GdbARMAlien>>simulateReturnIn: (in category 'execution') -----
- ----- Method: GdbARMAlien>>simulateReturnIn: (in category 'execution simulation') -----
simulateReturnIn: aMemory
PostBuildStackDelta ~= 0 ifTrue:
[self sp: self sp + PostBuildStackDelta].
self fp: (self popWordIn: aMemory).
"According to tpr, most C compilers implement return by simply
popping into the pc, rather than popping through the link register."
self pc: (self popWordIn: aMemory)!
More information about the Vm-dev
mailing list