Project

General

Profile

Actions

Bug #21172

closed

Race condition in `register_fstring`

Added by byroot (Jean Boussier) 30 days ago. Updated 19 days ago.

Status:
Closed
Assignee:
-
Target version:
-
[ruby-core:121246]

Description

This is a rare bug with very low criticality, but it can cause occasional CI failures. I leave it to branch maintainers to decide if it's worth backporting or not.

Timeline

  • A "foo" oid=1 string is interned.
  • "foo" oid=1 is no longer referenced and will be swept in the future.
  • Another "foo" oid=2 string is interned.
  • register_fstring finds "foo" oid=1, but since it is about to be swept, removes it from fstring_table and insert "foo" oid=2 instead.
  • "foo" oid=1 is swept, since it has the RSTRING_FSTR flag, a st_delete is issued in fstring_table which removes "foo" oid=2.

Unfortunately, I couldn't come up with a minimal reproduction for this, but it did reproduce consistently with a large amount of tests and a very specific seed.

Consequence

This has little to no consequence on real world code. It just breaks a few ruby tests that is attempting to ensure some strings were interned.

Example:

	  1) Failure:
	JSONParserTest#test_freeze [/tmp/ruby/src/trunk/test/json/json_parser_test.rb:361]:
	Expected "foo" (oid=416) to be the same as "foo" (oid=424).
	make: *** [uncommon.mk:953: yes-test-all] Error 1
Actions

Also available in: Atom PDF

Like0
Like0Like0Like0Like0