crash-eppic-7.2.9-150300.23.10.1<>,ĉbp9|d`1S?4?$d # f )J[ q      0Dt  y (8E9E: lEBzGHIXYZ[\]^5bc/defluvwxy Ccrash-eppic7.2.9150300.23.10.1Embeddable Pre-Processor and Interpreter for C extension for crashEPPIC is a C interpreter that permits easy access to the symbol and type information stored in a executable image like a coredump or live memory interfaces (e.g. /dev/kmem, /dev/mem). Although it has a strong association with live or postmortem kernel analysis, it is not constraint to it and can be embedded in any tools that is C friendly. Authors: -------- Luc Chouinard bibs-arm-4SUSE Linux Enterprise 15SUSE LLC GPL-2.0-or-laterhttps://www.suse.com/Development/Tools/Debuggershttps://crash-utility.github.io/linuxaarch64P3!AA큤bkbZbZbZbZ71cf1486a02d7d9fa54ea8fd83f871a77b7e6114590f41ff2c87faaf681ff03d8c86f76ca8811d32b33ddb17eee3f041ff27f8e7addfd1512d6ea2f4b8aaba677083175ae01eb50eb176ef89a99fcad2e71fd56cf95de8b689370d0960ab0a95rootrootrootrootrootrootrootrootrootrootcrash-7.2.9-150300.23.10.1.src.rpmcrash-eppiccrash-eppic(aarch-64)crash-sial@@@@    crashld-linux-aarch64.so.1()(64bit)ld-linux-aarch64.so.1(GLIBC_2.17)(64bit)libc.so.6()(64bit)libc.so.6(GLIBC_2.17)(64bit)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)7.2.93.0.4-14.6.0-14.0-15.2-14.14.3aMaLl@`@`@`n@`lM@`\{@`H`@`x@_@_@_P_X_R,@_R,@_P^^^^@^^@^9\^g@]ʞ]X]]2@]L]@\@\eX@\8@\@[[j@[<[" command line option * Enhancement of the "struct -r" option * Enhancement of the "bpf -p|-P" options * New "extend -s" option - Dropped the following patches obsoleted by the version upgrade: * crash-Fix-for-reading-compressed-kdump-dumpfiles-from-syst.patch * crash-Fix-kmem-i-option-on-Linux-5.9-rc1-and-later-kernels.patch * crash-Fix-to-allow-the-translation-of-ARM64-FIXMAP-address.patch * crash-Introduce-a-new-ARM64-machdep-vabits_actual-value-co.patch * crash-Prepare-for-the-introduction-of-ARM64-8.3-Pointer-Au.patch * crash-Several-fixes-for-ARM64-kernels.patch * crash-arm64-Change-tcr_el1_t1sz-variable-name-to-TCR_EL1_T.patch * crash-fix-kmem-sS-for-caches-created-during-SLUB-bootstrap.patch * crash-fix-memory_driver-build-kernel-5.8.patch * crash-gdb-fix-aarch64.patch * crash-task.c-avoid-unnecessary-cpu-cycles-in-stkptr_to_tas.patch * crash-update-whitepaper-URL.patch * crash-verify-exception-frame-accessible-for-all-verify-requests.patch * crash-xendump-fix-failure-to-match-arm-aarch64-elf-format-.patch - Support the lockless printk ringbuffer added into kernel-5.10 (bsc#1183965) * crash-printk-add-support-for-lockless-ringbuffer.patch * crash-printk-use-committed-finalized-state-values.patch- Install and ship the small built-in extensions snap.so, trace.so, and dminfo.so. "trace.so" is particularly useful. Ship them in the main "crash" package, as they are small.- Added crash-xen-increase-__physical_mask_shift_xen-to-52.patch (bsc#1177050)- Update arm64 support (boo#1169099). crash-Fix-to-allow-the-translation-of-ARM64-FIXMAP-address.patch crash-Introduce-a-new-ARM64-machdep-vabits_actual-value-co.patch crash-Prepare-for-the-introduction-of-ARM64-8.3-Pointer-Au.patch crash-Several-fixes-for-ARM64-kernels.patch crash-arm64-Change-tcr_el1_t1sz-variable-name-to-TCR_EL1_T.patch crash-xendump-fix-failure-to-match-arm-aarch64-elf-format-.patch crash-arm64-update-mapping-symbol-filter-in-arm64_verify_s.patch crash-Fix-segmentation-fault-when-ikconfig-passed-nonstand.patch- Fix "kmem -i" option on Linux 5.9-rc1 and later kernels (bsc#1179970 ltc#188981). crash-Fix-kmem-i-option-on-Linux-5.9-rc1-and-later-kernels.patch - Fix crash utility is taking forever to initialize a vmcore from large config system (bsc#1178827 ltc#189279). crash-task.c-avoid-unnecessary-cpu-cycles-in-stkptr_to_tas.patch- Corrected project URL in spec file to match the changed upstream location as-of May 30th 2020. Noted the project URL change in README.SUSE without removing the old URL because it represents the location the project source was obtained from. The next project source update is available from the new project URL. When the package is updated with that source all URL project references will be modified to only show the new URL. Add crash-update-whitepaper-URL.patch Note change of no longer valid old project whitepaper URL to current valid project whitepaper URL in help output. Leave the old one reported because it represents the location the project source was obtained from for this package version. (bsc#1179536)- Fix build on aarch64: crash-gdb-fix-aarch64.patch- Add crash-verify-exception-frame-accessible-for-all-verify-requests.patch In calls to search a stack for x86_64 exceptions a flag is used to request the stack be verified for room to contain saved registers. The verify is not performed if other flags are used in the same call. Fixing this exposes another bug where only a kernel stack is verified anyway, even if the exception is being searched for on a userspace stack. Patch fixes both problems. (bsc#1162297)- Add eppic-remove-duplicate-symbols.patch Fix eppic extension build.- Add crash-fix-memory_driver-build-kernel-5.8.patch Fix memory driver build failure with kernels 5.8+.- Always build crash KMPs.- remove bypass lto and add -mfull-toc for ppc64le to check boo#1146646- Add crash-Define-fallback-PN_XNUM.patch Add a fallback PN_XNUM definition.- Make Factory ppc64 crash usable on both SLE 15 SP1 and releases before SLE15 SP1 (bsc#1148197). This is only a workaround that requires to build crash for each codestream separately.- Drop crash-s390-autodetect-kaslr.patch which has been merged in 7.2.7.- Add crash-fix-kmem-sS-for-caches-created-during-SLUB-bootstrap.patch Fix "kmem -[sS]" for caches created during SLUB bootstrap (bsc#1164815 ltc#182973).- Add crash-Fix-for-reading-compressed-kdump-dumpfiles-from-syst.patch Fix integer overflow with large memory configuration (bsc#1168233 ltc#184660).- Upgraded the source to version 7.2.8. The previous version was modified to support newer kernels used in SLE-15-SP2 but was not complete. * Includes a fix for kernels that contain: e0703556644a531e50b5dc61b9f6ea83af5f6604 which introduces symbol namespaces. Without the change then depending on architecture: (1) the kernel module symbol list will contain garbage (2) the session fails during initialization with a dump of the internal buffer allocation stats followed by the message "crash: cannot allocate any more memory" (3) the session fails during initialization with a segmentation violation (bsc#1162064) * Includes the merge of the S390x patches since crash 7.2.7 (bsc#1156645/bsc#1161640) * Source already includes XZ compressed module support, removed: crash-symbols-add-support-for-XZ.patch * Refreshed patches that were no longer aligned with source: crash-allow-use-of-sadump-captured-KASLR-kernel.patch crash-s390-autodetect-kaslr.patch crash-sles9-time.patch- Upgraded the source tarball to version 7.2.7. This is required to support coredumps from currently used kernel versions in the product (bsc#1159686). - droped the patch obsoleted due to already being present in the new source: * crash-allow-kmem-section-is-early.patch- Added commit c0371f6ee2cae31ec9f506bbd231ab8fbe334c13 - Fix to allow live analysis of s390x kernels that have been configured with CONFIG_RANDOMIZE_BASE=y (KASLR). This allows crash to load the coredump without the need for "--kaslr= on the command-line. Added: crash-s390-autodetect-kaslr.patch Implements jsc#SLE-9797- add crash-symbols-add-support-for-XZ.patch (bnc#1155921)- Disable LTO for PowerPC as bypass boo#1146646- Added patch for commit 326e1b8f83a4318b09033ef754f40c785aed5e68 in linux 5.3: crash-allow-kmem-section-is-early.patchUpgraded the source tarball to version 7.2.6 to bring better support of version 5 kernels such as 5.3 in SLE-15-SP2 (bsc#114706) Dropped the following patches obsoleted by the version upgrade: * crash-xen-invalid-pcpu-vaddr-use-hardware-domain-symbol.patch * crash-fix-for-4.20-without-CONFIG_RANDOMIZE_BASE.patch * crash-fix-for-virsh-dump-dumps-with-KASLR.patch * crash-fix-kmem-z-on-kernel-5.0.patch * crash-fix-kmem-i-on-kernel-5.0.patch * crash-fix-sym-for-module-symbols-on-kernel-5.0.patch * crash-fix-dis-function-for-module-symbols-on-kernel-5.0.patch * crash-handle-radix_tree_root-changes-in-post-5.1-kernels.patch * crash-find-kernel-configuration-data-with-kernel-5.1.patch * crash-fix-dev-dD-on-kernel-5.1.patch crash-Fix-and-an-update-for-the-ipcs-command.patch crash-update-recognition-of-x86_64-CPU_ENTRY_AREA.patch Re-aligned the following patches with the new version source: crash-allow-use-of-sadump-captured-KASLR-kernel.patch crash-debuginfo-compressed.patch crash-make-emacs-default.diff crash-sles9-time.patch Modified the following patches to integrate with version upgrade: crash-compressed-booted-kernel.patch crash-SLE15-SP1-With-Linux-4.19-rc1-up-MAX_PHYSMEM_BITS-to-128TB.patch crash-SLE15-SP1-Fix-for-PPC64-kernel-virtual-address-translation-in.patch- Upgrade the source tarball to version 7.2.5 - drop patches obsoleted by version upgrade: * crash-fix-snprintf-overflow.patch * crash-update-recognition-of-x86_64-CPU_ENTRY_AREA.patch - post-7.2.5 upstream patches for kernel 5.0/5.1 compatibility: * crash-fix-for-4.20-without-CONFIG_RANDOMIZE_BASE.patch * crash-fix-for-virsh-dump-dumps-with-KASLR.patch * crash-fix-kmem-z-on-kernel-5.0.patch * crash-fix-kmem-i-on-kernel-5.0.patch * crash-fix-sym-for-module-symbols-on-kernel-5.0.patch * crash-fix-dis-function-for-module-symbols-on-kernel-5.0.patch * crash-handle-radix_tree_root-changes-in-post-5.1-kernels.patch * crash-find-kernel-configuration-data-with-kernel-5.1.patch * crash-fix-dev-dD-on-kernel-5.1.patch- Update for XEN dom0 changes in v4.11 that cause coredumps made of a domU using virch on the dom0 to fail to load in the dom0 version of crash reporting "crash: invalid kernel virtual address:
type:fill_pcpu_struct", followed by "WARNING: cannot fill pcpu_struct" and "crash: cannot read cpu_info" (bsc#1124690 and bsc#1122594) Added: crash-xen-invalid-pcpu-vaddr-use-hardware-domain-symbol.patch- Update the recognition of x86_64 CPU_ENTRY_AREA (bsc#1104743, bsc#1090127) Added: crash-update-recognition-of-x86_64-CPU_ENTRY_AREA.patch- Fix SLE15 SP1 Incorrect vmcore generated (bsc#1119791). Added: crash-SLE15-SP1-With-Linux-4.19-rc1-up-MAX_PHYSMEM_BITS-to-128TB.patch crash-SLE15-SP1-Fix-for-PPC64-kernel-virtual-address-translation-in.patch This is not compatible with SLE15 and SLE12 SP4.- Sync with SLE15 SP1 (SR#173916) to enable the kmp-rt for SLERT15 SP1 only set %if 0%{?sle_version} >= 150100- Added: crash-Fix-and-an-update-for-the-ipcs-command.patch The update is required for Linux 4.11 and greater kernels, which reimplemented the IDR facility to use radix trees in kernel commit 0a835c4f090af2c76fc2932c539c3b32fd21fbbb, titled "Reimplement IDR and IDA using the radix tree". Without the patch, if any IPCS entry exists, the command would fail with the message "ipcs: invalid structure member offset: idr_top" (bsc#1092101)- Added crash-fix-snprintf-overflow.patch Fix to address a "__builtin___snprintf_chk" compiler warning. - Added crash-update-recognition-of-x86_64-CPU_ENTRY_AREA.patch Update the recognition of x86_64 CPU_ENTRY_AREA.- Upgrade the source tarball to version to 7.2.3 A complete changelog is available via the crash source page at: http://people.redhat.com/anderson/crash.changelog.html - Refreshed: crash-compressed-booted-kernel.patch- Upgraded to 7.2.1 because it includes the fixes to support several core cases that recently were caused tofail to open. As a result, removed patches that were already superceded by 7.2.1 source (bsc#1103371). Removed: crash-ppc64-book3s-update-hash-page-table-geometry.patch crash-x86_64_kvtop-usable-symtab_init.patch crash-ppc64-ensure-chosen-stack-symbol-relates-to-an-actual-backtrace.patch crash-fix-error-cannot-resolve-schedulers-0001.patch crash-fix-error-cannot-resolve-schedulers-0002.patch crash-extend-direct-mapping-to-5TB.patch Modified: crash-allow-use-of-sadump-captured-KASLR-kernel.patch- Added: crash-fix-error-cannot-resolve-schedulers-0001.patch crash-fix-error-cannot-resolve-schedulers-0002.patch crash-extend-direct-mapping-to-5TB.patch Fixes Xen dump files that cannot be opened in hypervisor mode. bsc#1073993- Added crash-ppc64-ensure-chosen-stack-symbol-relates-to-an-actual-backtrace.patch With latest NMI IPI changes, crash_ipi_callback is found multiple times on the stack. Ensure the chosen symbol relates to an actual backtrace. bsc#1072718- Escape the usage of %{VERSION} when calling out to rpm. RPM 4.14 has %{VERSION} defined as 'the main packages version'.- Added crash-x86_64_kvtop-usable-symtab_init.patch to change x86_64_kvtop() so that it can be called during symtab_init() Added crash-allow-use-of-sadump-captured-KASLR-kernel.patch to allow use of dumps of KASLR enabled kernels that were captured by sadump. Both are bsc#1070278/FATE#323473- Upgrade the source tarball to version to 7.2.0 which requires the removal of patches that are then already applied: crash-gdb-add-proc_service-sync-with-GLIBC.patch crash-xen_add_support_for_domU_with_linux_kernel_from_3.19.patch A complete changelog is available via the crash source page at: http://people.redhat.com/anderson/crash.changelog.html Added crash-ppc64-book3s-update-hash-page-table-geometry.patch from hbathini@linux.vnet.ibm.com via bsc#1067702 to correct errors with virtual-to-physical address translation in the larger virtual address range of newer kernels. Added a BuildRequires of libelf that will populate the build workspace with libelf (from elfutils) even though it is not directly required by crash but is required by gdb (which crash nests). It no longer got picked up automatically for build and gdb and kernel module features had build errors before it.- crash-xen_add_support_for_domU_with_linux_kernel_from_3.19.patch: Since linux kernel 3.19 crash readmem() can't be used to read xen_p2m_addr associate memory directly during m2p translation. PV domU p2m mapping is also stored at xd->xfd + xch_index_offset and organized as struct xen_dumpcore_p2m. This patch implements a special reading function read_xc_p2m() to extract the mfns from xd->xfd + xch_index_offset and makes and crash support Xen PV domU dumpfiles for kernel 3.19 and later (bsc#1043501). - add crash-xen_add_support_for_domU_with_linux_kernel_from_3.19.patch- Merge SLE changes into Factory (bsc#1041638)- crash-stop_read_error_when_intent_is_retry.patch: When reading a memory image fails it may not be an error if it is still possible to switch image and retry the read. Fix the error message output to only occur if no retries are intended (bsc#1038839). - add crash-stop_read_error_when_intent_is_retry.patch- Exclude openSUSE from RT KMP build (bsc#1013843)- crash source nests gdb source but gdb has a new build error on Factory due to the bug and build environment modifications. The fix is upstream gdb but not upstream crash's gdb. Created crash patch: crash-gdb-add-proc_service-sync-with-GLIBC.patch to create the gdb patch in expanded crash and added to the gdb Makefile patch it's application. Resolves the build error.- Upgrade of source tarball to 7.1.8 from upstream and refresh of patches to align with the version. For a detailed changelog of the source tarball see: http://people.redhat.com/anderson/crash.changelog.html Adds a feature to permit the use of the command-line options "--kaslr=" and/or "--kaslr=auto" with the x86 32-bit architecture. - refresh crash-sles9-time.patch crash-compressed-booted-kernel.patch - drop crash-Fix-for-the-PPC64-bt-command-for-non-panicking-activ.patch merged upstram in 7.1.8- Fix analyzing fadump dumps on PPC64 (bsc#1022962). + crash-Fix-for-the-PPC64-bt-command-for-non-panicking-activ.patch- Upgrade of source tarball to 7.1.7 from upstream, removal of crash-kernel-4.7.patch (source includes it) and refresh of other patches to align with the version. For a detailed changelog of the source tarball see: http://people.redhat.com/anderson/crash.changelog.html Feature enhancements included from 7.1.6: - Introduction of support for "live" ramdump files, such as those that are specified by the latest QEMU version's mem-path argument of a memory-backend-file object, e.g.: $ qemu-kvm ...other-options... \ - object memory-backend-file,id=MEM,size=128m,mem-path=/tmp/MEM,share=on \ - numa node,memdev=MEM -m 128 and a live session run can be run against the guest kernel like so: $ crash live:/tmp/MEM@0 - Implemented support for the redesigned ARM64 kernel virtual memory layout that was introduced in Linux 4.6. Plus ARM64 support for 4k pages with 4-level page tables and 48 VA bits. NB: On live systems automatic operation with Linux 4.6 ARM64 kernels requires that CONFIG_RANDOMIZE_BASE is not configured. If it is configured then use with a live system requires two - -machdep arguments, e.g.: - -machdep phys_offset= - -machdep kimage_voffset= - Improvement of the ARM64 bt -f display so that, for most cases, the stack frame delimiter will be the location of the old FP and LR pair. - New bt -v option that checks all tasks for evidence of stack overflows. - Incorporation of an alternative stack backtrace mathod accessed directly using bt -o and the default method can be toggled between the two using bt -O. - Fix for the case where the sym/dis commands fail for a symbol name that is composed entirely of hexadecimal characters and was previously interpreted as an address. - Determine structure member data if the member is contained in an anonymous structure or union (no longer necessary to use a] discrete gdb "printf" command to find the offset of it). - Session initialization speed up. - Addition of "list -S" and "tree -S" options (similar to the -s option of each command) where member values are read from memory instead of being interpreting gdb output (much faster behavior for 1-, 2-, 4- and 8-byte members). - Fix to recognize x86_64 Linux 4.8-rc1 and later kernels that are configured with CONFIG_RANDOMIZE_MEMORY. - Support for PPC64 virtual address translation of radix MMU. - Improvement of "dev -d" output to display I/O statistics for devices that use the blk-mq interface. Feature enhancements included from 7.1.7: - Restore x86_64 "dis" command's symbol translation for call or jump target addresses for kernels configured with CONFIG_RANDOMIZE_BASE. - Re-factor of the trace extension module to locate all of the ftrace buffers and extracts data from each of them rather than only the primary one. - Support for s390x CONFIG_THREAD_INFO_IN_TASK configuration so that "bt" command no longer shows incomplete output. - Support for live ARM64 kernels from Linux 4.6 that have the kernel image loaded anywhere in physical memory. - Update of /dev/crash/kernel driver to v1.3 which adds support Linux 4.6 and later ARM64 kernels configured with CONFIG_HARDENED_USERCOPY and S390x kernels that use xlate_dev_mem_ptr() and unxlate_dev_mem_ptr() rather than kmap() and kunmap(). - refresh eppic-support-arm64.patch crash-debuginfo-compressed.patch - drop crash-linux-4.6-printk-flags.patch merged upstream in 7.1.6- Enabled RT KMP build (bsc#1005578)- crash-linux-4.6-printk-flags.patch: Fix warning "failed to read pageflag_names entry" on Linux 4.6 (bsc#978601).- crash-kernel-4.7.patch: support 4.7 kernel (page._count renamed to page._refcount)- eppic-support-arm64.patch: Support for ARM64 (FATE#320844).- Upgrade of source tarball to 7.1.5 from upstream and fix of crash-sles9-time.patch for the version and refresh of other patches to align with the version. For a detailed changelog of the source tarball see: http://people.redhat.com/anderson/crash.changelog.html includes a fix for bsc#977306. Feature enhancements include: - "whatis -r" and "whatis -m" commands that allow search for data structure of a specified size and that contains a member of a given type respectively.- Upgrade to 7.1.4 from upstream. For a detailed changelog see http://people.redhat.com/anderson/crash.changelog.html- Disable RT KMP build (bsc#962719)- Enable RT KMP build (bsc#948840)- For 7.1.3 ppc64le the following patches are obsoleted by mainline crash-gdb-7.6-add-powerpc64le-linux.patch crash-gdb-7.6-bound_minimal_symbol.patch crash-gdb-7.6-floatformat.patch crash-gdb-7.6-ppc64-ELFv2-trampoline-match.patch crash-gdb-7.6-ppc64_sysv_abi_push_float.patch crash-gdb-7.6-ppc64le.patch crash-gdb-7.6-ppc_insns_match_pattern.patch crash-gdb-7.6-update-autoconf-2013-04-24.patch crash-gdb-7.6-update-autoconf-2013-06-10.patch crash-gdb-7.6.series crash-patch-gdb.patch- Update to 7.1.3 (bsc#946458) o Introduction of "dis -f
" which disassembles from the address to the end of the function o Introduction of "dis -s
" which displays the filename and line number associated with the specified text location, followed by a source code listing if available. o Addition of a new "--src " command line option for use by the "dis -s" option if the kernel source is not located in the standard location. o Do not search for a panic task in s390x dumpfiles that are marked as a "live dump" o Fix unnecessary error messages when a directory is used as a command line argument o See http://people.redhat.com/anderson/crash.changelog.html for the complete changelog - Removed these patches obsoleted by mainline: crash-x86_64-nested-nmi.patch crash-keep-file-orig-with-name-on-select.patch crash-kmem_cache-downsize.patch crash-s390x-add-vector-support.patch - Refreshed patches- crash-move-xen-dom0-handling-into-own-file.patch: Move Xen Dom0 handling into xen_dom0.c (FATE#316467). - crash-move-xen-p2m-map.patch: Move xen p2m map initialization to xen_kdump_p2m (FATE#316467). - crash-use-xen_machine_addr-command.patch: Use XEN_MACHINE_ADDR command flag instead of overriding readmem (FATE#316467). - crash-move-xen-elf-note-processing.patch: Move Xen ELF note processing to xen_dom0.c (FATE#316467). - crash-add-xen-dom0-support-for-kdump.patch: Add Xen Dom0 support for kdump compressed files (FATE#316467).- crash-s390x-add-vector-support.patch: SIMD support for dump tools (z13) (FATE#318058).- Upgrade to 7.1.2 from upstream. For a detailed changelog see http://people.redhat.com/anderson/crash.changelog.html - Refreshed patch series with some changes required to adjust for git host changes in eppic-switch-to-system-lib.patch- Upgrade to 7.1.1 from upstream. At the time of writing the only published changelog was supplied by e-mail list and is as follows - Fix for two minor issues with the "net" command. Without the patch, the "net -a" option appends its correct output with the command's "Usage:" message; and if either the "net -x" or "net -d" options are used without also specifying "-s" or "-S", the error message would indicate "net: illegal flag: 800000" or "net: illegal flag: 1000000" instead of showing the command's "Usage:" message. (anderson@redhat.com) - If the kernel (live or dumpfile) has the TAINT_LIVEPATCH bit set, or if the Red Hat "kpatch" module is installed, the tag "[LIVEPATCH]" will be displayed next to the kernel name in the initial system banner and by the "sys" command. This new tag replaces the "[KPATCH]" tag that was introduced in crash-7.0.7. (anderson@redhat.com) - Addressed three Coverity Scan complaints in vmware_vmss.c: 50:leaked_storage: Variable "fp" going out of scope leaks the storage it points to. 53:leaked_storage: Variable "fp" going out of scope leaks the storage it points to. 256:warning: Use of memory after it is freed (anderson@redhat.com) - Remove the LKCD-only "propeller spinner" seen when a dumpfile read requires more than 2048 page header accesses. This was put in place because of the non-random-access design of LKCD dumpfiles. Without the patch, the spinner display is intermingled with command output, which complicates the parsing of the output. (watters.sam@gmail.com) - Fix to support the Linux version increment from 3 to 4. Without the patch, both dumpfile and live sessions fail during initialization, issuing the message "WARNING: kernel version inconsistency between vmlinux and dumpfile" or "WARNING: kernel version inconsistency between vmlinux and live memory", followed by the nonsensical fatal error message "crash: incompatible arguments: vmlinux is not SMP -- vmcore is SMP" or "crash: incompatible arguments: vmlinux is not SMP -- live system is SMP". To prevent unexpected kernel version bumps in the future, support has been added for version 5. (anderson@redhat.com) - Add support for more than 16TB of physical memory space in the SADUMP dumpfile format. Without the patch, there is a limitation caused by several 32-bit members of dump_header structure, in particular the max_mapnr member, which overflows if the dumpfile contains more than 16TB of physical memory space. The header_version member of the dump_header structure has been increased from 0 to 1 in this extended new format, and the new 64-bit members will be used. (d.hatayama@jp.fujitsu.com) - Fix for command lines that are redirected to a pipe. Without the patch, if an external piped-to command contains a quoted string that includes a "|" character, the command fails with the message "crash: pipe operation failed". (anderson@redhat.com) - Fix for insecure temporary file usage in _rl_tropen() as reported by readline library CVE-2014-2524. (anderson@redhat.com) - When the gdb-.patch file has changed and a rebuild is done from within a previously-existing build tree, the "patch -N" option is used to ignore patches that have been previously applied; this patch also applies the "patch -r-" option to prevent unnecessary .rej files from being created. (anderson@redhat.com) - Fix to account for Xen hypervisor's "domain" structure member name change from "is_paused_by_controller" to "controller_pause_count". Without the patch, in Xen 4.2.5 and later, the crash session fails during initialization with the error message 'crash: invalid structure member offset: domain_is_paused_by_controller". (dietmar.hahn@ts.fujitsu.com) - During initialization, reject useless ARM64 "(A)" and "(a)" absolute symbols that are below the text region. Without the patch, several recently-introduced absolute symbols have been introduced into the kernel, which will be displayed by "sym -l" prior to the first kernel virtual address symbol, and will show up in command output where memory values are translated into kernel symbol references. (anderson@redhat.com) - Fix for ARM64 kernels to account for changes in the virtual memory layout introduced in Linux 3.17. The vmalloc region end address, and the vmemmap start and end addresses are now calculated at kernel build time, because they depend upon the size of a struct page. Accordingly, the crash utility needs to calculate those three address values dynamically, after the embedded gdb module has initialized. Without the patch, reads of page structures return invalid data due to incorrect virtual-to-physical translations of memory in the vmemmap range. This in turn causes commands that require page structure contents to fail or show invalid data, such as "kmem -p", "kmem -[sS]", and the "kmem -[fF]" options. (anderson@redhat.com) - Fix to support ELF vmcore dumpfiles whose PT_LOAD file offset values of their respective memory segments are not laid out sequentially from low to high in the dumpfile. This has only been seen in ELF dumpfiles created by VMware's "vmss2core -M" facility. Without the patch, the crash session may fail during initialization, either with the message "cannot malloc ELF header buffer", or "crash: : not a supported file format". (anderson@redhat.com) - Enhancement to the support of VMware .vmss suspended state dumpfiles. There may be holes in the memory address saved for PCI, etc. In such cases, the memory dump is divided into regions. With this patch, up to 3 memory regions are supported. (hfu@vmware.com) - Fortified the error handling of task gathering from the pid_hash[] chains during session initialization. If a chain has been corrupted, the patch prevents the sequence from entering an infinite loop, and the error messages associated with corrupt/invalid chains have been updated to report the pid_hash[] index number. (anderson@redhat.com) - Implemented a new STRDUPBUF() utility that will duplicate an existing string into a buffer allocated with GETBUF(). As is the case with any buffer allocated with GETBUF(), it is only meant to exist during the life-span of the current command. If it is not explicitly freed via FREEBUF(), then it will be freed automatically prior to the next command. (anderson@redhat.com) - Implemented a new fill_struct_member_data() function that gathers a bundle of data that describes a structure member. The function receives a pointer to a struct_member_data structure, in which the caller has initialized the "structure" and "member" name pointers: struct struct_member_data { char *structure; char *member; long type; long unsigned_type; long length; long offset; long bitpos; long bitsize; }; A gdb "printm" command is crafted using those two fields, and the output of the command is used to initialize the remaining six fields. Adapted from Qiao Nuohan's "pstruct" extension module. (anderson@redhat.com, qiaonuohan@cn.fujitsu.com) - Implemented a new "runq -c cpu(s)" option to display the run queue data of specified cpus. It can be used in conjunction with all runq command options. The cpus must be specified in a comma- and/or dash-separated list; for examples, "3", "1,8,9", "1-23", or "1,8-15". (anderson@redhat.com) - Build extension modules that utilize the generic extensions/Makefile with -g. In addition, build the snap.c extension module with -g. (rabinv@axis.com) - Several fixes, updates, and enhancements for 32-bit MIPS support: (1) The MIPS general purpose registers in the elf_gregset_t don't start at index 0 but at index 6. (2) Adjust for the kernel's pt_regs structure changes between kernel versions. For example, fields are inserted into the middle based on build time options, and the amount of padding at the head of the structure was changed relatively recently. To handle this, split the structure definition into two parts and get the offsets of these two parts dynamically. (3) Do not display each parsed kernel symbol during initialization when invoked with "crash -d8". (4) Add support for loading raw MIPS ramdump dumpfiles. (5) Add support for compressed kdump dumpfiles. (rabinv@axis.com) - Fix for a typo in "help foreach", and a fix for a spelling error in "help input". (weijg.fnst@cn.fujitsu.com) - Fix for "and and" and "the the" typos in the README file. (weijg.fnst@cn.fujitsu.com) - Fix to address the Xen 4.5.0 hypervisor symbol name change from "dom0" to "hardware_domain". Without the patch, the crash session fails with the error message "crash: cannot resolve: dom0". (dslutz@verizon.com) - Fix for a regression in crash-7.1.0 that causes failures when the "crash -t" option is run on a live system, and when analyzing remote Linux kernels. Without the patch, "crash -t" on a live system fails with the message "crash: cannot open remote memory source: /dev/mem", and attempts to analyze a Linux kernel remotely just shows the kernel timestamp and exits immediately. (dslutz@verizon.com, anderson@redhat.com) - Speed up the session invocation time of "flattened" format dumpfiles created by the makedumpfile(8) facility. When sorting the blocks of memory by their intended ELF or compressed kdump file offsets, the patch replaces the bubble-sort method that is currently used with an insertion sort method. (dslutz@verizon.com) - Remove the non-existent "-L" option from the "ps" command's mutually- exclusive options error message. (vvs@parallels.com) - Fix for the "irq", "mount", "kmem -p" and "kmem -v" commands when they are used in an input file. If more than one of any of those four commands are used in an input file, the output of the second and subsequent command instances will not display their respective command headers. (anderson@redhat.com) - Implemented a new "kmem -m" option that is similar to "kmem -p", but it allows the user to specify the page struct members to be displayed. The option takes a comma-separated list of one or more page struct members, which will be displayed following the page structure address. The "flags" member will always be expressed in hexadecimal format, and the "_count" and "_mapcount" members will always be expressed in decimal format. Otherwise, all other members will be displayed in hexadecimal format unless the current output radix is 10 and the member is a signed/unsigned integer. Members that are data structures may be specified by the data structure's member name, or expanded to specify a member of that data structure. For example, "-m lru" refers to a list_head data structure, in which case both the list_head.next and list_head.prev pointer values will be displayed; if "-m lru.next" is specified, just the list_head.next value will be displayed. (atomlin@redhat.com, anderson@redhat.com) - Support enhancement for the 32-bit MIPS architecture that retrieves the per-cpu registers from the NT_PRSTATUS notes stored in the header of compressed kdump dumpfiles. (rabinv@axis.com) - Fix to remove an invalid warning message on ARM64 if a crash session is invoked with the "-d" debug flag. Without the patch, the invalid message is "WARNING: SPARSEMEM_EX: questionable section values". (anderson@redhat.com) - Remove the leftover ".constructor" build file in the extensions subdirectory when "make extensions" is complete, and update the top-level .gitignore file to ignore post-build extensions subdirectory files. (anderson@redhat.com) - Fix for a segmentation violation generated by the "help -[n|D]" options on ARM64 compressed kdumps. (anderson@redhat.com) - Additional output for the "help [-D|-n]" options on ARM64. For ELF kdump vmcores and compressed kdumps, the elf_prstatus structure in each NT_PRSTATUS note will be translated. (anderson@redhat.com) - The "help -r" option has been extended to dump the ARM64 registers stored in each per-cpu NT_PRSTATUS note in compressed kdump and ELF kdump dumpfiles. (anderson@redhat.com) - Fix for the ARM64 page size determination on Linux 4.1 and later kernels. Without the patch, the crash session fails during initialization with the message "crash: invalid/unsupported page size: 98304" on kernels with 64K pages. On kernels with 4K pages, the message is "crash: invalid/unsupported page size: 6144". In addition, the "-p " command line override option had no effect on ARM64; that has been fixed as well. (anderson@redhat.com) - Fix for the DATE display in the initial system banner and by the "sys" command to account for the Linux 3.17 change that moved the "timekeeper" symbol and structure into a containing tk_core structure; the "shadow_timekeeper" timekeeper will be used as an alternative. Without the patch, the DATE shows something within a few hours of the Linux epoch, such as "Wed Dec 31 18:00:00 1969". (kmcmartin@redhat.com) - Fixes for the translation of ARM64 PTEs, as displayed by the "vm -p" and "vtop" commands. Without the patch, if "vm -p" references a swapped-out page on Linux 4.0 and later kernels, the SWAP location may indicate "(unknown swap location)", and will show an invalid OFFSET value; on Linux 3.13 and later kernels, running "vtop" on a user virtual address incorrectly translates the PTE contents of swapped out pages by showing a PHYSICAL address and FLAGS translation instead of the SWAP device and OFFSET. It is possible that there may be PTE bit translation errors on other kernel versions; the patch addresses the changes in ARM64 PTE bit definitions made in Linux 3.11, 3.13, and 4.0 kernels. (anderson@redhat.com) - Enhanced the "struct.member" display capability of the "struct", "union", "task", "list" and "tree" commands. If a specified structure member contains an embedded structure, the output may be restricted to just the embedded structure by expressing the .member argument as "member.member". If a specified structure member is an array, the output may be restricted to a single array element by expressing the .member argument as "member[index]". Furthermore, these embedded member specifications may extend beyond one level deep, for example, by expressing the member argument as "member.member.member", or "member[index].member". (Alexandr_Terekhov@epam.com, anderson@redhat.com) - Fix for any command that passes strings to gdb for evaluation, where the string contains a parentheses-within-parentheses expression along with a ">" or ">>" operator inside the outermost set of parentheses. Without the patch, a command such as the following fails like so: crash> p ((1+1) >> 1) p: gdb request failed: p ((1+1) crash> (anderson@redhat.com) - Fix for the handling of ARM64 kernel module per-cpu symbols. Without the patch, if the debuginfo data of an ARM64 kernel module that contains a per-cpu section is loaded by "mod -s " or "mod -S", commands such as "bt" or "sym" may incorrectly translate the module's virtual addresses to symbol names. (Jan.Karlsson@sonymobile.com) - 0001-Prepare-for-the-future-increment-of-Linux-3.x-to-4.x.patch: Dropped. Handling kernel 4.0 is now part of the upstream source.- add patch from upstream to handle kernel 4.0 0001-Prepare-for-the-future-increment-of-Linux-3.x-to-4.x.patch- Upgrade to 7.1.0 from upstream. For a detailed changelog see http://people.redhat.com/anderson/crash.changelog.html - Refreshed patch series with only re-alignment required.- Upgrade to 7.0.9 from upstream, For a detailed changelog see http://people.redhat.com/anderson/crash.changelog.html - Refreshed patch series but no modifications required.crash-sial7.2.9-150300.23.10.17.2.9-150300.23.10.17.2.97.2.9eppic.sosialcrashfiles.cps.c/usr/lib64/crash/extensions//usr/share//usr/share/sial//usr/share/sial/crash/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:Maintenance:24893/SUSE_SLE-15-SP3_Update/2e57f5c8c7ca1e386685ffe21a67ae87-crash.SUSE_SLE-15-SP3_Updatedrpmxz5aarch64-suse-linuxELF 64-bit LSB shared object, ARM aarch64, version 1 (SYSV), dynamically linked, BuildID[sha1]=6d625a5309664c4af142608c5e06dc8148bc2075, strippeddirectoryASCII textC source, ASCII textRRRRutf-8f2a04f6e361c399fed6529ec7a6639cd76b187bf1009e36011b144512784e004?7zXZ !t/ГS5]"k%jWkS0Jn$w+JlpPrbиZ-?YdVA/ g7b UuH؏w[P8P˪ʅ>GE{0bx ňHpl(MCq$MqШCY!RO`ܛ_V'~GB;A!z2MDj/q( 㱪|FW]NLTTQPx^]-/4RU1ӕ Dמ1#og^S؄eL l!+li-љFK;7Ugh~+#FfX] U"0Fy|7_c?q`|j6CHRIc "fw9F<7bW?&C""D^e^婺_:Ոc;C9r ̫)6#>31BDd" Z@2޾|3ߒҢ8onM tq=(܂wf/D,TU>p2PZ"B/V߹ҶfGV2K7ޙeWh@尊u}rq#|R؜R"A h@Лv/Ma4y%|•.tbзfMJ%,Wm"avQss ,_M ۯbQ= qqTLo2c))U; ygLgcyK~ɕ5yl):b:cN Zj?1;`M0e/~CDǑ:GڇlAŕ+EEx C z[.PF,ΜX ;ukYVUM`6;^wYaC'!_@@xvbje-m' ڽo\Mި]Z"'H%e/_t/0(;T>sR|HYK9rʜw<"b"5o5[3D-FҨ%|SȱMڔWҖ_їl EL Q:3sXKm^KX@d@ef{ 86WAL;Fz艗䙜bOa0Eb [P?Th!?`W>K\$=v KdYfC*X1sR*̜m.Wٗꠕ\Zxا&DFTr6XXz,HuY72\~:+~/qb-Ihs E;%͇hl gl9Dш^Eo\.ge4 mIkmꚤj@AIp4aT?4,M4F;˱NBU|DMz"F;nIbOB#b݋i3DÒQ6{TA٣)z9b{=#< ҽ+pAs-qj ` "۔HV7X:C6l)sF}Y2v Ӝ1q&0_iO#T򂹎0t͔OC;wGǛm.?F2g0F<0>SOeODpt֤xeLfɚ%;7z[eZf,rY$X+ђ i+ܳ{RPůGhI<(U CUXkh߽juliWɓ:&k# GلPԏLh}~!$[0t26G25 ( 9IQ.j]h]5_H:O6.G]}r:ƳIGh,Uxw)M4_$h t++b7$ ֖kQPC@Ly^Fc\PUhVu[-K=TPRbn9=rTo= B4 I#%Mw# 5'>Ckų5~~#ٖ|*+31_.q#f7u !/E@ZZT8mCprJK {鐬%6C֟ g]*΍2 Ж咭/\`OJ9"CR{R;8cB/)M5m27QSq!men 3ӛq)#I4FoY{,-{DX;c8蕞scD0RyXk%:;sVSr=ٛ)}G?F~L}˳`%"uJT𡶸Ƥ@q`"RÉ2P1 溯7? gfTz E(hT,h\DN$ms&t$1G8/@ ez~?iGfd;#mkcT0o=J ;qF1|!DժĄ3 o@jȐTD$PF~-UT;njg*__Vl^M(l_,?۲yf ~;CVOp1Rh&!@|ݚbn:["ґq(>qp:ԡS+OrQosV qZnǮF%x%ZXʜPGAqM@ yAm)A?R~= K&z*AP @'gK|>F t(P\e%Fܹ K@HWGFr6;IFZ[02} ƾ~V F%7 7]Q`Nz$=hSQH:r'WxrVN5Ay(ZYg F֘|\K0v&A,rm[iV;tfr3DYQ$=iCD- <,d` &1{*R^3[I4iK645m9[wQv`COиsAHq+Yd8#0s Θ}qDlooVK͜V`Hj# y$)q)U/hGLwX c?OP'R|n+m-kWUۮrMڴ9ΊeosJ:7 g 2E;4F *|l{Y̼)EZMx N0 a?WmP&F꧸^*pQN97NUt˛QǑ*5cX,!)DLq8\W%=߾Umd}mzxtꭧycxڭ.p0 ̈A^ڪɩ1h 4j:lC֊5dZ.oꞗ",irxsmHA#S\Sܑyȏ^ 4D*p`Q%̇(vg@WqzwvYzTx?,OҘZ}g B4tm y̚JPc|EaU 9=^N,ࢨ֯yig_VZlׅ{M5\2ƾ:y\]kKP8|{"MP@7TYb*p9݁2o{þ*~@feK/yBr~\˅1 8|(+39&=IZU|ӋcV"qX2myu:vE#ͬhǐft[l{LBGhPʠ#VZ2A9EUH;J *\6sPIZC܃hdpж"ΧMWtOm.4녛bU[Z~CSQʩ%dgÉ:c>UY̤i1Vuo=C=0D̉^l# M @R~r̿ʊnp&0~4]JiǕ_} Syt`@TuS_xviV9;qh+DBZEo&,N]p&fX1 H}@2'l3!s=\mPؙ'5 TsA|&|6/tyQd΅A8zN(JFO8]?p`UB*+@XIBY 5[wzS)G5wYl ĀND{FY) |uB3@N쳜B2 F 7|q|a^T\(7o ts-L-fPRr$]7$pg2[+W{u [R,%࿾7/?6kF7!iЛDwnyGa$L ?fHGM*XaZJ@`J-S]K}؉o݉&HUw7d0tbԅG=҈/8$4v|X[qgXmEHjB3O:d(_~)UX2vl@0Mݣȡ<)%AkGՔG!ѶpEaff:{?k|[(1cepCDICcM V҅`vޞfE6CvxP~[ b8ޖjgFiwujm;Ylayf 6 1MϚ[|!MLЫ@m:50PqN5NgT,v!f*/B1(e89 +9CHKNHJniߠ=NE^ښx wHB~m Q8DIN/b G ߞI}|.5EA,8 #,ɆY\v >&ACJԚlʅެ@Y_}4>qh~<3N,KA|d&J;0Wh+âg|Cy*fba&k;$6_ Ft;8{F'&$x@9-}͔ԲMPK,G zНT$Ѕ2O{(5UHhBneIzyE ❳L .XJtNAIiclWv%7VXM9 Hm[ǗS@(QYDŽB=Yw yW Lx}p[Kk/#~Ȣ+Th ![{ǽz&,;\kuׂ;Չm~  9# “MIQ{Jͮ$4tKϊiQGj2T)A񨕰)!Co}+z'dmcZȥ]hw\_JWe0է4@H#L!lݣWEr8y _Ar Z oDMWzi$3o6g2k*[xs+*h r*3u|{&# O:rl *` .2+0Wc29ݩǐxrP Hf #yHÍV(nXs7UނD ѧ}.`&b҇P:loԷOb޴SlfPع.Lw#5NcHI%jW!'嵽kd-Մ3SYB(H^Ej=OB ۫dO9#U/Ĵ6,cן6oT-Yeu0߾1 7waP(~GہAM ޿D4 hUq#-j/\^FcDU:TQ}TT K`,&rsYp{DJp7DK]PGfE٭4>8pA'{ I'=a1\r}<ѡ8dƌ"}%n^= "$WC,qʄ R땇iXQ[҄ IRm! 1yvO7 6ܫF|r6j( ܈-+_UHH gn򯼄oxE}'ebɵӾ!cYT$DPy3};iy{}^%1c#@dZr%uwfՊ!5XUVV+jzPn'eNx7/}tXT%(b= 6@P(fC/. Y"7rtƪ;W)'rK侥e,wrxn{¯]Aq;{ޫ?xCT2q`eٿy!Ei= jq2'C[+ Z>CqƋiSDރYSGW- /pC6PU э.m9\Ի1\E^L!9sr63̴ePX )c- P&Ř1diUVc*<{T6xq5|QLYb!CWrU ~j]Gi2(4gV~7[ƍr Q4*~%̚ghOܓ_WVPWO7JF)>s0#I+rLdsw$}WVo'm:#{Gi }z3W&50fG6FfF4'6^C%(oþ_u^n_Gt.vې브 WHfGԷRi7[ F 8Lǰ{&5ҹ@`\MQg(К'/k!uF'ZN8譜Mp@=s\aMQх۬i$xUe#^ч$M&] ~vsQ1.` h@\:xYљD!IzvYltbhi :`ϓ֯t ᕌǮt(b$3e"/.Dž!oTzɃ2]Hҵ ~Ƥ}S41\&^F .{\GFclbJ _flkӖp-ZÅ5 s읒Iuv}sבGyYȼlLYOb՚K1MD *^&%'jziUZ-at[/PFZb:}uلI gѤz鹿۸ 4:& (a2iJЯPW=ҏ~Lԫä${lwfrhwEկ#'w1021 ᵱ@JV0-kOp¦b0=uٷ;M\ *D0KCR6(;ѡHE""VP}Ӿ&V%qOL/;ācUȇ<3GAh+(J}-Yճ6G<Rl|#mr_@\%jbK}Q;@q?|8$:Vz'R#u)xwԃ&q4ZlUS4@=K01V:c6% mִv$Sz)ŹH{|.LnE pg n#)IS^`6?D<9y(W.fVT<. 0!'-9KKAr{glLfXP\=J1!冞;F q%/X!TѺk pulz Q)ؓn$P aeúB=%0J6&ZxOp҆s+XR \0h=#dktep$#9:XrDy""քC_؀ Go?9{ԫ4P}i_/G6Qx"-ztvʎeBҞg)A&(H[[ u]D5=p ڏ!x>F*4' h L,b"9zsdBڼǗFq@]!z[UҰ2, QbkA Vzg$h@@oҗݚg5xӍ+Yk٫c ƚep8R^I@Ĭܕ6l1NkN2ByQ/r`9s{ gc9[Vo *YvZ[52V1~?. /!pFz:5Dt(ј С&ԎT i)ߩ(deGЮ)`O+D\@lyq8IB֓hMXD (Ԕtn<庎L>^’iyFaȳKM ':% q(Ғ1ډ B|/Ð_p8s]ϽdɕZmAX 'U'qohהVGC!ԧXǪϬR0e?OIe#Co$En?u!Z%=MkZjxL,4o RGGA dJ~n]^jh8s˲ rK0k4ue[IG]պcdFBWRJPҊqbUZ䝄;6LQ" !,jZp2Hą?#Ңo8aە1^}7S=>ϲqruiVv>1`f1M'bC7%-{Nx:   AV^]Y)}xbik+@$BLpI=vG$W?w&gGR'n:8Nblbћص6#֔Ct&?(+ip"5jν_^ʦ8U_*r;(L+Od:^EY")Uh%DH ܑD&&khLsoH͙{dE9*plHhP8y:$Rh*N"MfS\Q~>/<; CN ! S,FG\D8x%LEզ$ ڰ{l78B:;<?*ܼ]^ㇷ¢šEwKYp ]`uR'M2g{-ǡ #kS;Bl: SuʲMK`FOYv"ƫ ;2*9tl*]T΢z[늺k\ͼ6U1/; )-qn7Du!U7Ц9QogRU>@W6x)_t[?hYVlT|auDuovqQi憗RG3(?þJpUю;ɠfY5㘼(k]M Tc$uNxb$M? L2a-l)UCɺ,gpd'"{M}!MYo1kz1)V#7кbU13~";ox'z/p:YWʹ_ 6A㫉]:'S(htVX5jv⩷$*\N_7Nj礕.іbO\L.Kx<DqzBwֹOc5Bw\ﮭ׵ZR7Mɒgrw̳΍5:.'2x&L֣ ~F OG}+b7 l^m FY 8qemO; ~~Pp JC!T~ 0Nu]}Q bES =h'M5JF"|͢M&QAE9Jyp 8ޙy,d~D~)D[X~d l$]-@DHNtCZaFFIV MXuQ-%g6ze_vޱt3Ķ)4B]wLb3Z)%xշh2YNG}O:(sLL.5鵵ER4UpzO-Ћ;5Mqlz7*]`npWE-q%hSn`^SܒxJ撤ͥj<ueaBm+믭q&Ǭ TgIRScGzmzv"THyG/:NT껍NWGڊ15}׹^u$n`mpY;jʬ~YZ3! n@GyVJ%9T*R[s/[![xk; 13Œxz3=rIrw,af= $ V3Cw9 zsl8֨vSz0.`N.CpښݦTjU*s QzQGµ&QUn1&4;e;1#0LYŦֈǠRɦ%`l]VDc茣C Qh %k!V=L96ֻj([RՄ :I fx]p "sɘ,\g"x`oF\oqfUӵg}8@n y?~]> |hW0WdtW2fm!,f)LlDg"r30F@1fFBzfxp:#ߐ?S ^~cP^71?!3~c~2}!tNQ0oCU죄@!85-3shILay5L"6d}'-B; Nv $]k ;|>oxi+*eFppIԆ/[e+kϲCٻ?rծ]Z.6)ї W 4--$3q5\x^6m] wScdrxz-Bg p  Jw6gT=Tj)K播zĎ?CM {w9Cm .rE=1z3c 5XJ74GNs6ʷ.BHϐ g Xl>n!,:hqEH|&'9Ŋ`&Tp)S}0Ȟ&XY kYG#8b~ZT12뱊C,VR6x>C# b?tH7<%2W]Z{tf[T?c6.5La/e͂"^ܖ+yAUJbO*7uV>Cl +F[,fig߶NqZyIddF L  ۹ %tpX9z-a a'J? XV-AXl?t<=[*<lTl&B"'oz Rg<ښoQQ#|c]l5m c&}IQ# w^Kl# ˂ ȫ},n}C5L9o:G!z_'0LU! ǜmřk߃dfUdAI<4;['r*+eo-Q߲j|h{G `OC '/079S8TmǗ@:B!|K}GߤsTLRS⣎Mg߇n9Twt)j^-Ov%8 wۗo2d~7GhDdj =& /Dhi=(:(vϣR02H{I*Cߘhs4OB{KM%[dU!jG}HQ.#AI߲`U!KRoҦg#e"D"ثTK$/Cݪa0;(6/?ȿTUun@c Rk昨iHd21ˇ+%$(*~hU+$F$2-"2y٘)bcaa$GȒq)6F0 >^Y/.hVk]s1N AK6a-/!fOܭҲ%\$yɳg|2 3f)ٚL!ޅ#ȰܘFO"lID@MZdY {b%*-Qdr}U$AI&TQ!W"IBbqHTGcZ->ŒLmY$98 n,a"]ɢAEf $ki!S )R*c܋W"%nH/yw4#͡aDׯ?ß1C V LV2^^ $.56 #nmAɼUOGםʢ!mޱa$-kh@\"'`թV^i/8R}=_g&4Pu|-?x6#DgVjSܒ{|dmDHd?P3}Urg.ԀR?_z  O7r_)Goz᥼M zY{0>QoI tB^8h!\6f)i.M3H=3n Z1p8yg3IJ7P*G+|*HX^z.DHPֵsֱGԯLT%Կl/jYTċd.C/%@<W`PuD-=~QXwЙwu _rQN=L1np )!^>큮k*ol8/qlh_ XPeѣ҉, p|5|e&!i]X ru=F(Y%_4T? &j}Qc&.pskhUVRv6.~a ]>OGG&k4=POil[H Fb>P(ߕ 7K䫣66o W̉h8/}o4x>FV̊Nj;,G}3=/)WC8)b=.5-IAB9_=j1fv?f'!&niMen ߫{%KHߍ"#(M%KeZo`< @XNzIdƮeW%m>0S~IpgUi4ۃ`%!nl۳d8Ýؖpt܏)dÄɂ mfNYO`Ah$k 4kZ+`'>ı Wݔ+)#3OM^Ue2AW8 iuXqS"!e^tW4%Eq; Yi|Q i\Y&0`'#^d`(5e۷N@ %| MSmiVh1fi j ,|U# ;TUxU9{ڒȀe 6O-D, lB}Zui6Tuy:(wQs?Ēؾ_ nv!JKC#D).Q-iMFvo!7c0ѨzY\˅ (~\#j!!(s9pkpWVj?M? m.;m͞mN;ZTV{8`#tVM~[rX =L\ 7~ Ǟc߱B6Isߩc\V%;i]͓qD3NH$7<t+(ɽ|HRNp,El_p "`(KW{ 0 Eq'0kRJ}صҬeWOWOlr&ʹQi=|,|[(W_ն˻b}Ldd=jZ;;B|IO܅*^'E{6:Syוʺ?n U5a,11j c 2](+zU͚#(^U :cQ$x"PftrYR%j^R>k-9IlP0CR({C"o,ꕸ>y}8(=#t:RH|ayp1QSyUL1&+AB4ϕޖe0"z46/V %AFFR<=Yx^^/hCz֐k\Eȗ/y#{C{{?h,<@K,Dpdm;fYߎZ^#퐢+B-H>q+:Da_=Gnfʫ1xM &~m%ƆeTYhm3vDʧlVFfmE:wJC^caDqiS_6ϣ-21kxܝɇ`蘇HHYw7$IqQ# B ȹnJ)P׽I&!ȝeCtjXD)罔myW{BΆ7hȣVSԎMk;A ҈L`|* A7\ b+d+l[ I[&ME @Jj|jJQȚߤ2Ac1"˓؂-cs{5Mtsg M6Y͟pdJ7ql]\8:'EǸm}I/7ؐ2z^T?Ur*prOLƊPyT {$jL~|svTEύgv$u8׫/E=cԻ>x_mr^/oe=:٥Q`v@6`Ի%Ҧ!芣#)\_ok]ȱp JhxD\Q.voj_EhP4am:lcodZxPE—ީUUzqk7Dz{C˒f,b(]jAz7U_50zL"X³#ry^w)N=zF .~.L:ra&_s(e}mVa U²ieE#h_$i7DK*ϰV )Nr*"d焢V=Vd N"zi> 70gp]|0^2%9QVV@[-48ǬUOLⶶW>IypuחCPxVꯈ3Du1`zȋ^l{ cWU>T;>kTФ0K|Vk"~1xrwn!y-[(AtMſU7̘15,+<C@JbYK?;pSؕy:n:wpMY JQVj'81T]hC0AҬl(7t6/$/я>Dl+!vTao^ X¿yP!@uF!eJtTo =C|U/*uB#y4{xđ & XD,cEx C1rNCmN5mNNk.9qC0pNP2i?-Юn "yZK;'"j;r?d(Ĺ6'mAlgUGWrwI>.VT`%DXB`6,ÚcbK^#{4d~;+]YfbDXP?FzL]rV.~f+" fg mLTm=:+Fy`GNӒ.FԝXF5guUoJmZK pG>kuWp?s Q2ڣ{c6RX4>̮D,%j$<-?D£j&  NrF(yaC6w@!я/'8"7a -޹;{IDa6NƮg LEx EˈLИ i^ Ǿ]攙v%Ua3B Uw]gJwh,A:%Xu&fxjp~ׇg?Fe.J)ԦAC /37[n_a YZ