On Mon, Feb 26, 2024 at 9:04 PM Ryan Roberts <ryan.roberts@xxxxxxx> wrote: > > On 26/02/2024 08:55, Lance Yang wrote: > > Hey David, > > > > Thanks for your suggestion! > > > > On Mon, Feb 26, 2024 at 4:41 PM David Hildenbrand <david@xxxxxxxxxx> wrote: > >> > > [...] > >>> On Mon, Feb 26, 2024 at 12:00 PM Barry Song <21cnbao@xxxxxxxxx> wrote: > >>> [...] > >>>> On Mon, Feb 26, 2024 at 1:33 AM Lance Yang <ioworker0@xxxxxxxxx> wrote: > >>> [...] > > [...] > >>> +static inline bool pte_range_cont_mapped(pte_t *pte, unsigned long nr) > >>> +{ > >>> + pte_t pte_val; > >>> + unsigned long pfn = pte_pfn(pte); > >>> + for (int i = 0; i < nr; i++) { > >>> + pte_val = ptep_get(pte + i); > >>> + if (pte_none(pte_val) || pte_pfn(pte_val) != (pfn + i)) > >>> + return false; > >>> + } > >>> + return true; > >>> +} > >> > >> I dislike the "cont mapped" terminology. > >> > >> Maybe folio_pte_batch() does what you want? > > > > folio_pte_batch() is a good choice. Appreciate it! > > Agreed, folio_pte_batch() is likely to be widely useful for this change and > others, so suggest exporting it from memory.c and reusing as is if possible. Thanks for your suggestion. I'll use folio_pte_batch() in v2. Best, Lance > > > > > Best, > > Lance > > > >> > >> -- > >> Cheers, > >> > >> David / dhildenb > >> >