| Commit message (Collapse) | Author | Age | Files | Lines |
|
|
|
|
|
|
| |
Node has not been managed by GC from Ruby 2.5.
Therefore these codes are not needed. If ObjectSpace depends on Node,
it needs to update the file when node type is updated. Delete node
related codes to avoid such update.
|
|
|
|
|
| |
Too complex classes use a hash table to store ivs, and should always pin
their IVs. We shouldn't touch those classes in compaction.
|
|
|
|
| |
This reverts commit 5f3fb4f4e397735783743fe52a7899b614bece20.
|
|
|
|
|
| |
This records the called_id and klass from imemo_callcache objects in
heap dumps.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Context: https://github.com/ivoanjo/gvl-tracing/pull/4
Some hooks may want to collect data on a per thread basis.
Right now the only way to identify the concerned thread is to
use `rb_nativethread_self()` or similar, but even then because
of the thread cache or MaNy, two distinct Ruby threads may report
the same native thread id.
By passing `thread->self`, hooks can use it as a key to store
the metadata.
NB: Most hooks are executed outside the GVL, so such data collection
need to use a thread-safe data-structure, and shouldn't use the
reference in other ways from inside the hook.
They must also either pin that value or handle compaction.
|
|
|
|
|
|
|
| |
This reverts commit f6910a61122931e4193bcc0fad18d839c319b720.
We're seeing crashes in the test suite of Shopify's core monolith after
this change.
|
|
|
|
| |
https://github.com/ruby/io-console/commit/057ab96a73
|
|
|
|
| |
https://github.com/ruby/io-console/commit/b0c688c57e
|
|
|
|
| |
https://github.com/ruby/io-console/commit/ebdbebf461
|
|
|
|
| |
https://github.com/ruby/io-console/commit/0bfde8372c
|
|
|
|
|
| |
We don't need to create a shape to transition capacity as we can
transition the capacity when the capacity of the SHAPE_IVAR changes.
|
|
|
|
| |
https://github.com/ruby/digest/commit/2f3505bf3f
|
|
|
|
| |
https://github.com/ruby/stringio/commit/a2f8ef1a6a
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
(https://github.com/ruby/stringio/pull/69)
The conversion logic is borrowed from ruby/ruby's io.c:
https://github.com/ruby/ruby/blob/40391faeab608665da87a05c686c074f91a5a206/io.c#L4059-L4079
Fix ruby/stringio#68
Reported by IWAMOTO Kouichi. Thanks!!!
https://github.com/ruby/stringio/commit/4b170c1a68
|
|
|
|
| |
https://github.com/ruby/strscan/commit/1b3393be05
|
|
|
|
| |
https://github.com/ruby/fiddle/commit/bbcb66e16e
|
|
|
|
| |
https://github.com/ruby/fiddle/commit/74a05fb358
|
|
|
|
|
|
|
|
| |
GitHub: fix https://github.com/ruby/fiddle/pull/130
Reported by Benoit Daloze. Thanks!!!
https://github.com/ruby/fiddle/commit/2640e0148e
|
|
|
|
| |
https://github.com/flori/json/commit/ec47749b53
|
| |
|
|
|
|
|
|
| |
As agreed in [Feature #18822]
https://github.com/ruby/cgi/commit/9d1161ec9d
|
|
|
|
| |
https://github.com/ruby/zlib/commit/2561e122ac
|
|
|
|
| |
https://github.com/ruby/zlib/commit/661ea3ec5f
|
|
|
|
| |
https://github.com/ruby/pathname/commit/f3d23679b0
|
|
|
|
| |
https://github.com/ruby/fcntl/commit/fe780abe07
|
|
|
|
| |
https://github.com/ruby/win32ole/commit/9a18f388a9
|
|
|
|
|
|
| |
the scale of `1` is actually 0
https://github.com/ruby/bigdecimal/commit/9a8bc9c417
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Follow up https://github.com/ruby/bigdecimal/issues/89.
`BigDecimal.new` has already been removed. This PR replaces `BigDecimal.new` with
`Kernel.BigDecimal` in the documentation, following the message below:
> BigDecimal.new is deprecated; use Kernel.BigDecimal method instead.
https://github.com/ruby/bigdecimal/commit/26d84ba766e971da8eaaf2ce41e7b89935fa68da
https://github.com/ruby/bigdecimal/commit/dd52adf3b2
|
|
|
|
| |
https://github.com/ruby/date/commit/50e18d2684
|
|
|
|
|
| |
Do not use `pthread_attr_setaffinity_np` if `sched_getcpu()` exceeds
`CPU_SETSIZE`. (Using `CPU_ALLOC()` would be more appropriate.)
|
|
|
|
| |
pointed by @nobu
|
| |
|
|
|
|
|
|
|
|
|
|
| |
After a pthread for getaddrinfo is detached, we cannot predict when the
thread will exit. It would lead to a segfault by setting
pthread_setaffinity to the terminated pthread. I guess this problem
would be more likely to occur in high-load environments.
This change detaches the pthread after pthread_setaffinity is called.
[Feature #19965]
|
|
|
|
| |
This reverts commit de82439215dd2770ef9a3a2cf5798bdadb788533.
|
|
|
|
| |
https://github.com/ruby/etc/commit/e4c71e5996
|
|
|
|
| |
https://github.com/ruby/stringio/commit/4400bf3380
|
|
|
|
| |
https://github.com/ruby/stringio/commit/3f90a0d619
|
|
|
|
|
| |
This commit makes every initial size pool shape a root shape and assigns
it a capacity of 0.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Add a new API rb_profile_thread_frames(), which is essentialy a
per-thread version of rb_profile_frames().
While the original rb_profile_frames() always returns results about the
current active thread obtained by GET_EC(), this new API takes a Thread
to be profiled as an argument.
This should come in handy when profiling I/O-bound programs such as
webapps, since this new API allows us to learn about Threads performing
I/O (which do not have the GVL).
Profiling worker threads (such as Sidekiq workers) may be another
application.
Implements [Feature #10602]
Co-authored-by: Mike Perham <mike@perham.net>
|
|
|
|
| |
https://github.com/ruby/etc/commit/a9e4d4730d
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
extconf.rb
(https://github.com/ruby/zlib/pull/69)
The android NDK (android-ndk-r21e) does not have crc32_z, adler32_z, nor
z_size_t in its zlib.h header file. However, it _does_ have the crc32_z
and adler32_z symbols in the libz.a static library!
mkmf performs two tests for have_func:
* It sees if a program that includes the header and takes the address of
the symbol can compile
* It sees if a program that defines the symbol as `extern void sym_name()`
and calls it can be linked
If either test works, it considers the function present. The
android-ndk-r21e is passing the second test but not the first for
crc32_z/adler32_z. So, we define HAVE_ZLIB_SIZE_T_FUNCS, but then can't
actually compile the extension (since the prototypes aren't in the
header file).
We can keep this working how it was working before by _also_ checking
for `have_type("z_size_t", "zlib.h")`. The have_type check _only_ looks
in the header file for the type; if a program including the header file
and using the type can't compile, the type is considered absent
regardless of what might be in libz.a.
https://github.com/ruby/zlib/commit/3b9fe962d8
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
We use the Cloudflare fork of zlib
(https://github.com/cloudflare/zlib), which we find gives improved
performance on AWS Graviton ARM instances. That fork does not define
crc32_z and alder32_z functions.
Until two days ago, Ruby's zlib gem worked fine, because cloudflare zlib
_also_ did not define z_size_t, which meant Ruby did not try and use
these functions.
Since https://github.com/cloudflare/zlib/commit/a3ba99596d6271224d39ef9d6853511f51821e05
however, cloudflare zlib _does_ define z_size_t (but NOT crc32_z or
alder32_z). The zlib gem would try and use these nonexistant
functions and not compile.
This patch fixes it by actually specifically detecting the functions
that the gem wants to call, rather than just the presence of the
z_size_t type.
https://github.com/ruby/zlib/commit/c96e8b9a57
|
|
|
|
|
|
|
|
|
|
| |
Looks like it randomly causes a segfault
https://rubyci.s3.amazonaws.com/rhel_zlinux/ruby-master/log/20231025T093302Z.fail.html.gz
```
[11186/26148] TestNetHTTP_v1_2#test_set_form/home/chkbuild/build/20231025T093302Z/ruby/tool/lib/webrick/httprequest.rb:197: [BUG] Segmentation fault at 0x000003ff1ffff000
ruby 3.3.0dev (2023-10-25T07:50:00Z master 526292d9fe) [s390x-linux]
```
|
| |
|
|
|
|
| |
Cosmetic change per ko1's preference
|
| |
|
|
|
|
| |
Same as previous commit for rb_getnameinfo.
|
|
|
|
|
|
|
|
| |
When pthread_create is available, rb_getaddrinfo creates a pthread and
executes getaddrinfo(3) in it. The caller thread waits for the pthread
to complete, but detaches it if interrupted. This allows name resolution
to be interuppted by Timeout.timeout, etc. even if it takes a long time
(for example, when the DNS server does not respond). [Feature #19965]
|
| |
|
|
|
|
|
| |
This is a preparation for introducing cancellable
getaddrinfo/getnameinfo.
|