Feature #8158
closedlightweight structure for loaded features index
Description
Use lightweight structure for loaded_features index:
- use hand made simple hash structure, which uses only one memory chunk,
- do not store feature name string, only hash of it, since loaded_feature_path
will recheck feature name on hash collision - use single linked lists instead of arrays for storing features indices.
- store this lists inside one array, using array's indices as a reference.
While startup speedup improvement is relatively small compared current implementation,
this one does not need any Ruby Objects at all, so that there is no presure on GC.
https://github.com/ruby/ruby/pull/264.patch
https://github.com/ruby/ruby/pull/264.diff
https://github.com/ruby/ruby/pull/264
Files
Updated by zzak (zzak _) almost 12 years ago
- File 264.patch added
- Category set to core
Updated by nobu (Nobuyoshi Nakada) over 11 years ago
- Status changed from Open to Assigned
- Assignee set to nobu (Nobuyoshi Nakada)
Updated by hsbt (Hiroshi SHIBATA) almost 11 years ago
- Target version changed from 2.1.0 to 2.2.0
Updated by funny_falcon (Yura Sokolov) over 8 years ago
- File 0001-load.c-reduce-memory-usage-of-loaded_features_index.patch added
Updated by funny_falcon (Yura Sokolov) over 8 years ago
I've changed implementation a bit:
Because https://bugs.ruby-lang.org/issues/12142 likely to be accepted,
I've used st_table with numtable instead of separate datastructure.
So patch now is shorter.
https://bugs.ruby-lang.org/attachments/download/6182/0001-load.c-reduce-memory-usage-of-loaded_features_index.patch
Updated by normalperson (Eric Wong) about 8 years ago
funny.falcon@gmail.com wrote:
So patch now is shorter.
https://bugs.ruby-lang.org/attachments/download/6182/0001-load.c-reduce-memory-usage-of-loaded_features_index.patch
Thanks; this got broken by trivial whitespace change in r57032
I'm not sure about the portability of initializing structs
with non-const values for some compilers. Maybe usa or
somebody with more portability experience can comment.
Also, in C Ruby; initial indent is 4 spaces, second indent is
hard tab. Not my rule and I hate it; but not much we can do...
Updated by usa (Usaku NAKAMURA) about 8 years ago
Hi,
In message "[ruby-core:78595] Re: [Ruby trunk Feature#8158] lightweight structure for loaded features index"
on Mon, 12 Dec 2016 06:06:13 +0000, normalperson@yhbt.net wrote:
I'm not sure about the portability of initializing structs
with non-const values for some compilers. Maybe usa or
somebody with more portability experience can comment.
It's OK, at least for VC++.
Regards,¶
U.Nakamaura usa@garbagecollect.jp
Updated by nobu (Nobuyoshi Nakada) about 8 years ago
Usaku NAKAMURA wrote:
In message "[ruby-core:78595] Re: [Ruby trunk Feature#8158] lightweight structure for loaded features index"
on Mon, 12 Dec 2016 06:06:13 +0000, normalperson@yhbt.net wrote:I'm not sure about the portability of initializing structs
with non-const values for some compilers. Maybe usa or
somebody with more portability experience can comment.It's OK, at least for VC++.
Other compilers fail, IIRC, Solaris, AIX, HP-UX, or something.
Updated by funny_falcon (Yura Sokolov) about 8 years ago
I'll fix patch today.
Updated by funny_falcon (Yura Sokolov) about 8 years ago
- File deleted (
264.patch)
Updated by funny_falcon (Yura Sokolov) about 8 years ago
- File deleted (
0001-load.c-reduce-memory-usage-of-loaded_features_index.patch)
Updated by funny_falcon (Yura Sokolov) about 8 years ago
I've uploaded fixed patch:
https://bugs.ruby-lang.org/attachments/download/6293/0001-load.c-reduce-memory-usage-of-loaded_features_index.patch
Github branch and diff:
https://github.com/funny-falcon/ruby/tree/loaded_features_strings
https://github.com/ruby/ruby/compare/trunk...funny-falcon:loaded_features_strings.patch
Updated by funny_falcon (Yura Sokolov) about 8 years ago
- File load.c-loaded_features_numindex.patch added
Updated by funny_falcon (Yura Sokolov) about 8 years ago
- File deleted (
load.c-loaded_features_numindex.patch)
Updated by funny_falcon (Yura Sokolov) about 8 years ago
Updated by funny_falcon (Yura Sokolov) about 8 years ago
I've tried to simplify patch: remove struct feature_str
and use just pointer with len.
https://bugs.ruby-lang.org/attachments/download/6295/load.c-loaded_features_numindex.patch
https://github.com/ruby/ruby/compare/trunk...funny-falcon:loaded_features_index.patch
https://github.com/funny-falcon/ruby/tree/loaded_features_index
Updated by shyouhei (Shyouhei Urabe) about 8 years ago
We looked at this issue at today's developer meeting and had positive opinions. Maybe introduced in 2.5.
Updated by matz (Yukihiro Matsumoto) almost 8 years ago
The patch seems OK now. @funny_falcon do you want to check in by yourself?
Matz.
Updated by funny_falcon (Yura Sokolov) almost 8 years ago
Matz,
I don't know English enough to clearly understand your suggestion.
Is it suggestion of commit rights?
If it is, it will be a great honor for me.
But I'm not even-tempered person, and I fear I will put a mess into repository if I will have commit rights.
If your suggestion means some-thing else, then may you formulate it in some other words so I can understand?
With regards,
Yura.
Updated by sam.saffron (Sam Saffron) almost 7 years ago
Hi Yura,
I think the commit rights here reduce the amount of work for the rest of the Ruby team.
This change is approved and reviewed, so you can commit it directly once you have the rights, no need to make other people do the committing.
Very keen to have this change included in Ruby.
Sam
Updated by duerst (Martin Dürst) almost 7 years ago
- Related to Feature #14460: Speed up `require` and reduce memory usage added
Updated by funny_falcon (Yura Sokolov) almost 7 years ago
Year after I think I am more stable person, so I'm going to accept commit rights with gratitude, honor and great responsibility.
But until I passed procedure, I'd be thankful if @tenderlovemaking (Aaron Patterson) will commit this one.
With regards,
Yura.
Updated by tenderlovemaking (Aaron Patterson) almost 7 years ago
- Status changed from Assigned to Closed
Committed in r62404. Thanks Yura!!
Updated by normalperson (Eric Wong) almost 7 years ago
I am curious, what is the significance of the 0xfea7009e
initializer passed to st_hash?
Would it be appropriate to use for the `st_hash' call in
hash.c::hash_i as well?
Thanks.
Updated by matz (Yukihiro Matsumoto) almost 7 years ago
@funny_falcon? Will you be a committer?
Matz.
Updated by funny_falcon (Yura Sokolov) almost 7 years ago
@matz (Yukihiro Matsumoto) , yes I will.
Excuse me for the delay. I'll try to proceed with steps from CommitterHowto this week.
With regards,
Yura.
Updated by funny_falcon (Yura Sokolov) almost 7 years ago
normalperson (Eric Wong) wrote:
I am curious, what is the significance of the 0xfea7009e
initializer passed to st_hash?
0xfea7009e - is a "feature" hex-spelled :-) Nothing special.
It could be ommitted, given features are strings without zero bytes.
I put it here just for fun.
Would it be appropriate to use for the `st_hash' call in
hash.c::hash_i as well?
I believe, there's no real needs.
Thanks.
With regards,
Yura.
Updated by hsbt (Hiroshi SHIBATA) almost 7 years ago
Hi all.
I did create an account of funny_falcon on svn.ruby-lang.org.