-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
make clean: split file list into manageable chunks #1897
Conversation
mk/cleandirs.mk
Outdated
# (200 files at a time), to minimize the odds of having: | ||
# "/bin/bash: Argument list too long" | ||
define do-rm-f | ||
$(call _do-rm, $(wordlist 1, 200, $(1))) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
_do-rm-f
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ditto
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Doh! That's what happens when you decide to rename something at the last minute.
Will fix, thanks.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
tested ok with s/_do-rm/_do-rm-f/ fix.
mk/cleandirs.mk
Outdated
|
||
define _do-rm-f | ||
${q}rm -f $1 | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
minor: spurious empty line
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Correct. Leftover from a previous solution whic hwas simply iterating with foreach.
Will fix.
mk/cleandirs.mk
Outdated
$(call _do-rm, $(wordlist 1, 200, $(1))) | ||
$(eval _tail := $(wordlist 201, $(words $(1)), $(1))) | ||
$(if $(_tail), $(call do-rm-f, $(_tail))) | ||
$(eval _tail :=) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
do you need this
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No, un-necessary cleanup indeed. Will fix.
mk/cleandirs.mk
Outdated
# (200 files at a time), to minimize the odds of having: | ||
# "/bin/bash: Argument list too long" | ||
define do-rm-f | ||
$(call _do-rm, $(wordlist 1, 200, $(1))) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ditto
Update |
|
"make clean" might fail with the following error: make[2]: execvp: /bin/bash: Argument list too long This error was observed on a platform that has lots of additional source files compared to upstream (drivers, etc.), and that sets a long output path on the command line (make ... O=/some/long/path). Fix the error by splitting the file list into more manageable chunks. Note that removing one file at a time is not reasonable, because spawning too may shells takes quite a long time (up to 7-10 seconds to "make clean"). Signed-off-by: Jerome Forissier <[email protected]> Reported-by: Lijianhui <[email protected]> Reviewed-by: Jens Wiklander <[email protected]>
fd97054
to
4b358a1
Compare
"make clean" might fail with the following error:
make[2]: execvp: /bin/bash: Argument list too long
This error was observed on a platform that has lots of additional
source files compared to upstream (drivers, etc.), and that sets a long
output path on the command line (make ... O=/some/long/path).
Fix the error by splitting the file list into more manageable chunks.
Note that removing one file at a time is not reasonable, because
spawning too may shells takes quite a long time (up to 7-10 seconds to
"make clean").
Signed-off-by: Jerome Forissier [email protected]
Reported-by: Lijianhui [email protected]