Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ulab code size of certain functions grew a lot with gcc13, when not used with LTO #648

Open
dhalbert opened this issue Nov 1, 2023 · 1 comment

Comments

@dhalbert
Copy link
Contributor

dhalbert commented Nov 1, 2023

ulab commit: eacb0c9

ARM just released a gcc13 toolchain: https://developer.arm.com/downloads/-/arm-gnu-toolchain-downloads.

CircuitPython just converted the main branch of CircuitPython to use gcc 13. In general we see a decrease of code size with gcc13 compared with gcc 2. But for ulab compiled on a build without LTO, we see a substantial increase. See adafruit/circuitpython#8546 (comment). If you expand > diffs.txt in that comment, an scroll to the end, you'll see that the functions with the largest increase in byte size are:

...
152 numerical_sum_mean_std_ndarray
206 ndarray_binary_add
206 ndarray_binary_multiply
232 ndarray_inplace_ams
570 ndarray_binary_equality
700 compare_function
712 ndarray_get_slice
764 ndarray_binary_power
798 ndarray_binary_subtract
824 ndarray_binary_floor_divide
846 ndarray_binary_true_divide
1606 ndarray_binary_more

This increase does not show up on LTO builds: see the atmel-samd Metro M4 numbers in that comment.
But on non-LTO builds, there is a substantial increase. I tested a couple of ports and see increases on stm and raspberrypi (RP2040).

I haven't looked at these functions to see what might be unusual about them yet.

@v923z
Copy link
Owner

v923z commented Nov 5, 2023

Thanks for the info! I'll try to look into this in the near future.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants