From: Dave Young <dyoung@redhat.com>
To: Andrew Morton <akpm@linux-foundation.org>
Cc: bhe@redhat.com, boris.ostrovsky@oracle.com, bp@alien8.de,
david@redhat.com, hpa@zytor.com, jasowang@redhat.com,
jgross@suse.com, linux-mm@kvack.org, mhocko@suse.com,
mingo@redhat.com, mm-commits@vger.kernel.org, mst@redhat.com,
osalvador@suse.de, rafael.j.wysocki@intel.com, rppt@kernel.org,
sstabellini@kernel.org, tglx@linutronix.de,
torvalds@linux-foundation.org, vgoyal@redhat.com
Subject: Re: [patch 08/87] proc/vmcore: convert oldmem_pfn_is_ram callback to more generic vmcore callbacks
Date: Tue, 9 Nov 2021 11:59:53 +0800 [thread overview]
Message-ID: <YYnyOQ2BkxNAUon1@dhcp-128-65.nay.redhat.com> (raw)
In-Reply-To: <20211109023148.b1OlyuiXG%akpm@linux-foundation.org>
Hi Andrew,
On 11/08/21 at 06:31pm, Andrew Morton wrote:
> From: David Hildenbrand <david@redhat.com>
> Subject: proc/vmcore: convert oldmem_pfn_is_ram callback to more generic vmcore callbacks
>
> Let's support multiple registered callbacks, making sure that registering
> vmcore callbacks cannot fail. Make the callback return a bool instead of
> an int, handling how to deal with errors internally. Drop unused
> HAVE_OLDMEM_PFN_IS_RAM.
>
> We soon want to make use of this infrastructure from other drivers:
> virtio-mem, registering one callback for each virtio-mem device, to
> prevent reading unplugged virtio-mem memory.
>
> Handle it via a generic vmcore_cb structure, prepared for future
> extensions: for example, once we support virtio-mem on s390x where the
> vmcore is completely constructed in the second kernel, we want to detect
> and add plugged virtio-mem memory ranges to the vmcore in order for them
> to get dumped properly.
>
> Handle corner cases that are unexpected and shouldn't happen in sane
> setups: registering a callback after the vmcore has already been opened
> (warn only) and unregistering a callback after the vmcore has already been
> opened (warn and essentially read only zeroes from that point on).
This is a nice improvement, thanks David. But I did not get time to
review it yet. The overall idea is good, I would prefer to hold on the
patches for some time and waiting for more review.
Sorry for jumping in late.
>
> Link: https://lkml.kernel.org/r/20211005121430.30136-6-david@redhat.com
> Signed-off-by: David Hildenbrand <david@redhat.com>
> Cc: Baoquan He <bhe@redhat.com>
> Cc: Borislav Petkov <bp@alien8.de>
> Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com>
> Cc: Dave Young <dyoung@redhat.com>
> Cc: "H. Peter Anvin" <hpa@zytor.com>
> Cc: Ingo Molnar <mingo@redhat.com>
> Cc: Jason Wang <jasowang@redhat.com>
> Cc: Juergen Gross <jgross@suse.com>
> Cc: "Michael S. Tsirkin" <mst@redhat.com>
> Cc: Michal Hocko <mhocko@suse.com>
> Cc: Mike Rapoport <rppt@kernel.org>
> Cc: Oscar Salvador <osalvador@suse.de>
> Cc: "Rafael J. Wysocki" <rafael.j.wysocki@intel.com>
> Cc: Stefano Stabellini <sstabellini@kernel.org>
> Cc: Thomas Gleixner <tglx@linutronix.de>
> Cc: Vivek Goyal <vgoyal@redhat.com>
> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
> ---
>
> arch/x86/kernel/aperture_64.c | 13 +++-
> arch/x86/xen/mmu_hvm.c | 11 ++-
> fs/proc/vmcore.c | 101 ++++++++++++++++++++++----------
> include/linux/crash_dump.h | 26 +++++++-
> 4 files changed, 112 insertions(+), 39 deletions(-)
>
> --- a/arch/x86/kernel/aperture_64.c~proc-vmcore-convert-oldmem_pfn_is_ram-callback-to-more-generic-vmcore-callbacks
> +++ a/arch/x86/kernel/aperture_64.c
> @@ -73,12 +73,23 @@ static int gart_mem_pfn_is_ram(unsigned
> (pfn >= aperture_pfn_start + aperture_page_count));
> }
>
> +#ifdef CONFIG_PROC_VMCORE
> +static bool gart_oldmem_pfn_is_ram(struct vmcore_cb *cb, unsigned long pfn)
> +{
> + return !!gart_mem_pfn_is_ram(pfn);
> +}
> +
> +static struct vmcore_cb gart_vmcore_cb = {
> + .pfn_is_ram = gart_oldmem_pfn_is_ram,
> +};
> +#endif
> +
> static void __init exclude_from_core(u64 aper_base, u32 aper_order)
> {
> aperture_pfn_start = aper_base >> PAGE_SHIFT;
> aperture_page_count = (32 * 1024 * 1024) << aper_order >> PAGE_SHIFT;
> #ifdef CONFIG_PROC_VMCORE
> - WARN_ON(register_oldmem_pfn_is_ram(&gart_mem_pfn_is_ram));
> + register_vmcore_cb(&gart_vmcore_cb);
> #endif
> #ifdef CONFIG_PROC_KCORE
> WARN_ON(register_mem_pfn_is_ram(&gart_mem_pfn_is_ram));
> --- a/arch/x86/xen/mmu_hvm.c~proc-vmcore-convert-oldmem_pfn_is_ram-callback-to-more-generic-vmcore-callbacks
> +++ a/arch/x86/xen/mmu_hvm.c
> @@ -12,10 +12,10 @@
> * The kdump kernel has to check whether a pfn of the crashed kernel
> * was a ballooned page. vmcore is using this function to decide
> * whether to access a pfn of the crashed kernel.
> - * Returns 0 if the pfn is not backed by a RAM page, the caller may
> + * Returns "false" if the pfn is not backed by a RAM page, the caller may
> * handle the pfn special in this case.
> */
> -static int xen_oldmem_pfn_is_ram(unsigned long pfn)
> +static bool xen_vmcore_pfn_is_ram(struct vmcore_cb *cb, unsigned long pfn)
> {
> struct xen_hvm_get_mem_type a = {
> .domid = DOMID_SELF,
> @@ -24,10 +24,13 @@ static int xen_oldmem_pfn_is_ram(unsigne
>
> if (HYPERVISOR_hvm_op(HVMOP_get_mem_type, &a)) {
> pr_warn_once("Unexpected HVMOP_get_mem_type failure\n");
> - return -ENXIO;
> + return true;
> }
> return a.mem_type != HVMMEM_mmio_dm;
> }
> +static struct vmcore_cb xen_vmcore_cb = {
> + .pfn_is_ram = xen_vmcore_pfn_is_ram,
> +};
> #endif
>
> static void xen_hvm_exit_mmap(struct mm_struct *mm)
> @@ -61,6 +64,6 @@ void __init xen_hvm_init_mmu_ops(void)
> if (is_pagetable_dying_supported())
> pv_ops.mmu.exit_mmap = xen_hvm_exit_mmap;
> #ifdef CONFIG_PROC_VMCORE
> - WARN_ON(register_oldmem_pfn_is_ram(&xen_oldmem_pfn_is_ram));
> + register_vmcore_cb(&xen_vmcore_cb);
> #endif
> }
> --- a/fs/proc/vmcore.c~proc-vmcore-convert-oldmem_pfn_is_ram-callback-to-more-generic-vmcore-callbacks
> +++ a/fs/proc/vmcore.c
> @@ -62,46 +62,75 @@ core_param(novmcoredd, vmcoredd_disabled
> /* Device Dump Size */
> static size_t vmcoredd_orig_sz;
>
> -/*
> - * Returns > 0 for RAM pages, 0 for non-RAM pages, < 0 on error
> - * The called function has to take care of module refcounting.
> - */
> -static int (*oldmem_pfn_is_ram)(unsigned long pfn);
> -
> -int register_oldmem_pfn_is_ram(int (*fn)(unsigned long pfn))
> -{
> - if (oldmem_pfn_is_ram)
> - return -EBUSY;
> - oldmem_pfn_is_ram = fn;
> - return 0;
> +static DECLARE_RWSEM(vmcore_cb_rwsem);
> +/* List of registered vmcore callbacks. */
> +static LIST_HEAD(vmcore_cb_list);
> +/* Whether we had a surprise unregistration of a callback. */
> +static bool vmcore_cb_unstable;
> +/* Whether the vmcore has been opened once. */
> +static bool vmcore_opened;
> +
> +void register_vmcore_cb(struct vmcore_cb *cb)
> +{
> + down_write(&vmcore_cb_rwsem);
> + INIT_LIST_HEAD(&cb->next);
> + list_add_tail(&cb->next, &vmcore_cb_list);
> + /*
> + * Registering a vmcore callback after the vmcore was opened is
> + * very unusual (e.g., manual driver loading).
> + */
> + if (vmcore_opened)
> + pr_warn_once("Unexpected vmcore callback registration\n");
> + up_write(&vmcore_cb_rwsem);
> }
> -EXPORT_SYMBOL_GPL(register_oldmem_pfn_is_ram);
> +EXPORT_SYMBOL_GPL(register_vmcore_cb);
>
> -void unregister_oldmem_pfn_is_ram(void)
> +void unregister_vmcore_cb(struct vmcore_cb *cb)
> {
> - oldmem_pfn_is_ram = NULL;
> - wmb();
> + down_write(&vmcore_cb_rwsem);
> + list_del(&cb->next);
> + /*
> + * Unregistering a vmcore callback after the vmcore was opened is
> + * very unusual (e.g., forced driver removal), but we cannot stop
> + * unregistering.
> + */
> + if (vmcore_opened) {
> + pr_warn_once("Unexpected vmcore callback unregistration\n");
> + vmcore_cb_unstable = true;
> + }
> + up_write(&vmcore_cb_rwsem);
> }
> -EXPORT_SYMBOL_GPL(unregister_oldmem_pfn_is_ram);
> +EXPORT_SYMBOL_GPL(unregister_vmcore_cb);
>
> static bool pfn_is_ram(unsigned long pfn)
> {
> - int (*fn)(unsigned long pfn);
> - /* pfn is ram unless fn() checks pagetype */
> + struct vmcore_cb *cb;
> bool ret = true;
>
> - /*
> - * Ask hypervisor if the pfn is really ram.
> - * A ballooned page contains no data and reading from such a page
> - * will cause high load in the hypervisor.
> - */
> - fn = oldmem_pfn_is_ram;
> - if (fn)
> - ret = !!fn(pfn);
> + lockdep_assert_held_read(&vmcore_cb_rwsem);
> + if (unlikely(vmcore_cb_unstable))
> + return false;
> +
> + list_for_each_entry(cb, &vmcore_cb_list, next) {
> + if (unlikely(!cb->pfn_is_ram))
> + continue;
> + ret = cb->pfn_is_ram(cb, pfn);
> + if (!ret)
> + break;
> + }
>
> return ret;
> }
>
> +static int open_vmcore(struct inode *inode, struct file *file)
> +{
> + down_read(&vmcore_cb_rwsem);
> + vmcore_opened = true;
> + up_read(&vmcore_cb_rwsem);
> +
> + return 0;
> +}
> +
> /* Reads a page from the oldmem device from given offset. */
> ssize_t read_from_oldmem(char *buf, size_t count,
> u64 *ppos, int userbuf,
> @@ -117,6 +146,7 @@ ssize_t read_from_oldmem(char *buf, size
> offset = (unsigned long)(*ppos % PAGE_SIZE);
> pfn = (unsigned long)(*ppos / PAGE_SIZE);
>
> + down_read(&vmcore_cb_rwsem);
> do {
> if (count > (PAGE_SIZE - offset))
> nr_bytes = PAGE_SIZE - offset;
> @@ -136,8 +166,10 @@ ssize_t read_from_oldmem(char *buf, size
> tmp = copy_oldmem_page(pfn, buf, nr_bytes,
> offset, userbuf);
>
> - if (tmp < 0)
> + if (tmp < 0) {
> + up_read(&vmcore_cb_rwsem);
> return tmp;
> + }
> }
> *ppos += nr_bytes;
> count -= nr_bytes;
> @@ -147,6 +179,7 @@ ssize_t read_from_oldmem(char *buf, size
> offset = 0;
> } while (count);
>
> + up_read(&vmcore_cb_rwsem);
> return read;
> }
>
> @@ -537,14 +570,19 @@ static int vmcore_remap_oldmem_pfn(struc
> unsigned long from, unsigned long pfn,
> unsigned long size, pgprot_t prot)
> {
> + int ret;
> +
> /*
> * Check if oldmem_pfn_is_ram was registered to avoid
> * looping over all pages without a reason.
> */
> - if (oldmem_pfn_is_ram)
> - return remap_oldmem_pfn_checked(vma, from, pfn, size, prot);
> + down_read(&vmcore_cb_rwsem);
> + if (!list_empty(&vmcore_cb_list) || vmcore_cb_unstable)
> + ret = remap_oldmem_pfn_checked(vma, from, pfn, size, prot);
> else
> - return remap_oldmem_pfn_range(vma, from, pfn, size, prot);
> + ret = remap_oldmem_pfn_range(vma, from, pfn, size, prot);
> + up_read(&vmcore_cb_rwsem);
> + return ret;
> }
>
> static int mmap_vmcore(struct file *file, struct vm_area_struct *vma)
> @@ -668,6 +706,7 @@ static int mmap_vmcore(struct file *file
> #endif
>
> static const struct proc_ops vmcore_proc_ops = {
> + .proc_open = open_vmcore,
> .proc_read = read_vmcore,
> .proc_lseek = default_llseek,
> .proc_mmap = mmap_vmcore,
> --- a/include/linux/crash_dump.h~proc-vmcore-convert-oldmem_pfn_is_ram-callback-to-more-generic-vmcore-callbacks
> +++ a/include/linux/crash_dump.h
> @@ -91,9 +91,29 @@ static inline void vmcore_unusable(void)
> elfcorehdr_addr = ELFCORE_ADDR_ERR;
> }
>
> -#define HAVE_OLDMEM_PFN_IS_RAM 1
> -extern int register_oldmem_pfn_is_ram(int (*fn)(unsigned long pfn));
> -extern void unregister_oldmem_pfn_is_ram(void);
> +/**
> + * struct vmcore_cb - driver callbacks for /proc/vmcore handling
> + * @pfn_is_ram: check whether a PFN really is RAM and should be accessed when
> + * reading the vmcore. Will return "true" if it is RAM or if the
> + * callback cannot tell. If any callback returns "false", it's not
> + * RAM and the page must not be accessed; zeroes should be
> + * indicated in the vmcore instead. For example, a ballooned page
> + * contains no data and reading from such a page will cause high
> + * load in the hypervisor.
> + * @next: List head to manage registered callbacks internally; initialized by
> + * register_vmcore_cb().
> + *
> + * vmcore callbacks allow drivers managing physical memory ranges to
> + * coordinate with vmcore handling code, for example, to prevent accessing
> + * physical memory ranges that should not be accessed when reading the vmcore,
> + * although included in the vmcore header as memory ranges to dump.
> + */
> +struct vmcore_cb {
> + bool (*pfn_is_ram)(struct vmcore_cb *cb, unsigned long pfn);
> + struct list_head next;
> +};
> +extern void register_vmcore_cb(struct vmcore_cb *cb);
> +extern void unregister_vmcore_cb(struct vmcore_cb *cb);
>
> #else /* !CONFIG_CRASH_DUMP */
> static inline bool is_kdump_kernel(void) { return 0; }
> _
>
next prev parent reply other threads:[~2021-11-09 4:01 UTC|newest]
Thread overview: 96+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-11-09 2:30 incoming Andrew Morton
2021-11-09 2:31 ` [patch 01/87] vfs: keep inodes with page cache off the inode shrinker LRU Andrew Morton
2021-11-09 2:31 ` [patch 02/87] mm,hugetlb: remove mlock ulimit for SHM_HUGETLB Andrew Morton
2021-11-09 2:31 ` [patch 03/87] procfs: do not list TID 0 in /proc/<pid>/task Andrew Morton
2021-11-09 2:31 ` [patch 04/87] x86/xen: update xen_oldmem_pfn_is_ram() documentation Andrew Morton
2021-11-09 2:31 ` [patch 05/87] x86/xen: simplify xen_oldmem_pfn_is_ram() Andrew Morton
2021-11-09 2:31 ` [patch 06/87] x86/xen: print a warning when HVMOP_get_mem_type fails Andrew Morton
2021-11-09 2:31 ` [patch 07/87] proc/vmcore: let pfn_is_ram() return a bool Andrew Morton
2021-11-09 2:31 ` [patch 08/87] proc/vmcore: convert oldmem_pfn_is_ram callback to more generic vmcore callbacks Andrew Morton
2021-11-09 3:59 ` Dave Young [this message]
2021-11-09 6:40 ` David Hildenbrand
2021-11-10 7:22 ` Baoquan He
2021-11-10 8:10 ` David Hildenbrand
2021-11-10 11:11 ` Dave Young
2021-11-10 11:21 ` David Hildenbrand
2021-11-10 11:28 ` Dave Young
2021-11-10 12:05 ` David Hildenbrand
2021-11-09 2:31 ` [patch 09/87] virtio-mem: factor out hotplug specifics from virtio_mem_init() into virtio_mem_init_hotplug() Andrew Morton
2021-11-09 2:31 ` [patch 10/87] virtio-mem: factor out hotplug specifics from virtio_mem_probe() " Andrew Morton
2021-11-09 2:31 ` [patch 11/87] virtio-mem: factor out hotplug specifics from virtio_mem_remove() into virtio_mem_deinit_hotplug() Andrew Morton
2021-11-09 2:32 ` [patch 12/87] virtio-mem: kdump mode to sanitize /proc/vmcore access Andrew Morton
2021-11-09 2:32 ` [patch 13/87] proc: allow pid_revalidate() during LOOKUP_RCU Andrew Morton
2021-11-09 2:32 ` [patch 14/87] kernel.h: drop unneeded <linux/kernel.h> inclusion from other headers Andrew Morton
2021-11-09 2:32 ` [patch 15/87] kernel.h: split out container_of() and typeof_member() macros Andrew Morton
2021-11-09 2:32 ` [patch 16/87] include/kunit/test.h: replace kernel.h with the necessary inclusions Andrew Morton
2021-11-09 2:32 ` [patch 17/87] include/linux/list.h: " Andrew Morton
2021-11-09 2:32 ` [patch 18/87] include/linux/llist.h: " Andrew Morton
2021-11-09 2:32 ` [patch 19/87] include/linux/plist.h: " Andrew Morton
2021-11-09 2:32 ` [patch 20/87] include/media/media-entity.h: " Andrew Morton
2021-11-09 2:32 ` [patch 21/87] include/linux/delay.h: " Andrew Morton
2021-11-09 2:32 ` [patch 22/87] include/linux/sbitmap.h: " Andrew Morton
2021-11-09 2:32 ` [patch 23/87] include/linux/radix-tree.h: " Andrew Morton
2021-11-09 2:32 ` [patch 24/87] include/linux/generic-radix-tree.h: " Andrew Morton
2021-11-09 2:32 ` [patch 25/87] kernel.h: split out instruction pointer accessors Andrew Morton
2021-11-09 2:32 ` [patch 26/87] linux/container_of.h: switch to static_assert Andrew Morton
2021-11-09 2:32 ` [patch 27/87] mailmap: update email address for Colin King Andrew Morton
2021-11-09 2:32 ` [patch 28/87] MAINTAINERS: add "exec & binfmt" section with myself and Eric Andrew Morton
2021-11-09 2:32 ` [patch 29/87] MAINTAINERS: rectify entry for ARM/TOSHIBA VISCONTI ARCHITECTURE Andrew Morton
2021-11-09 2:32 ` [patch 30/87] MAINTAINERS: rectify entry for HIKEY960 ONBOARD USB GPIO HUB DRIVER Andrew Morton
2021-11-09 2:33 ` [patch 31/87] MAINTAINERS: rectify entry for INTEL KEEM BAY DRM DRIVER Andrew Morton
2021-11-09 2:33 ` [patch 32/87] MAINTAINERS: rectify entry for ALLWINNER HARDWARE SPINLOCK SUPPORT Andrew Morton
2021-11-09 2:33 ` [patch 33/87] lib, stackdepot: check stackdepot handle before accessing slabs Andrew Morton
2021-11-09 2:33 ` [patch 34/87] lib, stackdepot: add helper to print stack entries Andrew Morton
2021-11-09 2:33 ` [patch 35/87] lib, stackdepot: add helper to print stack entries into buffer Andrew Morton
2021-11-09 2:33 ` [patch 36/87] include/linux/string_helpers.h: add linux/string.h for strlen() Andrew Morton
2021-11-09 2:33 ` [patch 37/87] lib: uninline simple_strntoull() as well Andrew Morton
2021-11-09 2:33 ` [patch 38/87] mm/scatterlist: replace the !preemptible warning in sg_miter_stop() Andrew Morton
2021-11-09 2:33 ` [patch 39/87] const_structs.checkpatch: add a few sound ops structs Andrew Morton
2021-11-09 2:33 ` [patch 40/87] checkpatch: improve EXPORT_SYMBOL test for EXPORT_SYMBOL_NS uses Andrew Morton
2021-11-09 2:33 ` [patch 41/87] checkpatch: get default codespell dictionary path from package location Andrew Morton
2021-11-09 2:33 ` [patch 42/87] binfmt_elf: reintroduce using MAP_FIXED_NOREPLACE Andrew Morton
2021-11-09 2:33 ` [patch 43/87] ELF: simplify STACK_ALLOC macro Andrew Morton
2021-11-09 2:33 ` [patch 44/87] kallsyms: remove arch specific text and data check Andrew Morton
2021-11-09 2:33 ` [patch 45/87] kallsyms: fix address-checks for kernel related range Andrew Morton
2021-11-09 2:33 ` [patch 46/87] sections: move and rename core_kernel_data() to is_kernel_core_data() Andrew Morton
2021-11-09 2:33 ` [patch 47/87] sections: move is_kernel_inittext() into sections.h Andrew Morton
2021-11-09 2:33 ` [patch 48/87] x86: mm: rename __is_kernel_text() to is_x86_32_kernel_text() Andrew Morton
2021-11-09 2:34 ` [patch 49/87] sections: provide internal __is_kernel() and __is_kernel_text() helper Andrew Morton
2021-11-09 2:34 ` [patch 50/87] mm: kasan: use is_kernel() helper Andrew Morton
2021-11-09 2:34 ` [patch 51/87] extable: use is_kernel_text() helper Andrew Morton
2021-11-09 2:34 ` [patch 52/87] powerpc/mm: use core_kernel_text() helper Andrew Morton
2021-11-09 2:34 ` [patch 53/87] microblaze: use is_kernel_text() helper Andrew Morton
2021-11-09 2:34 ` [patch 54/87] alpha: " Andrew Morton
2021-11-09 2:34 ` [patch 55/87] ramfs: fix mount source show for ramfs Andrew Morton
2021-11-09 2:34 ` [patch 56/87] init: make unknown command line param message clearer Andrew Morton
2021-11-09 2:34 ` [patch 57/87] coda: avoid NULL pointer dereference from a bad inode Andrew Morton
2021-11-09 2:34 ` [patch 58/87] coda: check for async upcall request using local state Andrew Morton
2021-11-09 2:34 ` [patch 59/87] coda: remove err which no one care Andrew Morton
2021-11-09 2:34 ` [patch 60/87] coda: avoid flagging NULL inodes Andrew Morton
2021-11-09 2:34 ` [patch 61/87] coda: avoid hidden code duplication in rename Andrew Morton
2021-11-09 2:34 ` [patch 62/87] coda: avoid doing bad things on inode type changes during revalidation Andrew Morton
2021-11-09 2:34 ` [patch 63/87] coda: convert from atomic_t to refcount_t on coda_vm_ops->refcnt Andrew Morton
2021-11-09 2:34 ` [patch 64/87] coda: use vmemdup_user to replace the open code Andrew Morton
2021-11-09 2:34 ` [patch 65/87] coda: bump module version to 7.2 Andrew Morton
2021-11-09 2:34 ` [patch 66/87] nilfs2: replace snprintf in show functions with sysfs_emit Andrew Morton
2021-11-09 2:35 ` [patch 67/87] nilfs2: remove filenames from file comments Andrew Morton
2021-11-09 2:35 ` [patch 68/87] hfs/hfsplus: use WARN_ON for sanity check Andrew Morton
2021-11-09 2:35 ` [patch 69/87] crash_dump: fix boolreturn.cocci warning Andrew Morton
2021-11-09 2:35 ` [patch 70/87] crash_dump: remove duplicate include in crash_dump.h Andrew Morton
2021-11-09 2:35 ` [patch 71/87] signal: remove duplicate include in signal.h Andrew Morton
2021-11-09 2:35 ` [patch 72/87] seq_file: move seq_escape() to a header Andrew Morton
2021-11-09 2:35 ` [patch 73/87] seq_file: fix passing wrong private data Andrew Morton
2021-11-09 2:35 ` [patch 74/87] kernel/fork.c: unshare(): use swap() to make code cleaner Andrew Morton
2021-11-09 2:35 ` [patch 75/87] sysv: use BUILD_BUG_ON instead of runtime check Andrew Morton
2021-11-09 2:35 ` [patch 76/87] Documentation/kcov: include types.h in the example Andrew Morton
2021-11-09 2:35 ` [patch 77/87] Documentation/kcov: define `ip' " Andrew Morton
2021-11-09 2:35 ` [patch 78/87] kcov: allocate per-CPU memory on the relevant node Andrew Morton
2021-11-09 2:35 ` [patch 79/87] kcov: avoid enable+disable interrupts if !in_task() Andrew Morton
2021-11-09 2:35 ` [patch 80/87] kcov: replace local_irq_save() with a local_lock_t Andrew Morton
2021-11-09 2:35 ` [patch 81/87] scripts/gdb: handle split debug for vmlinux Andrew Morton
2021-11-09 2:35 ` [patch 82/87] kernel/resource: clean up and optimize iomem_is_exclusive() Andrew Morton
2021-11-09 2:35 ` [patch 83/87] kernel/resource: disallow access to exclusive system RAM regions Andrew Morton
2021-11-09 2:35 ` [patch 84/87] virtio-mem: disallow mapping virtio-mem memory via /dev/mem Andrew Morton
2021-11-09 2:35 ` [patch 85/87] selftests/kselftest/runner/run_one(): allow running non-executable files Andrew Morton
2021-11-09 2:35 ` [patch 86/87] ipc: check checkpoint_restore_ns_capable() to modify C/R proc files Andrew Morton
2021-11-09 2:36 ` [patch 87/87] ipc/ipc_sysctl.c: remove fallback for !CONFIG_PROC_SYSCTL Andrew Morton
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=YYnyOQ2BkxNAUon1@dhcp-128-65.nay.redhat.com \
--to=dyoung@redhat.com \
--cc=akpm@linux-foundation.org \
--cc=bhe@redhat.com \
--cc=boris.ostrovsky@oracle.com \
--cc=bp@alien8.de \
--cc=david@redhat.com \
--cc=hpa@zytor.com \
--cc=jasowang@redhat.com \
--cc=jgross@suse.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=mhocko@suse.com \
--cc=mingo@redhat.com \
--cc=mm-commits@vger.kernel.org \
--cc=mst@redhat.com \
--cc=osalvador@suse.de \
--cc=rafael.j.wysocki@intel.com \
--cc=rppt@kernel.org \
--cc=sstabellini@kernel.org \
--cc=tglx@linutronix.de \
--cc=torvalds@linux-foundation.org \
--cc=vgoyal@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).