merge revision(s) f7059af50a: [Backport #21046]

Use no-inline version `rb_current_ec` on Arm64

	The TLS across .so issue seems related to Arm64, but not Darwin.
This commit is contained in:
nagachika 2025-03-08 17:23:15 +09:00
parent 56ba9041d9
commit 8274b8193e
4 changed files with 5 additions and 5 deletions

View file

@ -132,8 +132,8 @@ struct rb_thread_sched {
NOINLINE(void rb_current_ec_set(struct rb_execution_context_struct *));
NOINLINE(struct rb_execution_context_struct *rb_current_ec_noinline(void));
# ifdef __APPLE__
// on Darwin, TLS can not be accessed across .so
# if defined(__arm64__) || defined(__aarch64__)
// on Arm64, TLS can not be accessed across .so
NOINLINE(struct rb_execution_context_struct *rb_current_ec(void));
# else
RUBY_EXTERN RB_THREAD_LOCAL_SPECIFIER struct rb_execution_context_struct *ruby_current_ec;

View file

@ -11,7 +11,7 @@
# define RUBY_VERSION_MINOR RUBY_API_VERSION_MINOR
#define RUBY_VERSION_TEENY 7
#define RUBY_RELEASE_DATE RUBY_RELEASE_YEAR_STR"-"RUBY_RELEASE_MONTH_STR"-"RUBY_RELEASE_DAY_STR
#define RUBY_PATCHLEVEL 124
#define RUBY_PATCHLEVEL 125
#include "ruby/version.h"
#include "ruby/internal/abi.h"

2
vm.c
View file

@ -551,7 +551,7 @@ rb_current_ec_set(rb_execution_context_t *ec)
}
#ifdef __APPLE__
#if defined(__arm64__) || defined(__aarch64__)
rb_execution_context_t *
rb_current_ec(void)
{

View file

@ -1930,7 +1930,7 @@ static inline rb_execution_context_t *
rb_current_execution_context(bool expect_ec)
{
#ifdef RB_THREAD_LOCAL_SPECIFIER
#ifdef __APPLE__
#if defined(__arm64__) || defined(__aarch64__)
rb_execution_context_t *ec = rb_current_ec();
#else
rb_execution_context_t *ec = ruby_current_ec;