mirror of
https://github.com/ruby/ruby.git
synced 2025-08-15 13:39:04 +02:00
Introduce Ractor mechanism for parallel execution
This commit introduces Ractor mechanism to run Ruby program in parallel. See doc/ractor.md for more details about Ractor. See ticket [Feature #17100] to see the implementation details and discussions. [Feature #17100] This commit does not complete the implementation. You can find many bugs on using Ractor. Also the specification will be changed so that this feature is experimental. You will see a warning when you make the first Ractor with `Ractor.new`. I hope this feature can help programmers from thread-safety issues.
This commit is contained in:
parent
eeb5325d3b
commit
79df14c04b
Notes:
git
2020-09-03 21:11:34 +09:00
41 changed files with 5951 additions and 783 deletions
|
@ -93,7 +93,7 @@ enum vm_regan_acttype {
|
|||
#define SET_SP(x) (VM_REG_SP = (COLLECT_USAGE_REGISTER_HELPER(SP, SET, (x))))
|
||||
#define INC_SP(x) (VM_REG_SP += (COLLECT_USAGE_REGISTER_HELPER(SP, SET, (x))))
|
||||
#define DEC_SP(x) (VM_REG_SP -= (COLLECT_USAGE_REGISTER_HELPER(SP, SET, (x))))
|
||||
#define SET_SV(x) (*GET_SP() = (x))
|
||||
#define SET_SV(x) (*GET_SP() = rb_ractor_confirm_belonging(x))
|
||||
/* set current stack value as x */
|
||||
|
||||
/* instruction sequence C struct */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue