Age | Commit message (Collapse) | Author |
---|
| https://.com/ruby/stringio/commit/ee3ee1df31 |
| EOC octets are required at the end of contents of a constructed encoding that uses the indefinite length form. This cannot be assumed from the end of the input. Raise an exception when necessary. https://.com/ruby/openssl/commit/bc20c13a7c |
| |
| Notes: Merged-By: ioquatix <[email protected]> |
| The fstring table size used to be reported as part of the VM size, but since it was refactored to be lock-less it was no longer reported. Since it's now wrapped by a `T_DATA`, we can implement its `dsize` function and get a valuable insight into the size of the table. ``` {"address":"0x100ebff18", "type":"DATA", "shape_id":0, "slot_size":80, "struct":"VM/fstring_table", "memsize":131176, ... ``` Notes: Merged: https://.com/ruby/ruby/pull/13138 |
| Notes: Merged: https://.com/ruby/ruby/pull/13137 |
| Notes: Merged-By: ioquatix <[email protected]> |
| Notes: Merged: https://.com/ruby/ruby/pull/13133 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| (https://.com/Shopify/zjit/pull/111) This makes the output a little nicer when doing --zjit-dump-hir=all Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| * Show failing test * Add second test case * Add empty NewArray setup * Update opt_tests and fix NewArray instantiation * Add code generation for NewArray * Add NewArray ordering test Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| * Implement JIT-to-JIT calls * Use a closer dummy address for Arm64 * Revert an obsoleted change * Revert a few more obsoleted changes * Fix outdated comments * Explain PosMarkers for CCall * s/JIT code/machine code/ * Get rid of ParallelMov Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Helps with readability and threads type info that's there around for longer. Amend test so `GuardType` doesn't DCE'ed. Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| We need to keep the Snapshot instruction alive. Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| We don't want to only guard on the class Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| A new optimization pass. Also: - Printing for `Insn::CCall` - Wrap `ID` and add convenience method for printing, replacing calls to rb_id2name() Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| In case the callee writes to the caller's locals, we need to be able to immediately side-exit because our frame's invariants might have been invalidated. If in the course of optimization we rewrite the Send, we can choose to remove the Point too---but it's not an error to keep it around. Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| (https://.com/Shopify/zjit/pull/99) * Disable ZJIT profiling at call-threshold * Stop referencing ZJIT instructions in codegen Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| * Add --zjit-profile-interval option * Fix min to max * Avoid rewriting instructions for --zjit-call-threshold=1 * Rename the option to --zjit-num-profiles Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| (https://.com/Shopify/zjit/pull/95) * Remove immediately deferenced borrow operators source: https://rust-lang..io/rust-clippy/master/index.html#needless_borrow * Remove unnecessary cast as i64 Since Const::CInt64 wraps i64, it is unnecessary to cast to i64. * Remove unnecessary borrow operators * Beautify assign operation syntax * Use .is_null() convenience method * Omit .into() call from u32 to u32 * Use more descriptive std::ptr::null<VALUE>() In lieu of casting a literal as a type, opt to use the convenience type. * Use sized integer literal * Simplify pattern matching to explicit check Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| (https://.com/Shopify/zjit/pull/96) Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| We want to return representatives for the stack and locals. Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| * Remove redundant statements * Remove .clone() since A64 implements Copy * Remove .clone() since InsnId implements Copy . * Dereference since *const rb_call_data implements Copy * Remove unnecessary return statement * Remove unnecessary braces * Use .is_empty() over length checks * Remove unnecessary conversion handling Since i32 can always fit into i64 (the inner type in Opnd::Imm), the conversion is infallibile. * Use slice notation in lieu of Vec https://rust-lang..io/rust-clippy/master/index.html#ptr_arg * Simplify match statement Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| (https://.com/Shopify/zjit/pull/90) Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Initialize with a vector of operands instead of ArraySet instructions. Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Dead code elimination (DCE) is like garbage collection for your HIR graph: it removes instructions that are not referenced by the "root set"---in this case, the instructions marked critical. Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Only emit them on-demand. Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| https://.com/Shopify/zjit/pull/87#discussion_r2025152210 Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| In calls to top-level functions, we assume that call targets will not get rewritten, so we can insert a Point and do the lookup at compile-time. Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| (https://.com/Shopify/zjit/pull/87) Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| Notes: Merged: https://.com/ruby/ruby/pull/13131 |
| We want to otherwise see real pointers in print output. Notes: Merged: https://.com/ruby/ruby/pull/13131 |