On Fri, Apr 19, 2019 at 6:33 AM Martin Schwidefsky <schwidefsky@xxxxxxxxxx> wrote: > > That problem got stuck in my head and I thought more about it. Why not > emulate the static folding sequence in the s390 page table code? So this model seems much closer to what x86 does in its folding, where the pattern is basically > static inline pX-1d_t *pXd_offset(pXd_t *pXd, unsigned long address) > { > if (pXd_folded(pXd) > return (pX-1d_t *) pXd; > return (pX-1d_t *) pXd_deref(*pXd) + pXd_index(address); > } which is really how the code is designed to work (ie the folded entry doesn't actually do anything to the page directory pointer, it just says "ok, we'll use this exact page directory pointer for the next lower level instead". And that's very much what allows the generic gup code to load the entry once, and use a temporary, and as you walk down the chain, if it is folded it just then uses that (previous) temporary value for the next level instead. IOW, the lower level page table is hidden inside the upper level one, and folding just means "don't do any offsets, don't change any values, just use the entry as-is for the next lower level". So I think that's the right thing to do. Looking at the s390 code, it seems to fold things the other way, conceptually hiding the upper level inside the lower one, and always doing the offset thing (but just avoiding the dereference). Maybe there's some reason why the s390 code does it that way, but I think your new model is the right one, and hopefully means you can use the generic page table walking more easily. Of course, the s390 folding is very different from the x86 one (or the generic fixed 3-level of 4-level cases). The x86 folding doesn't depend on the contents of the page tables, it's just entirely static (well, the 5th level is conditional, but it's conditional on a static key, not on what is in the page tables). So maybe the old model of s390 made more sense in that context, but I look at your new suggested pXd_offset() functions and I go "yeah, that's the way it's supposed to work". Linus