/* * jitdump.h: jitted code info encapsulation file format * * Adapted from OProfile GPLv2 support jidump.h: * Copyright 2007 OProfile authors * Jens Wilke * Daniel Hansel * Copyright IBM Corporation 2007 */ #ifndef JITDUMP_H #define JITDUMP_H #include #include #include /* JiTD */ #define JITHEADER_MAGIC 0x4A695444 #define JITHEADER_MAGIC_SW 0x4454694A #define PADDING_8ALIGNED(x) ((((x) + 7) & 7) ^ 7) #define ALIGN_8(x) (((x) + 7) & (~7)) #define JITHEADER_VERSION 1 enum jitdump_flags_bits { JITDUMP_FLAGS_ARCH_TIMESTAMP_BIT, JITDUMP_FLAGS_MAX_BIT, }; #define JITDUMP_FLAGS_ARCH_TIMESTAMP (1ULL << JITDUMP_FLAGS_ARCH_TIMESTAMP_BIT) #define JITDUMP_FLAGS_RESERVED (JITDUMP_FLAGS_MAX_BIT < 64 ? \ (~((1ULL << JITDUMP_FLAGS_MAX_BIT) - 1)) : 0) struct jitheader { uint32_t magic; /* characters "jItD" */ uint32_t version; /* header version */ uint32_t total_size; /* total size of header */ uint32_t elf_mach; /* elf mach target */ uint32_t pad1; /* reserved */ uint32_t pid; /* JIT process id */ uint64_t timestamp; /* timestamp */ uint64_t flags; /* flags */ }; enum jit_record_type { JIT_CODE_LOAD = 0, JIT_CODE_MOVE = 1, JIT_CODE_DEBUG_INFO = 2, JIT_CODE_CLOSE = 3, JIT_CODE_UNWINDING_INFO = 4, JIT_CODE_MAX, }; /* record prefix (mandatory in each record) */ struct jr_prefix { uint32_t id; uint32_t total_size; uint64_t timestamp; }; struct jr_code_load { struct jr_prefix p; uint32_t pid; uint32_t tid; uint64_t vma; uint64_t code_addr; uint64_t code_size; uint64_t code_index; }; struct jr_code_close { struct jr_prefix p; }; struct jr_code_move { struct jr_prefix p; uint32_t pid; uint32_t tid; uint64_t vma; uint64_t old_code_addr; uint64_t new_code_addr; uint64_t code_size; uint64_t code_index; }; struct debug_entry { uint64_t addr; int lineno; /* source line number starting at 1 */ int discrim; /* column discriminator, 0 is default */ const char name[0]; /* null terminated filename, \xff\0 if same as previous entry */ }; struct jr_code_debug_info { struct jr_prefix p; uint64_t code_addr; uint64_t nr_entry; struct debug_entry entries[0]; }; struct jr_code_unwinding_info { struct jr_prefix p; uint64_t unwinding_size; uint64_t eh_frame_hdr_size; uint64_t mapped_size; const char unwinding_data[0]; }; union jr_entry { struct jr_code_debug_info info; struct jr_code_close close; struct jr_code_load load; struct jr_code_move move; struct jr_prefix prefix; struct jr_code_unwinding_info unwinding; }; static inline struct debug_entry * debug_entry_next(struct debug_entry *ent) { void *a = ent + 1; size_t l = strlen(ent->name) + 1; return a + l; } static inline char * debug_entry_file(struct debug_entry *ent) { void *a = ent + 1; return a; } #endif /* !JITDUMP_H */ e>
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2016-12-09 11:27:22 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2016-12-09 11:27:22 -0800
commit810ac7b7558d7830e72d8dbf34b851fce39e08b0 (patch)
tree5c026763a237ab9d7940d83deb9b719fb6247d42 /net/atm/common.h
parent861d75d098e2d0a2d7692c9d6a30b6fd2c81387c (diff)
parent325896ffdf90f7cbd59fb873b7ba20d60d1ddf3c (diff)
Merge branch 'libnvdimm-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm
Pull libnvdimm fixes from Dan Williams: "Several fixes to the DSM (ACPI device specific method) marshaling implementation. I consider these urgent enough to send for 4.9 consideration since they fix the kernel's handling of ARS (Address Range Scrub) commands. Especially for platforms without machine-check-recovery capabilities, successful execution of ARS commands enables the platform to potentially break out of an infinite reboot problem if a media error is present in the boot path. There is also a one line fix for a device-dax read-only mapping regression. Commits 9a901f5495e2 ("acpi, nfit: fix extended status translations for ACPI DSMs") and 325896ffdf90 ("device-dax: fix private mapping restriction, permit read-only") are true regression fixes for changes introduced this cycle. Commit efda1b5d87cb ("acpi, nfit, libnvdimm: fix / harden ars_status output length handling") fixes the kernel's handling of zero-length results, this never would have worked in the past, but we only just recently discovered a BIOS implementation that emits this arguably spec non-compliant result. The remaining two commits are additional fall out from thinking through the implications of a zero / truncated length result of the ARS Status command. In order to mitigate the risk that these changes introduce yet more regressions they are backstopped by a new unit test in commit a7de92dac9f0 ("tools/testing/nvdimm: unit test acpi_nfit_ctl()") that mocks up inputs to acpi_nfit_ctl()" * 'libnvdimm-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm: device-dax: fix private mapping restriction, permit read-only tools/testing/nvdimm: unit test acpi_nfit_ctl() acpi, nfit: fix bus vs dimm confusion in xlat_status acpi, nfit: validate ars_status output buffer size acpi, nfit, libnvdimm: fix / harden ars_status output length handling acpi, nfit: fix extended status translations for ACPI DSMs
Diffstat (limited to 'net/atm/common.h')