memory core dump because of startup using pmem as mem mode on AEP

qemu-system-x86_64 -s -M pc,accel=kvm,nvdimm -kernel ./build/arch/x86_64/boot/bzImage -nographic -append “console=ttyS0” -initrd ../initramfs/initramfs-busybox-x86_64.cpio.gz

[    0.000000][    T0] Linux version 5.12.0-rc3+ ([email protected]) (gcc (GCC) 8.3.1 20191121 (Red Hat 8.3.1-5), GNU ld version 2.30-79.el8) #1 SMP Thu Mar 18 18:36:36 CST 2021
[    0.000000][    T0] Command line: console=ttyS0
[    0.000000][    T0] x86/fpu: x87 FPU will use FXSAVE
[    0.000000][    T0] BIOS-provided physical RAM map:
[    0.000000][    T0] BIOS-e820: [mem 0x0000000000000000-0x000000000009fbff] usable
[    0.000000][    T0] BIOS-e820: [mem 0x000000000009fc00-0x000000000009ffff] reserved
[    0.000000][    T0] BIOS-e820: [mem 0x00000000000f0000-0x00000000000fffff] reserved
[    0.000000][    T0] BIOS-e820: [mem 0x0000000000100000-0x0000000007fdffff] usable
[    0.000000][    T0] BIOS-e820: [mem 0x0000000007fe0000-0x0000000007ffffff] reserved
[    0.000000][    T0] BIOS-e820: [mem 0x00000000feffc000-0x00000000feffffff] reserved
[    0.000000][    T0] BIOS-e820: [mem 0x00000000fffc0000-0x00000000ffffffff] reserved
[    0.000000][    T0] NX (Execute Disable) protection: active
[    0.000000][    T0] SMBIOS 2.8 present.
[    0.000000][    T0] DMI: QEMU Standard PC (i440FX + PIIX, 1996), BIOS rel-1.14.0-0-g155821a1990b-prebuilt.qemu.org 04/01/2014
[    0.000000][    T0] tsc: Fast TSC calibration using PIT
[    0.000000][    T0] tsc: Detected 2600.179 MHz processor
[    0.001604][    T0] last_pfn = 0x7fe0 max_arch_pfn = 0x400000000
[    0.001639][    T0] x86/PAT: PAT not supported by the CPU.
[    0.001648][    T0] x86/PAT: Configuration [0-7]: WB  WT  UC- UC  WB  WT  UC- UC
[    0.009638][    T0] found SMP MP-table at [mem 0x000f5ab0-0x000f5abf]
[    0.009698][    T0] check: Scanning 1 areas for low memory corruption
[    0.011523][    T0] RAMDISK: [mem 0x07ef9000-0x07fdffff]
[    0.011541][    T0] ACPI: Early table checksum verification disabled
[    0.011557][    T0] ACPI: RSDP 0x00000000000F58D0 000014 (v00 BOCHS )
[    0.011566][    T0] ACPI: RSDT 0x0000000007FE1564 000034 (v01 BOCHS  BXPCRSDT 00000001 BXPC 00000001)
[    0.011579][    T0] ACPI: FACP 0x0000000007FE1418 000074 (v01 BOCHS  BXPCFACP 00000001 BXPC 00000001)
[    0.011592][    T0] ACPI: DSDT 0x0000000007FE0040 0013D8 (v01 BOCHS  BXPCDSDT 00000001 BXPC 00000001)
[    0.011601][    T0] ACPI: FACS 0x0000000007FE0000 000040
[    0.011609][    T0] ACPI: APIC 0x0000000007FE148C 000078 (v01 BOCHS  BXPCAPIC 00000001 BXPC 00000001)
[    0.011618][    T0] ACPI: HPET 0x0000000007FE1504 000038 (v01 BOCHS  BXPCHPET 00000001 BXPC 00000001)
[    0.011627][    T0] ACPI: WAET 0x0000000007FE153C 000028 (v01 BOCHS  BXPCWAET 00000001 BXPC 00000001)
[    0.012175][    T0] No NUMA configuration found
[    0.012181][    T0] Faking a node at [mem 0x0000000000000000-0x0000000007fdffff]
[    0.012198][    T0] NODE_DATA(0) allocated [mem 0x07ef5000-0x07ef8fff]
[    0.012735][    T0] Zone ranges:
[    0.012741][    T0]   DMA      [mem 0x0000000000001000-0x0000000000ffffff]
[    0.012747][    T0]   DMA32    [mem 0x0000000001000000-0x0000000007fdffff]
[    0.012751][    T0]   Normal   empty
[    0.012755][    T0] Movable zone start for each node
[    0.012758][    T0] Early memory node ranges
[    0.012761][    T0]   node   0: [mem 0x0000000000001000-0x000000000009efff]
[    0.012766][    T0]   node   0: [mem 0x0000000000100000-0x0000000007fdffff]
[    0.012771][    T0] Initmem setup node 0 [mem 0x0000000000001000-0x0000000007fdffff]
[    0.015616][    T0]   DMA zone: 28770 pages in unavailable ranges
[    0.017312][    T0]   DMA32 zone: 32 pages in unavailable ranges
[    0.026940][    T0] kasan: KernelAddressSanitizer initialized
[    0.027186][    T0] ACPI: PM-Timer IO Port: 0x608
[    0.027201][    T0] ACPI: LAPIC_NMI (acpi_id[0xff] dfl dfl lint[0x1])
[    0.027239][    T0] IOAPIC[0]: apic_id 0, version 17, address 0xfec00000, GSI 0-23
[    0.027247][    T0] ACPI: INT_SRC_OVR (bus 0 bus_irq 0 global_irq 2 dfl dfl)
[    0.027252][    T0] ACPI: INT_SRC_OVR (bus 0 bus_irq 5 global_irq 5 high level)
[    0.027256][    T0] ACPI: INT_SRC_OVR (bus 0 bus_irq 9 global_irq 9 high level)
[    0.027264][    T0] ACPI: INT_SRC_OVR (bus 0 bus_irq 10 global_irq 10 high level)
[    0.027269][    T0] ACPI: INT_SRC_OVR (bus 0 bus_irq 11 global_irq 11 high level)
[    0.027286][    T0] Using ACPI (MADT) for SMP configuration information
[    0.027290][    T0] ACPI: HPET id: 0x8086a201 base: 0xfed00000
[    0.027300][    T0] smpboot: Allowing 1 CPUs, 0 hotplug CPUs
[    0.027336][    T0] PM: hibernation: Registered nosave memory: [mem 0x00000000-0x00000fff]
[    0.027343][    T0] PM: hibernation: Registered nosave memory: [mem 0x0009f000-0x0009ffff]
[    0.027346][    T0] PM: hibernation: Registered nosave memory: [mem 0x000a0000-0x000effff]
[    0.027350][    T0] PM: hibernation: Registered nosave memory: [mem 0x000f0000-0x000fffff]
[    0.027356][    T0] [mem 0x08000000-0xfeffbfff] available for PCI devices
[    0.027365][    T0] clocksource: refined-jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 1910969940391419 ns
[    0.039488][    T0] setup_percpu: NR_CPUS:64 nr_cpumask_bits:64 nr_cpu_ids:1 nr_node_ids:1
[    0.040176][    T0] percpu: Embedded 60 pages/cpu s207640 r8192 d29928 u2097152
[    0.040295][    T0] Built 1 zonelists, mobility grouping on.  Total pages: 32105
[    0.040300][    T0] Policy zone: DMA32
[    0.040304][    T0] Kernel command line: console=ttyS0
[    0.040408][    T0] Dentry cache hash table entries: 16384 (order: 5, 131072 bytes, linear)
[    0.040427][    T0] Inode-cache hash table entries: 8192 (order: 4, 65536 bytes, linear)
[    0.040765][    T0] mem auto-init: stack:off, heap alloc:off, heap free:off
[    0.049354][    T0] Memory: 33328K/130552K available (22542K kernel code, 8150K rwdata, 7336K rodata, 1592K init, 7944K bss, 96968K reserved, 0K cma-reserved)
[    0.050469][    T0] SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=1, Nodes=1
[    0.050475][    T0] kmemleak: Kernel memory leak detector disabled
[    0.053361][    T0] ODEBUG: selftest passed
[    0.053398][    T0] Kernel/User page tables isolation: enabled
[    0.056143][    T0] rcu: Hierarchical RCU implementation.
[    0.056147][    T0] rcu:     RCU event tracing is enabled.
[    0.056150][    T0] rcu:     RCU restricting CPUs from NR_CPUS=64 to nr_cpu_ids=1.
[    0.056154][    T0] rcu:     RCU callback double-/use-after-free debug enabled.
[    0.056161][    T0] rcu: RCU calculated value of scheduler-enlistment delay is 100 jiffies.
[    0.056164][    T0] rcu: Adjusting geometry for rcu_fanout_leaf=16, nr_cpu_ids=1
[    0.090495][    T0] NR_IRQS: 4352, nr_irqs: 256, preallocated irqs: 16
[    0.091055][    T0] kfence: initialized - using 2097152 bytes for 255 objects at 0x(____ptrval____)-0x(____ptrval____)
[    0.091137][    T0] random: get_random_bytes called from start_kernel+0x1d6/0x394 with crng_init=0
[    0.094413][    T0] Console: colour VGA+ 80x25
[    0.148734][    T0] printk: console [ttyS0] enabled
[    0.149246][    T0] ACPI: Core revision 20210105
[    0.150207][    T0] clocksource: hpet: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604467 ns
[    0.151197][    T0] APIC: Switch to symmetric I/O mode setup
[    0.153304][    T0] ..TIMER: vector=0x30 apic1=0 pin1=2 apic2=-1 pin2=-1
[    0.158164][    T0] clocksource: tsc-early: mask: 0xffffffffffffffff max_cycles: 0x257ae5433b3, max_idle_ns: 440795258831 ns
[    0.159203][    T0] Calibrating delay loop (skipped), value calculated using timer frequency.. 5200.35 BogoMIPS (lpj=2600179)
[    0.160204][    T0] pid_max: default: 32768 minimum: 301
[    0.160887][    T0] LSM: Security Framework initializing
[    0.161284][    T0] SELinux:  Initializing.
[    0.161945][    T0] Mount-cache hash table entries: 512 (order: 0, 4096 bytes, linear)
[    0.162205][    T0] Mountpoint-cache hash table entries: 512 (order: 0, 4096 bytes, linear)
[    0.165776][    T0] Last level iTLB entries: 4KB 0, 2MB 0, 4MB 0
[    0.166205][    T0] Last level dTLB entries: 4KB 0, 2MB 0, 4MB 0, 1GB 0
[    0.166807][    T0] Spectre V1 : Mitigation: usercopy/swapgs barriers and __user pointer sanitization
[    0.167202][    T0] Spectre V2 : Mitigation: Full generic retpoline
[    0.168201][    T0] Spectre V2 : Spectre v2 / SpectreRSB mitigation: Filling RSB on context switch
[    0.169201][    T0] Speculative Store Bypass: Vulnerable
[    0.169685][    T0] MDS: Vulnerable: Clear CPU buffers attempted, no microcode
[    0.182755][    T0] debug: unmapping init [mem 0xffffffff93633000-0xffffffff9363cfff]
[    0.285865][    T1] smpboot: CPU0: Intel QEMU Virtual CPU version 2.5+ (family: 0x6, model: 0x6, stepping: 0x3)
[    0.287415][    T1] Performance Events: PMU not available due to virtualization, using software events only.
[    0.288371][    T1] rcu: Hierarchical SRCU implementation.
[    0.293391][    T1] smp: Bringing up secondary CPUs ...
[    0.293874][    T1] smp: Brought up 1 node, 1 CPU
[    0.294203][    T1] smpboot: Max logical packages: 1
[    0.294657][    T1] smpboot: Total of 1 processors activated (5200.35 BogoMIPS)
[    0.296333][    T1] devtmpfs: initialized
[    0.310055][    T1] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 1911260446275000 ns
[    0.310207][    T1] futex hash table entries: 256 (order: 2, 16384 bytes, linear)
[    0.311605][    T1] PM: RTC time: 21:08:42, date: 2021-03-18
[    0.313572][    T1] NET: Registered protocol family 16
[    0.315826][    T1] audit: initializing netlink subsys (disabled)
[    0.318502][    T1] thermal_sys: Registered thermal governor 'step_wise'
[    0.318505][    T1] thermal_sys: Registered thermal governor 'user_space'
[    0.319221][    T1] cpuidle: using governor menu
[    0.320242][   T17] audit: type=2000 audit(1616101722.164:1): state=initialized audit_enabled=0 res=1
[    0.321321][    T1] ACPI: bus type PCI registered
[    0.322582][    T1] PCI: Using configuration type 1 for base access
[    0.397427][    T1] Kprobes globally optimized
[    0.398504][    T1] HugeTLB registered 2.00 MiB page size, pre-allocated 0 pages
[    0.399621][   T21] cryptomgr_test (21) used greatest stack depth: 30688 bytes left
[    0.400938][   T26] cryptomgr_test (26) used greatest stack depth: 30464 bytes left
[    0.404879][    T1] ACPI: Added _OSI(Module Device)
[    0.405454][    T1] ACPI: Added _OSI(Processor Device)
[    0.405938][    T1] ACPI: Added _OSI(3.0 _SCP Extensions)
[    0.406202][    T1] ACPI: Added _OSI(Processor Aggregator Device)
[    0.406773][    T1] ACPI: Added _OSI(Linux-Dell-Video)
[    0.407224][    T1] ACPI: Added _OSI(Linux-Lenovo-NV-HDMI-Audio)
[    0.407770][    T1] ACPI: Added _OSI(Linux-HPI-Hybrid-Graphics)
[    0.468972][    T1] ACPI: 1 ACPI AML tables successfully acquired and loaded
[    0.478573][    T1] ACPI: Interpreter enabled
[    0.479167][    T1] ACPI: (supports S0 S3 S4 S5)
[    0.479202][    T1] ACPI: Using IOAPIC for interrupt routing
[    0.480317][    T1] PCI: Using host bridge windows from ACPI; if necessary, use "pci=nocrs" and report a bug
[    0.483927][    T1] ACPI: Enabled 3 GPEs in block 00 to 0F
[    0.581187][    T1] ACPI: PCI Root Bridge [PCI0] (domain 0000 [bus 00-ff])
[    0.582299][    T1] acpi PNP0A03:00: _OSC: OS supports [ASPM ClockPM Segments MSI HPX-Type3]
[    0.583501][    T1] acpi PNP0A03:00: fail to add MMCONFIG information, can't access extended PCI configuration space under this bridge.
[    0.594945][    T1] PCI host bridge to bus 0000:00
[    0.595217][    T1] pci_bus 0000:00: root bus resource [io  0x0000-0x0cf7 window]
[    0.595891][    T1] pci_bus 0000:00: root bus resource [io  0x0d00-0xffff window]
[    0.596213][    T1] pci_bus 0000:00: root bus resource [mem 0x000a0000-0x000bffff window]
[    0.597216][    T1] pci_bus 0000:00: root bus resource [mem 0x08000000-0xfebfffff window]
[    0.598213][    T1] pci_bus 0000:00: root bus resource [mem 0x100000000-0x17fffffff window]
[    0.598967][    T1] pci_bus 0000:00: root bus resource [bus 00-ff]
[    0.599417][    T1] pci 0000:00:00.0: [8086:1237] type 00 class 0x060000
[    0.603996][    T1] pci 0000:00:01.0: [8086:7000] type 00 class 0x060100
[    0.608062][    T1] pci 0000:00:01.1: [8086:7010] type 00 class 0x010180
[    0.610376][    T1] pci 0000:00:01.1: reg 0x20: [io  0xc040-0xc04f]
[    0.611558][    T1] pci 0000:00:01.1: legacy IDE quirk: reg 0x10: [io  0x01f0-0x01f7]
[    0.612203][    T1] pci 0000:00:01.1: legacy IDE quirk: reg 0x14: [io  0x03f6]
[    0.612834][    T1] pci 0000:00:01.1: legacy IDE quirk: reg 0x18: [io  0x0170-0x0177]
[    0.613202][    T1] pci 0000:00:01.1: legacy IDE quirk: reg 0x1c: [io  0x0376]
[    0.616949][    T1] pci 0000:00:01.3: [8086:7113] type 00 class 0x068000
[    0.617559][    T1] pci 0000:00:01.3: quirk: [io  0x0600-0x063f] claimed by PIIX4 ACPI
[    0.618208][    T1] pci 0000:00:01.3: quirk: [io  0x0700-0x070f] claimed by PIIX4 SMB
[    0.622369][    T1] pci 0000:00:02.0: [1234:1111] type 00 class 0x030000
[    0.623527][    T1] pci 0000:00:02.0: reg 0x10: [mem 0xfd000000-0xfdffffff pref]
[    0.625766][    T1] pci 0000:00:02.0: reg 0x18: [mem 0xfebf0000-0xfebf0fff]
[    0.629793][    T1] pci 0000:00:02.0: reg 0x30: [mem 0xfebe0000-0xfebeffff pref]
[    0.634280][    T1] pci 0000:00:03.0: [8086:100e] type 00 class 0x020000
[    0.635472][    T1] pci 0000:00:03.0: reg 0x10: [mem 0xfebc0000-0xfebdffff]
[    0.636471][    T1] pci 0000:00:03.0: reg 0x14: [io  0xc000-0xc03f]
[    0.640524][    T1] pci 0000:00:03.0: reg 0x30: [mem 0xfeb80000-0xfebbffff pref]
[    0.653084][    T1] ACPI: PCI Interrupt Link [LNKA] (IRQs 5 *10 11)
[    0.656265][    T1] ACPI: PCI Interrupt Link [LNKB] (IRQs 5 *10 11)
[    0.659434][    T1] ACPI: PCI Interrupt Link [LNKC] (IRQs 5 10 *11)
[    0.662581][    T1] ACPI: PCI Interrupt Link [LNKD] (IRQs 5 10 *11)
[    0.664165][    T1] ACPI: PCI Interrupt Link [LNKS] (IRQs *9)
[    0.676501][    T1] iommu: Default domain type: Translated
[    0.677439][    T1] pci 0000:00:02.0: vgaarb: setting as boot VGA device
[    0.678060][    T1] pci 0000:00:02.0: vgaarb: VGA device added: decodes=io+mem,owns=io+mem,locks=none
[    0.678203][    T1] pci 0000:00:02.0: vgaarb: bridge control possible
[    0.679202][    T1] vgaarb: loaded
[    0.682697][    T1] SCSI subsystem initialized
[    0.684084][    T1] ACPI: bus type USB registered
[    0.684537][    T1] usbcore: registered new interface driver usbfs
[    0.685373][    T1] usbcore: registered new interface driver hub
[    0.686224][    T1] usbcore: registered new device driver usb
[    0.687125][    T1] pps_core: LinuxPPS API ver. 1 registered
[    0.687202][    T1] pps_core: Software ver. 5.3.6 - Copyright 2005-2007 Rodolfo Giometti <[email protected]>
[    0.688286][    T1] PTP clock support registered
[    0.690383][    T1] Advanced Linux Sound Architecture Driver Initialized.
[    0.693545][    T1] NetLabel: Initializing
[    0.693937][    T1] NetLabel:  domain hash size = 128
[    0.694202][    T1] NetLabel:  protocols = UNLABELED CIPSOv4 CALIPSO
[    0.695290][    T1] NetLabel:  unlabeled traffic allowed by default
[    0.696251][    T1] PCI: Using ACPI for IRQ routing
[    0.697000][    T1] hpet: 3 channels of 0 reserved for per-cpu timers
[    0.697223][    T1] hpet0: at MMIO 0xfed00000, IRQs 2, 8, 0
[    0.697722][    T1] hpet0: 3 comparators, 64-bit 100.000000 MHz counter
[    0.702274][    T1] clocksource: Switched to clocksource tsc-early
[    0.963193][    T1] VFS: Disk quotas dquot_6.6.0
[    1.264038][    T1] VFS: Dquot-cache hash table entries: 512 (order 0, 4096 bytes)
[    1.268139][    T1] pnp: PnP ACPI init
[    1.283315][    T1] pnp: PnP ACPI: found 6 devices
[    1.317444][    T1] clocksource: acpi_pm: mask: 0xffffff max_cycles: 0xffffff, max_idle_ns: 2085701024 ns
[    1.318571][    T1] NET: Registered protocol family 2
[    1.321405][    T1] tcp_listen_portaddr_hash hash table entries: 256 (order: 0, 4096 bytes, linear)
[    1.322297][    T1] TCP established hash table entries: 1024 (order: 1, 8192 bytes, linear)
[    1.323055][    T1] TCP bind hash table entries: 1024 (order: 2, 16384 bytes, linear)
[    1.323755][    T1] TCP: Hash tables configured (established 1024 bind 1024)
[    1.324571][    T1] UDP hash table entries: 256 (order: 1, 8192 bytes, linear)
[    1.325229][    T1] UDP-Lite hash table entries: 256 (order: 1, 8192 bytes, linear)
[    1.326349][    T1] NET: Registered protocol family 1
[    1.327970][    T1] RPC: Registered named UNIX socket transport module.
[    1.328570][    T1] RPC: Registered udp transport module.
[    1.329048][    T1] RPC: Registered tcp transport module.
[    1.329536][    T1] RPC: Registered tcp NFSv4.1 backchannel transport module.
[    1.331648][    T1] pci_bus 0000:00: resource 4 [io  0x0000-0x0cf7 window]
[    1.332267][    T1] pci_bus 0000:00: resource 5 [io  0x0d00-0xffff window]
[    1.332875][    T1] pci_bus 0000:00: resource 6 [mem 0x000a0000-0x000bffff window]
[    1.333550][    T1] pci_bus 0000:00: resource 7 [mem 0x08000000-0xfebfffff window]
[    1.334228][    T1] pci_bus 0000:00: resource 8 [mem 0x100000000-0x17fffffff window]
[    1.335600][    T1] pci 0000:00:01.0: PIIX3: Enabling Passive Release
[    1.336179][    T1] pci 0000:00:00.0: Limiting direct PCI/PCI transfers
[    1.336816][    T1] pci 0000:00:01.0: Activating ISA DMA hang workarounds
[    1.337574][    T1] pci 0000:00:02.0: Video device with shadowed ROM at [mem 0x000c0000-0x000dffff]
[    1.338414][    T1] PCI: CLS 0 bytes, default 64
[    1.339449][    T1] Unpacking initramfs...
[    1.342529][    T1] swapper/0 invoked oom-killer: gfp_mask=0x100cca(GFP_HIGHUSER_MOVABLE), order=0, oom_score_adj=0
[    1.343507][    T1] CPU: 0 PID: 1 Comm: swapper/0 Not tainted 5.12.0-rc3+ #1
[    1.344134][    T1] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS rel-1.14.0-0-g155821a1990b-prebuilt.qemu.org 04/01/2014
[    1.344469][    T1] Call Trace:
[    1.344469][    T1]  dump_stack+0x89/0xb4
[    1.344469][    T1]  dump_header+0x81/0x51e
[    1.344469][    T1]  ? task_will_free_mem+0x1d/0x260
[    1.344469][    T1]  ? blocking_notifier_call_chain+0x23/0xb0
[    1.344469][    T1]  out_of_memory.cold.45+0x41/0xb2
[    1.344469][    T1]  ? oom_killer_disable+0x200/0x200
[    1.344469][    T1]  ? __zone_watermark_ok+0x72/0x1c0
[    1.344469][    T1]  __alloc_pages_slowpath.constprop.122+0xfff/0x10e0
[    1.344469][    T1]  ? warn_alloc+0x120/0x120
[    1.344469][    T1]  ? shmem_reserve_inode+0x1e1/0x210
[    1.344469][    T1]  ? shmem_mknod+0x39/0x110
[    1.344469][    T1]  ? kasan_unpoison+0x38/0x60
[    1.344469][    T1]  __alloc_pages_nodemask+0x3d1/0x400
[    1.344469][    T1]  ? __alloc_pages_slowpath.constprop.122+0x10e0/0x10e0
[    1.344469][    T1]  ? find_first_bit+0x19/0x70
[    1.344469][    T1]  ? offset_il_node+0x4b/0x90
[    1.344469][    T1]  alloc_page_interleave+0xd/0xc0
[    1.344469][    T1]  shmem_alloc_page+0xe7/0x160
[    1.344469][    T1]  ? shmem_free_swap+0x60/0x60
[    1.344469][    T1]  ? percpu_counter_add_batch+0x1f/0xa0
[    1.344469][    T1]  ? percpu_counter_add_batch+0x1f/0xa0
[    1.344469][    T1]  shmem_getpage_gfp.isra.74+0x223/0xd90
[    1.344469][    T1]  ? shmem_swapin_page+0xbf0/0xbf0
[    1.344469][    T1]  ? iov_iter_advance+0xe1/0x650
[    1.344469][    T1]  ? shmem_write_end+0xe0/0x3b0
[    1.344469][    T1]  generic_perform_write+0x1da/0x2e0
[    1.344469][    T1]  ? page_cache_next_miss+0x170/0x170
[    1.344469][    T1]  ? __mnt_drop_write_file+0xd/0x40
[    1.344469][    T1]  ? file_update_time+0x19d/0x210
[    1.344469][    T1]  ? update_time+0x60/0x60
[    1.344469][    T1]  ? generic_write_checks+0x10f/0x1a0
[    1.344469][    T1]  __generic_file_write_iter+0x18c/0x280
[    1.344469][    T1]  generic_file_write_iter+0x72/0xe0
[    1.344469][    T1]  __kernel_write+0x295/0x540
[    1.344469][    T1]  ? do_iter_readv_writev+0x330/0x330
[    1.344469][    T1]  ? preempt_schedule_common+0x29/0x40
[    1.344469][    T1]  ? __cond_resched+0x18/0x20
[    1.344469][    T1]  ? __inode_security_revalidate+0x68/0x80
[    1.344469][    T1]  kernel_write+0x70/0x170
[    1.344469][    T1]  xwrite.constprop.3+0x30/0x63
[    1.344469][    T1]  do_copy+0xf9/0x158
[    1.344469][    T1]  ? xwrite.constprop.3+0x63/0x63
[    1.344469][    T1]  write_buffer+0x30/0x41
[    1.344469][    T1]  flush_buffer+0x33/0x9a
[    1.344469][    T1]  ? initrd_load+0x3a/0x3a
[    1.344469][    T1]  __gunzip+0x366/0x447
[    1.344469][    T1]  ? write_buffer+0x41/0x41
[    1.344469][    T1]  ? bunzip2+0x579/0x579
[    1.344469][    T1]  ? initrd_load+0x3a/0x3a
[    1.344469][    T1]  ? __gunzip+0x447/0x447
[    1.344469][    T1]  gunzip+0xe/0x11
[    1.344469][    T1]  ? initrd_load+0x3a/0x3a
[    1.344469][    T1]  unpack_to_rootfs+0x1e4/0x3a7
[    1.344469][    T1]  ? initrd_load+0x3a/0x3a
[    1.344469][    T1]  ? retain_initrd_param+0x21/0x21
[    1.344469][    T1]  ? wake_up_q+0xd0/0xd0
[    1.344469][    T1]  ? _raw_spin_unlock_irqrestore+0xd/0x20
[    1.344469][    T1]  ? reserve_initrd_mem+0x197/0x197
[    1.344469][    T1]  populate_rootfs+0x92/0x1b0
[    1.344469][    T1]  ? reserve_initrd_mem+0x197/0x197
[    1.344469][    T1]  do_one_initcall+0x84/0x270
[    1.344469][    T1]  ? trace_event_raw_event_initcall_finish+0x130/0x130
[    1.344469][    T1]  ? __wake_up_common+0x200/0x200
[    1.344469][    T1]  ? __kasan_kmalloc+0x97/0xc0
[    1.344469][    T1]  ? __kmalloc+0x153/0x300
[    1.344469][    T1]  kernel_init_freeable+0x27d/0x2d0
[    1.344469][    T1]  ? rest_init+0xb5/0xb5
[    1.344469][    T1]  kernel_init+0x7/0x11b
[    1.344469][    T1]  ? rest_init+0xb5/0xb5
[    1.344469][    T1]  ret_from_fork+0x22/0x30
[    1.375643][    T1] Mem-Info:
[    1.375910][    T1] active_anon:0 inactive_anon:12 isolated_anon:0
[    1.375910][    T1]  active_file:0 inactive_file:0 isolated_file:0
[    1.375910][    T1]  unevictable:0 dirty:0 writeback:0
[    1.375910][    T1]  slab_reclaimable:3200 slab_unreclaimable:3636
[    1.375910][    T1]  mapped:0 shmem:24 pagetables:3 bounce:0
[    1.375910][    T1]  free:962 free_pcp:0 free_cma:0
[    1.378880][    T1] Node 0 active_anon:0kB inactive_anon:48kB active_file:0kB inactive_file:0kB unevictable:0kB isolated(anon):0kB isolated(file):0kB mapped:0kB dirty:0kB writeback:0kB shmem:96kB writeback_tmp:0kB kernel_o
[    1.381005][    T1] Node 0 DMA free:1420kB min:2392kB low:2476kB high:2560kB reserved_highatomic:0KB active_anon:0kB inactive_anon:0kB active_file:0kB inactive_file:0kB unevictable:0kB writepending:0kB present:15992kB manB
[    1.383306][    T1] lowmem_reserve[]: 0 17 17 17
[    1.383729][    T1] Node 0 DMA32 free:2428kB min:2432kB low:2528kB high:2624kB reserved_highatomic:0KB active_anon:0kB inactive_anon:48kB active_file:0kB inactive_file:0kB unevictable:0kB writepending:0kB present:114560kBB
[    1.386036][    T1] lowmem_reserve[]: 0 0 0 0
[    1.386441][    T1] Node 0 DMA: 2*4kB (ME) 2*8kB (UM) 1*16kB (U) 1*32kB (U) 1*64kB (U) 2*128kB (UM) 2*256kB (UM) 1*512kB (M) 0*1024kB 0*2048kB 0*4096kB = 1416kB
[    1.387725][    T1] Node 0 DMA32: 3*4kB (UE) 0*8kB 1*16kB (M) 3*32kB (UME) 2*64kB (UM) 1*128kB (M) 0*256kB 4*512kB (UME) 0*1024kB 0*2048kB 0*4096kB = 2428kB
[    1.388981][    T1] Node 0 hugepages_total=0 hugepages_free=0 hugepages_surp=0 hugepages_size=2048kB
[    1.389789][    T1] 24 total pagecache pages
[    1.390171][    T1] 0 pages in swap cache
[    1.390537][    T1] Swap cache stats: add 0, delete 0, find 0/0
[    1.391059][    T1] Free swap  = 0kB
[    1.391387][    T1] Total swap = 0kB
[    1.391712][    T1] 32638 pages RAM
[    1.392021][    T1] 0 pages HighMem/MovableOnly
[    1.392432][    T1] 24242 pages reserved
[    1.392783][    T1] Unreclaimable slab info:
[    1.393161][    T1] Name                      Used          Total
[    1.393701][    T1] rpc_buffers               19KB         31KB
[    1.394231][    T1] rpc_tasks                  5KB          7KB
[    1.394759][    T1] RAW                        2KB         15KB
[    1.395287][    T1] UDP                        1KB         15KB
[    1.395816][    T1] hugetlbfs_inode_cache          0KB          7KB
[    1.396375][    T1] bio-224                   20KB         22KB
[    1.396905][    T1] bio-160                    1KB          7KB
[    1.397431][    T1] biovec-max               150KB        155KB
[    1.397958][    T1] dmaengine-unmap-2          0KB          4KB
[    1.398488][    T1] audit_buffer               0KB          7KB
[    1.399010][    T1] skbuff_head_cache          6KB         15KB
[    1.399538][    T1] task_delay_info           13KB         18KB
[    1.400061][    T1] proc_dir_entry           120KB        127KB
[    1.400590][    T1] shmem_inode_cache         92KB         92KB
[    1.401113][    T1] kernfs_node_cache       1770KB       1773KB
[    1.401640][    T1] mnt_cache                 12KB         15KB
[    1.402160][    T1] filp                       0KB          7KB
[    1.402691][    T1] names_cache              244KB        248KB
[    1.403223][    T1] avc_node                   3KB          7KB
[    1.403747][    T1] lsm_inode_cache         3437KB       3438KB
[    1.404273][    T1] lsm_file_cache             0KB          3KB
[    1.404800][    T1] nsproxy                    0KB          7KB
[    1.405328][    T1] mm_struct                  1KB         15KB
[    1.405847][    T1] fs_cache                   0KB          4KB
[    1.406375][    T1] files_cache                1KB         15KB
[    1.406903][    T1] signal_cache              45KB         60KB
[    1.407440][    T1] sighand_cache             75KB         90KB
[    1.407960][    T1] task_struct              121KB        170KB
[    1.408494][    T1] cred_jar                  16KB         23KB
[    1.409032][    T1] pid                       16KB         23KB
[    1.409573][    T1] Acpi-Operand             142KB        196KB
[    1.410112][    T1] Acpi-ParseExt              0KB         15KB
[    1.410656][    T1] Acpi-Parse                 0KB         15KB
[    1.411176][    T1] Acpi-State                 0KB         15KB
[    1.411717][    T1] Acpi-Namespace           107KB        113KB
[    1.412247][    T1] numa_policy                0KB          7KB
[    1.412771][    T1] trace_event_file         588KB        591KB
[    1.413297][    T1] ftrace_event_field       1725KB       1726KB
[    1.413831][    T1] pool_workqueue            16KB         30KB
[    1.414361][    T1] vmap_area                  6KB          7KB
[    1.414882][    T1] debug_objects_cache         88KB         90KB
[    1.415432][    T1] kmalloc-8k               120KB        120KB
[    1.415954][    T1] kmalloc-4k               636KB        648KB
[    1.416489][    T1] kmalloc-2k               630KB        660KB
[    1.417009][    T1] kmalloc-1k               528KB        540KB
[    1.417541][    T1] kmalloc-512              249KB        255KB
[    1.418065][    T1] kmalloc-256              236KB        240KB
[    1.418596][    T1] kmalloc-192               51KB         55KB
[    1.419146][    T1] kmalloc-128              114KB        120KB
[    1.419711][    T1] kmalloc-96               142KB        145KB
[    1.420254][    T1] kmalloc-64               467KB        468KB
[    1.420799][    T1] kmalloc-32               265KB        277KB
[    1.421344][    T1] kmalloc-16               193KB        206KB
[    1.421894][    T1] kmalloc-8                248KB        300KB
[    1.422439][    T1] kmem_cache_node           72KB         72KB
[    1.422973][    T1] kmem_cache                90KB         90KB
[    1.423519][    T1] Tasks state (memory values in pages):
[    1.424006][    T1] [  pid  ]   uid  tgid total_vm      rss pgtables_bytes swapents oom_score_adj name
[    1.424846][    T1] Out of memory and no killable processes...
[    1.425383][    T1] Kernel panic - not syncing: System is deadlocked on memory
[    1.426039][    T1] CPU: 0 PID: 1 Comm: swapper/0 Not tainted 5.12.0-rc3+ #1
[    1.426376][    T1] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS rel-1.14.0-0-g155821a1990b-prebuilt.qemu.org 04/01/2014
[    1.426376][    T1] Call Trace:
[    1.426376][    T1]  dump_stack+0x89/0xb4
[    1.426376][    T1]  panic+0x18a/0x389
[    1.426376][    T1]  ? print_oops_end_marker.cold.9+0x10/0x10
[    1.426376][    T1]  ? out_of_memory.cold.45+0x66/0xb2
[    1.426376][    T1]  out_of_memory.cold.45+0x7e/0xb2
[    1.426376][    T1]  ? oom_killer_disable+0x200/0x200
[    1.426376][    T1]  ? __zone_watermark_ok+0x72/0x1c0
[    1.426376][    T1]  __alloc_pages_slowpath.constprop.122+0xfff/0x10e0
[    1.426376][    T1]  ? warn_alloc+0x120/0x120
[    1.426376][    T1]  ? shmem_reserve_inode+0x1e1/0x210
[    1.426376][    T1]  ? shmem_mknod+0x39/0x110
[    1.426376][    T1]  ? kasan_unpoison+0x38/0x60
[    1.426376][    T1]  __alloc_pages_nodemask+0x3d1/0x400
[    1.426376][    T1]  ? __alloc_pages_slowpath.constprop.122+0x10e0/0x10e0
[    1.426376][    T1]  ? find_first_bit+0x19/0x70
[    1.426376][    T1]  ? offset_il_node+0x4b/0x90
[    1.426376][    T1]  alloc_page_interleave+0xd/0xc0
[    1.426376][    T1]  shmem_alloc_page+0xe7/0x160
[    1.426376][    T1]  ? shmem_free_swap+0x60/0x60
[    1.426376][    T1]  ? percpu_counter_add_batch+0x1f/0xa0
[    1.426376][    T1]  ? percpu_counter_add_batch+0x1f/0xa0
[    1.426376][    T1]  shmem_getpage_gfp.isra.74+0x223/0xd90
[    1.426376][    T1]  ? shmem_swapin_page+0xbf0/0xbf0
[    1.426376][    T1]  ? iov_iter_advance+0xe1/0x650
[    1.426376][    T1]  ? shmem_write_end+0xe0/0x3b0
[    1.426376][    T1]  generic_perform_write+0x1da/0x2e0
[    1.426376][    T1]  ? page_cache_next_miss+0x170/0x170
[    1.426376][    T1]  ? __mnt_drop_write_file+0xd/0x40
[    1.426376][    T1]  ? file_update_time+0x19d/0x210
[    1.426376][    T1]  ? update_time+0x60/0x60
[    1.426376][    T1]  ? generic_write_checks+0x10f/0x1a0
[    1.426376][    T1]  __generic_file_write_iter+0x18c/0x280
[    1.426376][    T1]  generic_file_write_iter+0x72/0xe0
[    1.426376][    T1]  __kernel_write+0x295/0x540
[    1.426376][    T1]  ? do_iter_readv_writev+0x330/0x330
[    1.426376][    T1]  ? preempt_schedule_common+0x29/0x40
[    1.426376][    T1]  ? __cond_resched+0x18/0x20
[    1.426376][    T1]  ? __inode_security_revalidate+0x68/0x80
[    1.426376][    T1]  kernel_write+0x70/0x170
[    1.426376][    T1]  xwrite.constprop.3+0x30/0x63
[    1.426376][    T1]  do_copy+0xf9/0x158
[    1.426376][    T1]  ? xwrite.constprop.3+0x63/0x63
[    1.426376][    T1]  write_buffer+0x30/0x41
[    1.426376][    T1]  flush_buffer+0x33/0x9a
[    1.426376][    T1]  ? initrd_load+0x3a/0x3a
[    1.426376][    T1]  __gunzip+0x366/0x447
[    1.426376][    T1]  ? write_buffer+0x41/0x41
[    1.426376][    T1]  ? bunzip2+0x579/0x579
[    1.426376][    T1]  ? initrd_load+0x3a/0x3a
[    1.426376][    T1]  ? __gunzip+0x447/0x447
[    1.426376][    T1]  gunzip+0xe/0x11
[    1.426376][    T1]  ? initrd_load+0x3a/0x3a
[    1.426376][    T1]  unpack_to_rootfs+0x1e4/0x3a7
[    1.426376][    T1]  ? initrd_load+0x3a/0x3a
[    1.426376][    T1]  ? retain_initrd_param+0x21/0x21
[    1.426376][    T1]  ? wake_up_q+0xd0/0xd0
[    1.426376][    T1]  ? _raw_spin_unlock_irqrestore+0xd/0x20
[    1.426376][    T1]  ? reserve_initrd_mem+0x197/0x197
[    1.426376][    T1]  populate_rootfs+0x92/0x1b0
[    1.426376][    T1]  ? reserve_initrd_mem+0x197/0x197
[    1.426376][    T1]  do_one_initcall+0x84/0x270
[    1.426376][    T1]  ? trace_event_raw_event_initcall_finish+0x130/0x130
[    1.426376][    T1]  ? __wake_up_common+0x200/0x200
[    1.426376][    T1]  ? __kasan_kmalloc+0x97/0xc0
[    1.426376][    T1]  ? __kmalloc+0x153/0x300
[    1.426376][    T1]  kernel_init_freeable+0x27d/0x2d0
[    1.426376][    T1]  ? rest_init+0xb5/0xb5
[    1.426376][    T1]  kernel_init+0x7/0x11b
[    1.426376][    T1]  ? rest_init+0xb5/0xb5
[    1.426376][    T1]  ret_from_fork+0x22/0x30
[    1.426376][    T1] ---[ end Kernel panic - not syncing: System is deadlocked on memory ]---


kinda wield. this let me unable to start a single kvm program to debug.

Proposal for *A online systematic scheduling algorithm over Distributed IO Systems.*

In the resource allocation problem in the Distributed Systems under the High Performance Computer, we don’t really know which device like disk, NIC (network interface) is more likely to be worn, or not currently on duty which may trigger delaying a while to get the data ready. The current solution is random or round robin scheduling algorithm in avoidance of wearing and dynamic routing for fastest speed. We can utilize the data collected to make it automatic.

Matured system administrator may know the pattern of the parameter to tweak like stride on the distributed File Systems, network MTUs for Infiniband card and the route to fetch the data. Currently, eBPF(extended Berkeley Packets Filter) can store those information like the IO latency on the storage node, network latency over the topology into the time series data. We can use these data to predict which topology and stride and other parameter may be the best way to seek data.

The data is online, and the prediction function can be online reinforce learning. Just like k-arm bandit, the reward can be the function of latency gains and device wearing parameter. The update data can be the real time latency for disks and networks. The information that gives to the RL bots can be where the data locate on disks, which data sought more frequently (DBMS query or random small files) and what frequency the disk make fail.

Benchmarks and evaluation can be the statistical gain of our systems latency and the overall disk wearing after the stress tests.

近纲写的几篇文章

以士绅阶层变动论中美贸易战是否是“清军入关”
On whether the trade war between China and the U.S. is “the Qing Dynasty’s entry into China” based on the change of the scholar and gentry class

摘要:在历史学研究中,拓扑思维和历史周期率是恒久不变的两种手段,不同时间的不同无非是局部的不同,而在简单的比对中总是有很多谬误,就比如最近甚嚣尘上的“入关学”,即当今的中国是皇太极领导下的大清而美国是当时的大明。本质上是一种否认两者统治思路本质和两者目的的区别的片面推断,这与蓬佩奥所提冷战2.0,将当今中国与上世纪50年代的苏联相提并论如出一撤。我提出一种由士绅阶层变动为导向讨论中华民族统治的本质,从而驳斥“入关学”。

关键词:入关 士绅 拓扑比对 中美格局

士绅阶层广泛存在于中国社会,在古代,中国人没有所谓的家国情怀,而是认同“杨家寨”、“李家帮”所代表的部族,在这个部族中,相对自给自足。为何在历史的任何时代都有如此多的“汉奸”,从经济帐上来看,只是因为在部族中的个体对部族而非家国的效忠。《天朝的崩溃》中提及有人提供粮食给英军,日伪满政府中有大把满人组成的“伪军”,本质上是“琦善卖国说”。从这个意义上来讲,中华民族从来都是部族的个体意志大于集体主义的趋利避害思维。明清以来,“皇权不入乡”与“天高皇帝远”规范了部族的领袖作为承上启下的“传话筒”,百姓只要相信此类人,利益瓜分更加有效率,也能自得其乐。对朝代更替,其实并无想法。
士绅其实指的就是士族和乡绅的结合体。前者是当地的名门望族,后者是通过科举选拔制度留守在当地的读书人,这确保了智囊和财富累积的人才供给,他们的普遍想法决定了中国的思潮走向。这就是精英专政。科举制度、联姻及“轻商”保证了此类人的流动性。这点与林语堂的《吾国与吾民》中后续推演的家国情怀相互佐证。
直至近代,为何孙中山十数次的革命没有成果,却在辛亥革命前后引发了全国性的相应,本质上是保路运动让士绅认清推翻先有政府能让原有政策的既得利益集团的利益能被士绅瓜分。蒋介石下令北伐就能成功,不是因为他是黄埔军校的校长,而是他了解江南财阀的需求,如果他忤逆士绅想抗日的决心,也会被历史所左右。抗日花了十数年,而毛泽东以何一年解放中国成功,他做了推翻先有士绅阶级(土豪),建立了新的,以共产党为领导的工农阶级(无产阶级)所形成的士绅。现在的士绅便是有学识的商人及中国共产党党员。天下以农民起义得政权的人物不多,也就刘邦、朱元璋、李自成、洪秀全及毛润之,如果取得不了士绅的信任,也就数十年光景。
“入关”,在柯娇燕的语境中是指在中央对边境控制的过程中仅扮演一个财富提供商,由江浙的财阀、当地的士绅、女真等少数名族在边境形成转口贸易市场,本质上是中央撒币来维护周边少数民族的稳定。可中央无钱时,养好的肥肉都纷纷起义,这就是皇太极。这不是一种殖民,而是在维系统治的一种手段,而人靠利益联结在了一起。可蛮夷还是蛮夷。
“入关”本身是一个正常的市场行为,如果中央财政拨不出钱就由我来管理。再重建政治制度并建立中央银行重新分配民族之间的关系。满人确实利用了五族之间的克制关系建立了一个稳定的政权,同时边境问题也基本被解决。五胡乱华之后,中华民族的思维是如果你认同中华民族的文化就是中国人,而不是靠血统,这无疑让满人汉化,虽然在传统儒家的观念里,这是夷狄乱了华夏,可也是一种反相同化的过程。
通过拓扑思维来链接清军与当今之中国,明朝与美国,把中国“取代”美国成为世界上最强大的国家这一即将发生的历史事件,表面似是相同,但本质完全不同。
表面上,美国是当今世界文明中心和全球事务主导者,这种支配地位正式当年的大明所拥有的。从文明来看,大明对周边实行的是王道,同为世界中心,郑和对当时认知下的全世界的访问,带去的是和平与繁荣,明成祖希望的是来自“天朝上国”的恩泽,一个超级强国对弱国没有倚强凌弱,没有征服与殖民,却行王道,厚往而博来,此之谓文明。而当今的美国确带来的是杀戮与灾难。1989年美国出兵巴拿马,为的是巴拿马运河的经营权,总统直接入狱40年,他只是拒签1977年巴美签订的1999年所有美军从巴拿马撤走的续签条款。除此之外,朝鲜、越南、伊拉克、阿富汗、叙利亚,不知道有多少国家的人民被美国搞得生灵涂炭、颠沛流离。
文明不是一蹴而就的,200年的岛洲历史和盎格鲁撒克逊人的剥削文化并不能让其在强大科技和军力财力的过程中,看到、思考这么多,美国的精英只能从短暂的历史中寻找答案。
同时,中国不是满清,从民族上,当今的中国更像是汉族专政的大明,无论是对边境的事物上,还是国际事物上,所以从历史周期论讲,中华民族伟大复兴更像是“反清复明”。入关前的清是夷狄,非文明社会,是东北亚的渔猎民族,他们的社会形态是松散的部落,政体上和军事上没有像样的制度和架构,就是原始的奴隶制。明朝初期,他们被朝鲜人奴役,明太祖心软,才放他们在外兴安岭繁衍存续。
从本意上来讲,文明解放军在对待不共戴天的日本战俘和内战俘获国军战俘的人道主义精神,着实值得尊敬。在上世纪中叶的援助非洲,非洲兄弟报之以琼瑶——把中华人民共和国投进了联合国。亚投行的初心虽然是去产能、供给侧及后来地缘政治的考量,却也验证了文明的“你好我好大家好”的思维,与郑和下西洋如出一撤。反观朝鲜战场美军如何面对战俘?水刑。罄竹难书、无所不用其极。
中国的士绅阶级经过了五四的启蒙,文革的苦难,《河殇》的转折,至今,一个强大统一而又全面崛起的中国,正在面对新的“华夷之辨”。「夷狄之人貪而好利,被髮左衽,人面獸心。」,将中国的士绅阶级比做夷狄,着实是华夷错位。入关以后,扬州被屠城、湖广填四川;和平演变之后,南斯拉夫再也无往昔之荣光。士绅阶级在
美国对中国在经济和话语权上的打压来看,很有可能是先把你打趴下再继续贸易,和边民想收到中央的恩惠一样,是一种强盗思维。
从中美贸易战的博弈过程中来看,美国似是国立大势已去的清军,明成祖穿越于努尔哈赤的时代,把清军弄个底朝天。如若将中国和美国和明清的关系易位,是否能满足拓扑比较理论呢?其实还是不全面的,我认为美国做的还不如清军。
回到士绅阶级的论述,清军是如何占领士绅的呢?清军入关时写道:“俺汉人,百敌一,都是有剩;为什么,寡胜众,反易天常?只缘我,不晓得,种族主义;为他人,杀同胞,丧尽天良。”表面上是中国人自己人打自己人,或者映射到现在就是以公知为首的人提倡全盘西化,又有一帮人在走自己的中国特色社会主义道路。在入关以前,皇太极已经取得了边民少数民族的士绅阶级,从而通过利益绑定渗透到边民士绅和江南财阀。彼时新“天下”概念,汉人已经占其治下的多数。通过“剧场国家”理论,皇太极是蒙古大汗,清朝皇帝以及满族首领。中华士绅认同的只是他清朝皇帝的概念,同时又对蒙古人、旗人有所忌惮。已然形成了一个正统王朝的必然条件,通过控制士绅来控制汉人王国。
而美国想在中美贸易战中对中国进行制裁,居然打出了“反共不反中”的口号,他的言下之意是士绅阶级与中国是割裂开的。美国的执政者以蛮夷之姿,全连中国的统治本质都不了解,甚至连皇太极都不如。
至于历史周期论,还是有很多门道的,历史上任何掌权的人都是有头有脑的人,虽然有很大局限性,譬如川普政府之于空一格公,再如我认为当今的中国在重演明的历史。从蓬佩奥对新冷战的定义我感觉就是他们能从自己的历史中找到的比对样本太少,绝非像在中国历史乃至世界历史这个图灵完备的课本中。诚然,现代有更好的统计工具去做各个指标的对应,可中国仍由士绅阶级所决定。明清的历史沙盘纵使推演上千遍,也不及抓住这个本质重要,这也是让如今的士绅看清国际局势,向历史有所借鉴的最好座右铭。

中国内外交困近代史统治者心态变化的缩影
——荣国府的流水账
The Dust of Chinese Modern History

摘要:历史是一个任人打扮的小姑娘,无论现代人如何对历史总结及汇总,总是少不了谬误,以及对谬误的翻案。我不是一个考据的学者,如绝大多数人一样,以史为鉴,唯取一瓢饮。既然中国近代史是中国统治集团内部危机和外部势力的实力博弈过程,明清又有着不同的“超我”、“本我”以及“自我”,我想以一个容国府的视角,窥探明清直至明国的统治者心态及对外部敌对势力的心态变化。

关键词:内外交困 统治者 心态变化 荣国府

在贾府的决策者中,一直存在这三种思想,对应弗洛伊德所提出的“超我”、“本我”以及“自我”。“超我”便是贾夫人死后,贾府中再没有在朝廷中有与之对应荣华富贵的爵位,贾母如何延续荣国府的往日荣光,如何继续给予如刘姥姥等下层人高高在上的目光。活在牢笼中的人是可怜的,容易被无限的财富蒙蔽了双眼,殊不知“白茫茫一片真干净”已在明天,半奴半主王熙凤用往日的威严压迫家中奴隶。“自我”便是实际管理者王熙凤采取利用月钱放高利贷的手段为贾府的庞大开支续命,可贾雨村、贾政等最多只能混上五品官,并不能罩住这个勾当,贾探春尝试过用改革的方法治理,被王夫人五十九回的“还得请一个人打理”给打破了,后来就没了后文,探春也出嫁了,再后来探春就薨了。
索隐派红楼梦学者,如北大校长蔡元培先生认为《明月宝鉴》是一部政治隐喻史。蔡元爬杖生推断书中多次提到的红代表明朝政权,而曹雪芹批阅十载也是在悼红轩,似乎有悼明之意。书中第一回说到空道人改《石头记》为《情僧录》,古人常言,清风明月,比如雍正年间著名的文字狱,清风不识字,何故乱翻书,虽然这就是本身无关政治,但可以看出当时的文人或许会用一些隐晦的词表达自己对时尚的看法,所以风月有可能影射清明两个政权。书中男子都是满人,女子都是汉人。我国古代哲学常以阴阳二字说明一切对待着事物,男女分别对应养阴,石头记第三十一回,湘云说,天是阳,地就是阴,熊为阳,祠为阴,翠绿道主子为阳,奴才为阴。蔡元培认为,由于本书满人为主,汉人为奴才,那么宝玉所说我见到女子便觉清爽,见到男人就觉浊臭逼人,在隐晦的表达作者的复明之意。
如此红楼梦与清朝的关系有所确立。清朝统治者眼里,似也存在这三种思想,“超我”对应清朝的治理方向与水平。想要以后金来正统上位,获得朝代潮流士大夫的赏识,做的却是污蔑明朝成就的勾当,想要以收复台湾复汉官之威仪,以义和团战斗来复天朝上国之威仪,出来混,总是要还的,“本我”之下台湾的收复真的是郑成功运气好,面对荷兰的船坚炮利,当时的舰队只能说旗鼓相当,而非完全碾压,而是占据了天时地利人和。郑成功后人没能发挥他祖宗的才能,被康熙打败了。早在清中早期的统治者面前,国库还算富庶的情况下,他们就知道了西方的科技,只是没能领略这是跨代的差距,可以说是被短暂的成功蒙蔽了眼睛。清朝要巩固的是五族的统一,实话说在嘉庆年间就有农民起义能共进北京城。清朝的文字狱是最猖獗的,也是统治者背后悬梁锥刺股的寒意。
1 贾府的选择及“剧场国家”理论
几乎所有贾府的管理者在府上都是千人千面的。贾母虽然是家中的最后敲板人,可在王熙凤面前就会露出少有的怜爱,在刘姥姥二进大观园的档口,没有体现出高高在上的姿态,虽然认知水平和底层有冲突,可还是喜迎喜送。贾母曾经同样爱惜过贾探春以及李纨等人,她们在凤姐面前还确实是不值一提。凤姐在贾府的丫鬟,其他管理者面前还是体现出一种威严的感觉,同时剥削让她们活得无法喘气,似有点今日的日本“社畜”。王熙凤是在长时间掌握贾府月钱分发实权之后才敢放贷给缺钱的人,对外人的求情,转化为可以量化成钱的交易,徇私枉法。高价购买伪劣产品或者将贪污的钱入在流年账上,分别填补开销过去。好似当今的公司股价一天天的下跌,可是懂的人早就最高价甩卖走人了。如果有什么能占便宜的活,马上截取下来,成为新的谋钱手段。
清朝人不靠皇权而统治汉人,“剧场国家”理论认为满清的皇帝在不同种族人面前都在扮演其对应民族的最高统帅。我们典型的观念面,或者说汉人的史书上,清代的崛起,是北方游牧民族政府南方农耕民族的过程,其本质和五胡乱华、蒙古建立元朝不无差别,这是夷狄乱了华夏。而这本质上也是不对的。从满洲人的角度上看,我从边疆朝贡贸易不能赚到中央财政拨过来的钱,那就和关内的人合伙打劫,一起骗中央财政,可是中央再也拨不出钱的时候,等到边民没有那么有能力的时候就趁火打劫。夺取政权以后,清朝皇帝也是千人千面。他们似在关外就想清楚了这个问题。无论国家、家族抑或公司都需要一个想象共同体来支撑,可以是共同的梦想,可以设计假想敌,也可以对不同人采取不同的洗脑策略。美国当今干的勾当是竖切人群,拔起分成各类少数族裔,从而让每个人相信对政府的维权可以持续,而每个人都成不了气候。
“剧场国家”是顺延明朝对中国的统治的基础上完成对满人、藏人、新疆少数族裔等的统一管理。在更远的边疆,比如当今的西伯利亚贝加尔湖,管理没有那么强有力,但汉人及满人的精神还是在的,只是被沙俄帝国主义的流放犯人的无耻打败了。在边疆以外,清朝采取了与明朝相似的边境贸易策略从而维护松散的繁荣假象。在观看了同好游历海参崴、西伯利亚、蒙古国等地,我感觉清朝显然对其没有有效的控制,连教育都没能在时代的长河中对当地人产生些许的影响。蒙古国的思维完全是沙俄思维,美国的影响也有。在新疆等地,他们的民族向心里没有那么深,在游历土耳其后,我发觉突厥语的典籍和汉文化的完全不一致,突厥人的后裔可以说是表面兄弟他们由他们完整的一套话语体系。我认为剧场国家在对边疆的控制尽如此,更多的是对汉人的威慑,其他三族的管控可以说几乎没有。
贾府在后续逐渐的荒凉我认为并不全是人的慢慢离去,而是,自上而下大家觉得维护这样一个贾府还很昌盛的“剧场”太无聊了,早就失去实权的府上,再能敛财也不过是公家的钱,再能在最后撑足面子做一个贾府的寿宴。慈溪能在最后还想着给自己庆生。“剧场国家”的维护过程与面子无异。
2 商品经济的涌入与早期的资本阶级萌芽
王熙凤的高利贷的存在对应晚清兴盛的钱庄。可问题是这些钱庄做不了现代银行薅羊毛的手段:印钞票。钱庄是不是一个资本主义的集散地呢?是的。可是钱庄的敛财能力还不够,或者说当时的商品经济的发达水平还不足以孕育一个合格的资本主义市场,从而更好的投机。王熙凤的行为,更像是初出茅庐的投机者,借父母的银子玩一玩。商品经济的萌芽实际上在晚明早清的时候就有,红楼梦中的一种碗具就是进口自英吉利。其实当时的货物交换就已然有了,不过只在顶级富豪家才有。
我暑假实习的公司的竞争对手一家股票投资商人Optiver,他们在做宣传的时候就说他们是荷兰大航海时代对他们船上的货物的担保,可见商业文明的发达。在晚清各大银行搜刮了大清的铸币税,随意的在上海发钱投机,说实话就是清晚期受到资本的降维打击。同时也对当时的钱庄有所影响,可以从各大银行相互借钱还钱。说到晚清商人的投机,许多人想到的就是罪恶的资本主义世界里贪婪的商人形象,最容易与经济泡沫、金融海啸联系起来,直观上感觉投机是百害而无一利的。许多人认为投机就是参与一场赌博或者骗局,少数人暴富而多数人破产,所有投机者都试图通过不劳而获暴富,而损失让别人承担,因此堪称是资本主义罪恶性的集中体现。
投机的目的是为了获取超额收益,也就是超过市场整体平均的收益。完美的市场是达到均衡状态的市场,所有卖方都能将出售的商品以均衡价格卖出,而所有买方都能将需求的商品以均衡价格买入,价格完美地由供求决定。在这样的市场上投机收益的期望就是市场平均的收益,这样的市场被称为有效市场(Efficient Market)。有效市场是市场的最佳形态,买卖双方的利益均达到了最大化,资源配置达到了帕累托最优。上世纪二十年代的上海就是这样一个投机的地方。
明清两代的统治者对金融的管控自古以来就很强,北京对江浙财阀的限制永远是从开国时的紧到慢慢松的过程。这种东西就是靠脑子就能玩的很强的,只是到一定程度的投机也会如凤姐一样被一锅端。这种完全靠吸百姓血而生的勾当势必会被当局所处置。
3 五胡乱华与满洲人的关系
明代对抗外族侵袭的方法就是边境贸易,让利一份给边民从而换取和平。中央对边境控制的过程中仅扮演一个财富提供商,由江浙的财阀、当地的士绅、女真等少数名族在边境形成转口贸易市场,本质上是中央撒币来维护周边少数民族的稳定。可中央无钱时,养好的肥肉都纷纷起义,这就是皇太极。这不是一种殖民,而是在维系统治的一种手段,而人靠利益联结在了一起。可蛮夷还是蛮夷。大明在面对两者的联合是没办法翻身的。
清朝治下的旗人和满洲人是完全不一样的概念。旗人指的是跟随大清入关的所有人。其中既有满洲八旗,也有汉军八旗,就是汉人,还有蒙古八旗。“旗人”在政治、经济、社会各方面享有诸多特权。比如,旗人世代不必从事劳动生产,其生活来源全部由国家承担。旗人比民人享有更多的机会做官。旗人只是对应特权阶级,我们可以很清楚的看到曹家是满人也是汉军正白旗人。曹家在文化上变成了满人,汉化的满人。《东华录》中有载,雍正十八年六月,逝祖遗诏下令满人见习,汉族,又有康熙十五年十月议政王大臣等上奏,八旗子弟由于武备危机,事后请将旗下子弟考试生源举人进士暂令停止。也就是说亲弟为了笼络汉人巩固统治,已经下令清廷贵族学习汉族文化。只是到了辛亥革命前后,革命党为了强调民族区别,才把“旗人”和“满洲人”这两个概念混同起来。
近代史中,统治者从来都是想着如何继承前朝的正统性,从来没有崖山之后无中华或者崇祯被入关之后无中华的臆想。统治者从来不会不承认元清两代,至少不会放弃他们所代表的疆域,没有实力的时候至少先买个关子待定,等被对方完全控制的时候再承认也不迟。这种中庸思想在非洲抑或北美都是无法想象的。
4 荣国府的边界以及近代史的边界
荣国府的边界说是荣国府的疆域范围,包括大观园等。荣国府的势力范围并不仅仅局限于此。可以说,荣国府的边界,就是其利用其权力范围可以做到的自救所产生的边界。它的财富染指当地的平民,他的权力被隔壁宁国府的王夫人、邢夫人觊觎。但从荣国府的人来说,我觉得每个人都被压得死死的,无法传奇。每个人形形色色的如出水马桶,能够博眼球的也就无私或者手段阴险,而两者的动态平衡从来都是刀光剑影,没有人能改变现状。从大明郑和的航海时代,中国生产的财富以及白银,以一个朝贡贸易的形式对外输出,然而这一切三世而终。中国只有走出去才能避免内卷,近代史就是缺失在走出去。内部的人不断内卷,从而消磨光了国库,清朝的海禁从罗马教廷礼仪之争开始,只有一口通商。近代史的边界就是大清的疆域。
荣国府在对底层老百姓有公司对下属的威信但没有到士绅对乡民的威信,最大的原因是他们的利益没有挂钩。荣国府与手下及外部的百姓的收入是相反的。可以说荣国府代表队形象就是大清代言人,可是他们用惯了奴婢文化,使惯了尊卑思想,让下层人民群起反抗。
大清的读书人被文字狱给害了,本可以从三纲五常的戒律中退出来的,可是却一步一步的陷入进去。明代的科学之繁盛,常微分方程的解法比牛顿莱布尼茨的解法早了百余年就可怀疑是否是明代徐光启把中国的科学通过马可波罗带回到欧洲的;明晚期的朱明理学,船山学派在清朝都没了传承之人,取而代之的是桐城派这种为自己谋利益的地方学派。这些被清帝毁于一旦。可以说在文化上,清帝只是一个合格的另一个北魏孝文帝,而非使张骞出史开拓贸易的明君。
半封建半殖民地的中国大地,受到最多恩惠的是留美留日的一群人。这是中国所能冲出黎明的一群人。 同时期的还有下南洋的华人,香港、澳门受到见识的人。他们拓展了中国人的智识边界。何奈中国人赔给日本的钱早就让他们获得了这份智识。
5 如果“超我”能实现
如何自救?1840年开始的中国史的疆域,从对口岸的掌握,到对沿海的全部缺失,白银外流,国库空虚,走上了渐衰的国运,内部官员相互竞争剩余的价值。直至义和团的“白茫茫一片真干净”。由于乾隆,嘉庆皇帝的盲目以天朝自居,对外开放贸易限制逐渐变大,导致与世界隔绝,错失发展的良机。如果乾隆皇帝答应对外贸易,开放口岸,清朝会有多少好处,每年可以给清朝带来多少税收与国库收入。如果没有闭关锁国,在正常的情况下可以一分为二的看:一就是成功的进入帝国主义,就像日本一样,发展自身的军事实力,不惧怕列强的侵扰;二就是外因过于强大导致清王朝内部崩溃。可问题是,持这种观点的在儒家文化圈在少数,以致整个国家在面对日本的甲午战争的时候只有李鸿章这个部门能迎击。
而我认为荣国府的颓势是无法通过开放来解决的,就算已经实现了,贾母死了,王熙凤也只能与其他人内耗。这是一个无解的超我盘,大概只有与民同被割韭菜吧,毕竟更强大的权贵能在很多时候高人一等。
6 参考文献
《荣国府的经济账》
《尼加拉:十九世纪巴厘剧场国家》
《红楼梦与中国文化论稿》(胡文彬)
Wikipedia. Chinese Modern History. Wikipedia.org 2020

一个从天而降的方向

昨晚和以前实习的同学讨论一个上界的问题,如果在未来博士的过程中也能有这样的氛围就好了。

主要就是一道概率论题

已知\(\begin{array}{l}A \sim B i n o m(n, p) \ B \sim B i n o m(\frac{A(A-1)} 2, q)\end{array}\),求H(B),即B的entropy。

这里的难点是如何求二项随机分布的二项分布。直观上感觉后者的熵值是前者的 \(log(log())\) 这种。可对A的展开太过繁琐。敲在mathmetica当中可以是 \(P(B=i) = Sum[P(B=i|A=j)*P(A=j),{j,0,n}]\),暂时我只想到这种解法。

这个问题我找了找网络前两节课上的信息论推荐的书,上面有类似对于二项式分布的相关性质,可是唯一提到的也就是在 \(p\) 上做文章。fix n,H(A)的 max 在 p 取 \(\frac12\) 时取到。然而没啥卵用。

概率论与图论背后的算法

算这个事为了做一个算法去recover这个
ER random graph,given每次只能query graph的一小部分里面有没有edge的存在。

这个 random graph 很有名,很多概率图都是基于此。也是 TCS 求 lower bound 的一种方式,很多人梦寐以求的方向。

谈体系结构的进步对网络的影响

最近量子位又发了一篇体系结构的进步,TCAM,所谓的三态内容寻址储存器。可以说,从图灵机的角度来说,上层建筑下的基层还有很多没有解决,从现在那么多Startup 在真正的做业务Oriented 的数据库及网络链路优化,体系结构还有很多可以探索的部分。同时,新的架构真的是否安全,如TPU的数据通路是否有没有被侦测到的部分可以被攻击。多数的攻击来自于软硬结合,汇集了多少工程师的智慧结晶。

交换机的简化结构


这是一个去掉2个要素的冯诺伊曼体系结构图,交换机的OutBound 和Input的Throughput是显见的bottleneck,除此之外还有延时,这就需要主存储器性能或者包的传输协议的革新。

三态内容寻址储存器(TCAM)

我在当年写VB的时候记得有个slide的参数,是一个三进制数来表示不动,向上滑和向下滑的参数。而这种0、-1,1三进制在苏联当年的计算设备上有所尝试,可惜最终失败了。0.5或许是更好的一种表示中间态或者亚稳态的编码方式,可以用于模糊匹配,或者Not Set。

CAM本质上是一个数据查找硬件方法,读写数据的速度与RAM相同,查找数据能相对模糊的匹配到数据。

这时ARP 协议从报头或者CRC来验证数据正确性起到了很大的作用,就是不管怎样,数据到了,不管对不对,以最快的速度发出去,等到了再做检验的思路是一样的。(有点像高频交易架构的gateway。

Reference

  1. Constant-time Alteration Ternary CAM with Scalable In-Memory Architecture
  2. 三态内容寻址存储器(TCAM)工作原理

网络链路层路由算法总结

Routing protocols

  • Routing information protocols(RIP)

    • Algorithm: Distance Vector
  • Open Shortest Path First (OSPF)

    • Algorithm: Link State
  • BorderGatewayProtocol (BGP)

    • Another type of vector Routing: widely used in the AS Protocals
    • demo
    • Problem with integrate wit intra domain Routing

      • static method ALL unknown IPs send to D.
      • Entry Translation: high cost

      • interior BGP

ARP

之前打ctf 的时候搞过这个协议,主要是在MAC 层能对网卡欺骗,从而把destination 当成自己,就能抓取同路由器下的其他设备的包。

这种需要规避就得ip-mac 绑定。

几个Mac层的协议

我校网络老师不太Care 概率模型下的网络分析,只Care 实现。(但是我最近正好在学概率统计,权当一道作业题复习

ALOHA协议

主要思路就是让所有能发的人都发,有错误就随机掷骰子决定发送,如果碰撞,随机范围翻倍再掷骰子。


可问题是,非常容易冲突。

如果我们做一道概率题。

  1. 帧时T:发送一个标准长的帧所需的时间
  2. 吞吐率S:在一个帧时T内发送成功的平均帧数(0<S<1,S=1时信道利用率100%)
  3. 运载负载G:一个帧时T内所有通信站总共发送的帧平均值(包括原发和重发帧)(G≥S,G=S表示无冲突)
  4. P0:一帧发送成功(未发生冲突)的概率,发送成功的分组在已发送分组的总数中所占的比例;公式:S = G*P0

两个标准长的帧才会第二次碰撞,舍冲突危险期为2T,同时设这是的帧平均值为2G一个T内生成k个帧到的概率符泊松分布。

由柏松分布可知:

\(\operatorname{Pr}[\mathrm{k}]=\frac{\mathrm{G}^{\mathrm{k}} \mathrm{e}^{-\mathrm{G}} }{ \mathrm{k} !}\)

\(P(\text{success in 2T})=Pr(0)\times Pr(0)=e^{-2G}\)

带入S= G*P0 得
\(\mathrm{S}=\mathrm{Ge}^{-2 \mathrm{G}}\)

最高信道利用率是18.4%

Time-slotted ALOHA

  1. 分隙ALOHA是把时间分成时隙(时间片),时隙的长度对应一帧的传输时间
  2. 新帧的产生是随机的,但分隙ALOHA不允许随机发送,凡帧的发送必须在时隙的起点
  3. 冲突只发生在时隙的起点,冲突发生时只浪费一个时隙,一旦某个站占用时隙并发送成功,则在该时隙内不会出现冲突

显然刚刚 \(P(\text{success in 2T})=Pr(0)=e^{-G}\), \(S=\mathrm{Ge}^{-2 \mathrm{G}}\)
最高信道利用率是36.8%

CSMA/CD

一种带有冲突检测的载波监听多路访问,可以检测Mac传输的冲突。

主要流程是

  • 以广播发,看看有无其他节点(carrier sense)没有其他包就发包。
  • 检测 carrier detection。 如果碰撞再广播碰撞了。然后掷骰子重新发包
  • 15次失败报告timeout

CSMA/CA

WLAN 中实现不了CSMA/CD 主要原因是有hidden和exposed 的情况。一种不太好的解决方法是RTS-CTS。可这比较容易被攻击。

组里的两个邀请

上上上周和上上上上周,我们迎来了组里的讲座,一个是用DTMC来解释音频的项目。The author XIAONING DU is now in Sydney Tech。另一个是在交大读的研究生,NTU 读的两面本和博。 The author Hongxu Chen

我对前者的直观感受就是,可能这个方向的博士不是很难拿吧,但deepstellar当时还是热点,现在有点凉,但证明能干一些事情了,她趁火拿了好几篇adv和benign。我对后者的感受,很强,我到博士不一定有其水平的一半。

RNN to DTMC


就是一坨统计堆出来的可解释性。
进一步抽象


这里用的公式\(\operatorname{Dist}\left(\hat{s}, \hat{s}^{\prime}\right)=\Sigma_{d=1}^{k}\left|I^{d}(\hat{s})-I^{d}\left(\hat{s}^{\prime}\right)\right|\)

最终的结果

最后用统计做了一堆相似性的bound “证明”,就说RNN聚类抽象出来的state 和DTMC 一一对应。想法很新颖,但其实回头想没什么内涵。

MUZZ

这里 Thread-aware 就很厉害。

相当于独自开个领域


可我事后问了他scalable的问题,他的回答:

go channel不行 java lock 有几个坑 lock threading 不能很准 java分析 fuzzing oracle 异常 jlang 方舟编译器。 scala native不靠谱 动态 gc llvm 不会做 jvm 抽象等级 z一致性 印度 chenhao 学术界。llvm uiuc 
爷 工业界 fuzzing ok2。

他还有几篇

坚定了我去美国找个工位的目标,加油~