On Mon, 28 Jun 2021, Greg Kroah-Hartman wrote: > On Fri, Jun 25, 2021 at 05:38:01PM -0700, Hugh Dickins wrote: > > On Wed, 23 Jun 2021, Hugh Dickins wrote: > > > On Wed, 23 Jun 2021, Andrew Morton wrote: > > > > On Wed, 23 Jun 2021 09:44:14 -0700 (PDT) Hugh Dickins <hughd@xxxxxxxxxx> wrote: > > > > > > > > > > Any word on this? > > > > > > > > > > I have a "matrix" of what's needed ready, but I'm still waiting on > > > > > "I expect some more to follow in a few days time (thanks Andrew)": > > > > > I believe akpm does still intend to send them in to Linus for 5.13 > > > > > this week, but they've not gone yet. > > > > > > > > Linuswards tomorrow. Is that OK? > > > > > > That's great, thanks Andrew. Then when they appear in Linus's tree, > > > I'll complete my notes and tarball, and mail GregKH in reply here. > > > > All in now, thanks: so attached is a tarball of the variants, > > and here the finalized summary of what each stable needs. > > > > 5.12.13 5.10.46 5.4.128 4.19.195 4.14.237 4.9.273 > > 4.14/0001 << chpick > > 5.10/0001 << chpick << chpick << chpick << chpick > > 5.10/0002 << chpick << chpick << chpick > > 5.10/0003 << chpick << chpick << chpick > > ffc90cbb2970 << chpick << chpick > > 99fa8a48203d 5.10/0005 << chpick << chpick > > 3b77e8c8cde5 << chpick << chpick << chpick > > 732ed55823fc << chpick 5.04/0007 << chpick << chpick > > 494334e43c16 << chpick 5.04/0008 4.19/0007 << chpick > > 31657170deaf << chpick << chpick << chpick << chpick > > 22061a1ffabd 5.10/0010 5.04/0010 << chpick > > 504e070dc08f 5.10/0011 5.04/0011 4.19/0010 4.14/0008 4.09/0003 > > f003c03^..a7a69d8 chpick << chpick << chpick << chpick > > fe19bd3dae3d << chpick 5.04/0022 << chpick << chpick 4.09/0004 > > > > 19 recent THP-related upstream commits for 5.13: > > ffc90cbb2970 mm, thp: use head page in __migration_entry_wait() > > 99fa8a48203d mm/thp: fix __split_huge_pmd_locked() on shmem migration entry > > 3b77e8c8cde5 mm/thp: make is_huge_zero_pmd() safe and quicker > > 732ed55823fc mm/thp: try_to_unmap() use TTU_SYNC for safe splitting > > 494334e43c16 mm/thp: fix vma_address() if virtual address below file offset > > 31657170deaf mm/thp: fix page_address_in_vma() on file THP tails > > 22061a1ffabd mm/thp: unmap_mapping_page() to fix THP truncate_cleanup_page() > > 504e070dc08f mm: thp: replace DEBUG_VM BUG with VM_WARN when unmap fails for split > > f003c03bd29e mm: page_vma_mapped_walk(): use page for pvmw->page > > 6d0fd5987657 mm: page_vma_mapped_walk(): settle PageHuge on entry > > 3306d3119cea mm: page_vma_mapped_walk(): use pmde for *pvmw->pmd > > e2e1d4076c77 mm: page_vma_mapped_walk(): prettify PVMW_MIGRATION block > > 448282487483 mm: page_vma_mapped_walk(): crossing page table boundary > > b3807a91aca7 mm: page_vma_mapped_walk(): add a level of indentation > > 474466301dfd mm: page_vma_mapped_walk(): use goto instead of while (1) > > a765c417d876 mm: page_vma_mapped_walk(): get vma_address_end() earlier > > a9a7504d9bea mm/thp: fix page_vma_mapped_walk() if THP mapped by ptes > > a7a69d8ba88d mm/thp: another PVMW_SYNC fix in page_vma_mapped_walk() > > fe19bd3dae3d mm, futex: fix shared futex pgoff on shmem huge page > > > > Antecedents which get added into some older kernels: > > 4.14/0001 91241681c62a include/linux/mmdebug.h: make VM_WARN* non-rvals > > 5.10/0001 a4055888629b (part) mm: add VM_WARN_ON_ONCE_PAGE() macro > > 5.10/0002 e0af87ff7afc mm/rmap: remove unneeded semicolon in page_not_mapped() > > 5.10/0003 b7e188ec98b1 mm/rmap: use page_not_mapped in try_to_unmap() > > > > Nothing special for 5.12.13: all 19 can be cherry-picked cleanly. > > > > Antecedents and fixedups for 5.10.46 and older: > > 5.10/0001-mm-add-VM_WARN_ON_ONCE_PAGE-macro.patch > > 5.10/0002-mm-rmap-remove-unneeded-semicolon-in-page_not_mapped.patch > > 5.10/0003-mm-rmap-use-page_not_mapped-in-try_to_unmap.patch > > 5.10/0005-mm-thp-fix-__split_huge_pmd_locked-on-shmem-migratio.patch > > 5.10/0010-mm-thp-unmap_mapping_page-to-fix-THP-truncate_cleanu.patch > > 5.10/0011-mm-thp-replace-DEBUG_VM-BUG-with-VM_WARN-when-unmap-.patch > > > > Fixedups for 5.4.128 and older: > > 5.04/0007-mm-thp-try_to_unmap-use-TTU_SYNC-for-safe-splitting.patch > > 5.04/0008-mm-thp-fix-vma_address-if-virtual-address-below-file.patch > > 5.04/0010-mm-thp-unmap_mapping_page-to-fix-THP-truncate_cleanu.patch > > 5.04/0011-mm-thp-replace-DEBUG_VM-BUG-with-VM_WARN-when-unmap-.patch > > 5.04/0022-mm-futex-fix-shared-futex-pgoff-on-shmem-huge-page.patch > > > > Fixedups for 4.19.195 and older: > > 4.19/0007-mm-thp-fix-vma_address-if-virtual-address-below-file.patch > > 4.19/0010-mm-thp-replace-DEBUG_VM-BUG-with-VM_WARN-when-unmap-.patch > > > > (Why does matrix say not to port ffc90cbb2970 "use head page" to 4.19 > > and older? It is correct, and would apply to them: but they do not > > have put_and_wait_on_page_locked(), so it may behave worse on them.) > > > > Antecedent and fixedup for 4.14.237 and older: > > 4.14/0001-include-linux-mmdebug.h-make-VM_WARN-non-rvals.patch > > 4.14/0008-mm-thp-replace-DEBUG_VM-BUG-with-VM_WARN-when-unmap-.patch > > > > Fixedups for 4.9.273: > > 4.09/0003-mm-thp-replace-DEBUG_VM-BUG-with-VM_WARN-when-unmap-.patch > > 4.09/0004-mm-futex-fix-shared-futex-pgoff-on-shmem-huge-page.patch > > > > No backports to 4.4.273: it's too old and different for these. > > Thanks so much for this, and I was able to follow the above directions > for 5.12, 5.10, and 5.4. Yes, I've checked the results, and you've done brilliantly: thanks. > > But things fell apart for 4.19.y, when doing the backport of the longer > series: > > f003c03^..a7a69d8 chpick << chpick << chpick << chpick > > That just did not work. That's very odd. If that worked on 5.12, 5.10, 5.4 then I don't understand how it does not work on 4.19: I've had no trouble repeating it at this end, so can only think that you must have unconsciously changed procedure in some way on reaching 4.19. I say "no trouble", but agree "git cherry-pick f003c03^..a7a69d8" does not work: because linux-stable-rc.git master has not yet been updated to Linus's current tree, so the tree doesn't contain those SHA1s. But you already worked around that correctly on 5.12, 5.10, 5.4; and "the matrix" wasn't expecting you to go back to 5.13 for those on 4.19 anyway, but to cherry-pick those ten from what you already correctly prepared for 5.4. (Perhaps the right command is "git cherry-pick 461d351e7cd4^..d106cf83e3cb", that's what worked for me, but I haven't spent long enough thinking whether my tree is sufficiently identical to yours or not.) If that's not the issue, the other two possibilities that cross my mind are: you're sure that you already applied the first ten patches to that branch, cherry-picking from 5.4 or git-am'ing 0007 and 0010 - there are mods to mm/page_vma_mapped.c in a couple of those earlier patches, which are required for clean application of the later mods. And the other possibility: I did once or twice a few years ago have trouble with "git cherry-pick xxx^..yyy" syntax: it failed, but the equivalent series of individual cherry-picks succeeded. If that was not simply pilot error, I imagine it was a git bug long since fixed, but mention individual cherry-picks as perhaps a workaround. > > So could you just send a mbox of patches (or tarball), for the 4.19, > 4.14, and 4.9 trees? That would make it much easier to ensure I got > them all correct. At risk of irritating you, sorry, I am resisting: the more data I send you, the more likely I am to mess it up in some stupid way. Please ask again and I shall, but I think your success with 5.12, 5.10, 5.4 just means that you were right to take a break before 4.19, 4.14, 4.4. Many thanks, Hugh