Skip to content

Conversation

@devnexen
Copy link
Member

With nested objects and recursive comparisons, it is for now unavoidable to have a stack overflow we do some early damage control attempt early on with zend.max_allowed_stack_size check but ultimately more a band-aid than a definitive solution.

With nested objects and recursive comparisons, it is for now unavoidable
to have a stack overflow we do some early damage control attempt early
on with zend.max_allowed_stack_size check but ultimately more a band-aid
than a definitive solution.
@devnexen
Copy link
Member Author

As mentioned by @nielsdos the performance drop here should be minimal, zend_hash_compare however would have been more impactful I assume.

@devnexen devnexen marked this pull request as ready for review May 16, 2025 22:35
@devnexen devnexen requested a review from dstogov as a code owner May 16, 2025 22:35
Copy link
Member

@arnaud-lb arnaud-lb left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks good to me

--FILE--
<?php

error_reporting(E_ALL & ~E_DEPRECATED);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: Add #[AllowDynamicProperties] on the class to avoid the warning

zend_object *zobj1, *zobj2;

if (zend_objects_check_stack_limit()) {
zend_throw_error(NULL, "Object compare - stack limit reached");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit:

Suggested change
zend_throw_error(NULL, "Object compare - stack limit reached");
zend_throw_error(NULL, "Maximum call stack size reached during object comparison");

To get a similar message as in

"Maximum call stack size of %zu bytes (zend.max_allowed_stack_size - zend.reserved_stack_size) reached during compilation. Try splitting expression",

@devnexen devnexen closed this in 4dcbd24 May 17, 2025
devnexen added a commit to devnexen/php-src that referenced this pull request May 17, 2025
devnexen added a commit that referenced this pull request May 17, 2025

$cur = $first;

for ($i = 0; $i < 50000; $i++) {
Copy link
Contributor

@mvorisek mvorisek May 17, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The test "fail" even for i=0 (no loop at all) - https://3v4l.org/gkKqd. The comparison probably cannot find cycles correctly.

Copy link
Member Author

@devnexen devnexen May 18, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it does trigger the Nesting level too deep warning indeed but it does not trigger the Maximum call stack size reached one, which is the whole point of this test. (just tried locally with master)

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have simplified the code and opened #18585. I belive the recursion in weak comparasion should be handled.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants