1/* 2 * gdb helper commands and functions for Linux kernel debugging 3 * 4 * Kernel constants derived from include files. 5 * 6 * Copyright (c) 2016 Linaro Ltd 7 * 8 * Authors: 9 * Kieran Bingham <kieran.bingham@linaro.org> 10 * 11 * This work is licensed under the terms of the GNU GPL version 2. 12 * 13 */ 14 15#include <linux/clk-provider.h> 16#include <linux/fs.h> 17#include <linux/hrtimer.h> 18#include <linux/irq.h> 19#include <linux/mount.h> 20#include <linux/of_fdt.h> 21#include <linux/page_ext.h> 22#include <linux/radix-tree.h> 23#include <linux/slab.h> 24#include <linux/threads.h> 25#include <linux/vmalloc.h> 26 27/* We need to stringify expanded macros so that they can be parsed */ 28 29#define STRING(x) #x 30#define XSTRING(x) STRING(x) 31 32#define LX_VALUE(x) LX_##x = x 33#define LX_GDBPARSED(x) LX_##x = gdb.parse_and_eval(XSTRING(x)) 34 35/* 36 * IS_ENABLED generates (a || b) which is not compatible with python 37 * We can only switch on configuration items we know are available 38 * Therefore - IS_BUILTIN() is more appropriate 39 */ 40#define LX_CONFIG(x) LX_##x = IS_BUILTIN(x) 41 42/* The build system will take care of deleting everything above this marker */ 43<!-- end-c-headers --> 44 45import gdb 46 47LX_CONFIG(CONFIG_DEBUG_INFO_REDUCED) 48 49/* linux/clk-provider.h */ 50if IS_BUILTIN(CONFIG_COMMON_CLK): 51 LX_GDBPARSED(CLK_GET_RATE_NOCACHE) 52 53/* linux/fs.h */ 54LX_GDBPARSED(SB_RDONLY) 55LX_GDBPARSED(SB_SYNCHRONOUS) 56LX_GDBPARSED(SB_MANDLOCK) 57LX_GDBPARSED(SB_DIRSYNC) 58LX_GDBPARSED(SB_NOATIME) 59LX_GDBPARSED(SB_NODIRATIME) 60 61/* linux/htimer.h */ 62LX_GDBPARSED(hrtimer_resolution) 63 64/* linux/irq.h */ 65LX_GDBPARSED(IRQD_LEVEL) 66LX_GDBPARSED(IRQ_HIDDEN) 67 68/* linux/module.h */ 69if IS_BUILTIN(CONFIG_MODULES): 70 LX_GDBPARSED(MOD_TEXT) 71 LX_GDBPARSED(MOD_DATA) 72 LX_GDBPARSED(MOD_RODATA) 73 LX_GDBPARSED(MOD_RO_AFTER_INIT) 74 75/* linux/mount.h */ 76LX_VALUE(MNT_NOSUID) 77LX_VALUE(MNT_NODEV) 78LX_VALUE(MNT_NOEXEC) 79LX_VALUE(MNT_NOATIME) 80LX_VALUE(MNT_NODIRATIME) 81LX_VALUE(MNT_RELATIME) 82 83/* linux/threads.h */ 84LX_VALUE(NR_CPUS) 85 86/* linux/of_fdt.h> */ 87LX_VALUE(OF_DT_HEADER) 88 89/* linux/radix-tree.h */ 90LX_GDBPARSED(RADIX_TREE_ENTRY_MASK) 91LX_GDBPARSED(RADIX_TREE_INTERNAL_NODE) 92LX_GDBPARSED(RADIX_TREE_MAP_SIZE) 93LX_GDBPARSED(RADIX_TREE_MAP_SHIFT) 94LX_GDBPARSED(RADIX_TREE_MAP_MASK) 95 96/* linux/vmalloc.h */ 97LX_VALUE(VM_IOREMAP) 98LX_VALUE(VM_ALLOC) 99LX_VALUE(VM_MAP) 100LX_VALUE(VM_USERMAP) 101LX_VALUE(VM_DMA_COHERENT) 102 103/* linux/page_ext.h */ 104if IS_BUILTIN(CONFIG_PAGE_OWNER): 105 LX_GDBPARSED(PAGE_EXT_OWNER) 106 LX_GDBPARSED(PAGE_EXT_OWNER_ALLOCATED) 107 108/* linux/slab.h */ 109LX_GDBPARSED(SLAB_RED_ZONE) 110LX_GDBPARSED(SLAB_POISON) 111LX_GDBPARSED(SLAB_KMALLOC) 112LX_GDBPARSED(SLAB_HWCACHE_ALIGN) 113LX_GDBPARSED(SLAB_CACHE_DMA) 114LX_GDBPARSED(SLAB_CACHE_DMA32) 115LX_GDBPARSED(SLAB_STORE_USER) 116LX_GDBPARSED(SLAB_PANIC) 117 118/* Kernel Configs */ 119LX_CONFIG(CONFIG_GENERIC_CLOCKEVENTS) 120LX_CONFIG(CONFIG_GENERIC_CLOCKEVENTS_BROADCAST) 121LX_CONFIG(CONFIG_HIGH_RES_TIMERS) 122LX_CONFIG(CONFIG_NR_CPUS) 123LX_CONFIG(CONFIG_OF) 124LX_CONFIG(CONFIG_TICK_ONESHOT) 125LX_CONFIG(CONFIG_GENERIC_IRQ_SHOW_LEVEL) 126LX_CONFIG(CONFIG_X86_LOCAL_APIC) 127LX_CONFIG(CONFIG_SMP) 128LX_CONFIG(CONFIG_X86_THERMAL_VECTOR) 129LX_CONFIG(CONFIG_X86_MCE_THRESHOLD) 130LX_CONFIG(CONFIG_X86_MCE_AMD) 131LX_CONFIG(CONFIG_X86_MCE) 132LX_CONFIG(CONFIG_X86_IO_APIC) 133/* 134 * CONFIG_KVM can be "m" but it affects common code too. Use CONFIG_KVM_COMMON 135 * as a proxy for IS_ENABLED(CONFIG_KVM). 136 */ 137LX_CONFIG_KVM = IS_BUILTIN(CONFIG_KVM_COMMON) 138LX_CONFIG(CONFIG_NUMA) 139LX_CONFIG(CONFIG_ARM64) 140LX_CONFIG(CONFIG_ARM64_4K_PAGES) 141LX_CONFIG(CONFIG_ARM64_16K_PAGES) 142LX_CONFIG(CONFIG_ARM64_64K_PAGES) 143if IS_BUILTIN(CONFIG_ARM64): 144 LX_VALUE(CONFIG_ARM64_PA_BITS) 145 LX_VALUE(CONFIG_ARM64_VA_BITS) 146 LX_VALUE(CONFIG_PAGE_SHIFT) 147 LX_VALUE(CONFIG_ARCH_FORCE_MAX_ORDER) 148LX_CONFIG(CONFIG_SPARSEMEM) 149LX_CONFIG(CONFIG_SPARSEMEM_EXTREME) 150LX_CONFIG(CONFIG_SPARSEMEM_VMEMMAP) 151LX_CONFIG(CONFIG_KASAN) 152LX_CONFIG(CONFIG_KASAN_GENERIC) 153LX_CONFIG(CONFIG_KASAN_SW_TAGS) 154LX_CONFIG(CONFIG_KASAN_HW_TAGS) 155if IS_BUILTIN(CONFIG_KASAN_GENERIC) or IS_BUILTIN(CONFIG_KASAN_SW_TAGS): 156 LX_VALUE(CONFIG_KASAN_SHADOW_OFFSET) 157LX_CONFIG(CONFIG_VMAP_STACK) 158if IS_BUILTIN(CONFIG_NUMA): 159 LX_VALUE(CONFIG_NODES_SHIFT) 160LX_CONFIG(CONFIG_DEBUG_VIRTUAL) 161LX_CONFIG(CONFIG_STACKDEPOT) 162LX_CONFIG(CONFIG_PAGE_OWNER) 163LX_CONFIG(CONFIG_SLUB_DEBUG) 164LX_CONFIG(CONFIG_SLAB_FREELIST_HARDENED) 165LX_CONFIG(CONFIG_MMU) 166