On Fri, 2024-10-11 at 07:40 +0800, Phil Reid wrote: > On 10/10/2024 15:17, Richard Purdie wrote: > > On Thu, 2024-10-10 at 13:25 +0800, Phil Reid via lists.openembedded.org > > wrote: > > > Changes to the logic of is_work_shared where made in > > > commit: 5fbb4ca8da4f4f1ea426275c45634802dcb5a575 > > > "archiver.bbclass: Improve work-shared checking" > > > > > > The resuled in a change of the logic (simplifed here) from: > > > inherits(gcc-source) or inherits(kernel) or (inherits(kernelsrc) > > > and srcin(work-shared)) > > > to just > > > srcin(work-shared) > > > > > > With INHERIT += "archiver" in the local.conf and a kernel recipe that > > > uses > > > KERNEL_PACKAGE_NAME. When KERNEL_PACKAGE_NAME is defined the kernel > > > source is not placed into work-shared, but the archiver ends up > > > deleting the source folder in the work dir, and the build > > > subsequently fails. > > > > > > Restore the previous logic while also mainting the referenced commits > > > intent > > > to consider all recipes that use work-shared. Logic is now > > > inherits(gcc-source) or inherits(kernel) or srcin(work-shared) > > > > > > Signed-off-by: Phil Reid <[email protected]> > > > --- > > > meta/classes/archiver.bbclass | 5 ++++- > > > 1 file changed, 4 insertions(+), 1 deletion(-) > > > > You're effectively reverting that commit whilst changing the logic so > > it looks slightly different. > > > > Was there a problem with gcc-source archiving as I notice the patch > > adds gcc-source back too? > To be honest I didn't test without the gcc-source, I reverted the commit > first after > finding that commit to be the cause and modified it so it consider it always > considered > work-shared path and called it done and the old logic conditions. > > > > > The commit message isn't quite accurate as gcc-source isn't something > > which gets inherited. > Fair enough. > > > > > Does this only happen with kernel recipes which use > > KERNEL_PACKAGE_NAME? That might be the key missing detail which would > > allow us to reproduce the failure. > > > > I haven't seen the problem on a virtual/kernel. > When KERNEL_PACKAGE_NAME is specified the kernel source isn't put into > work-shared. > > > How would you like to see this fixed?
I deal with many patches a day and part of the review process is to see if a change makes sense. So far, this patch does not add up properly. What I need is a change which makes sense and is something I can review, agree with and merge. What I don't have is time to deep dive into every issue and work out the proper fix, much as I would love to. So far on this issue, the information I do have isn't adding up correctly. Taking what you say above, "KERNEL_PACKAGE_NAME is specified the kernel source isn't put into work-shared" - that makes sense. If the kernel isn't being put into shared workdir, "is_work_shared()" should be returning False in this case. Looking at the logic, I believe that is true and it will for a KERNEL_PACKAGE_NAME recipe. So what you're probably saying is that the code should be using the "shared" codepath for the KERNEL_PACKAGE_NAME even though the workdir isn't shared. At this point I'm just having to speculate though. So how would I like to see this fixed? I'd like to see an explaintion of the problem which makes sense and I'd like to see changes which don't make the code "worse", i.e. making a "is_work_shared()" function return True when it isn't. It sounds like there is a deeper problem with the archiver code which needs fixing at the root of the issue. Again, I'm back to speculating though. Cheers, Richard
-=-=-=-=-=-=-=-=-=-=-=- Links: You receive all messages sent to this group. View/Reply Online (#205676): https://lists.openembedded.org/g/openembedded-core/message/205676 Mute This Topic: https://lists.openembedded.org/mt/108924104/21656 Group Owner: [email protected] Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub [[email protected]] -=-=-=-=-=-=-=-=-=-=-=-
