Merge git://git.denx.de/u-boot-x86
diff --git a/Makefile b/Makefile
index 9919314..7b8efea 100644
--- a/Makefile
+++ b/Makefile
@@ -1040,6 +1040,7 @@
IFDTOOL_FLAGS += -m 0x$(shell $(NM) u-boot |grep _dt_ucode_base_size |cut -d' ' -f1)
IFDTOOL_FLAGS += -U $(CONFIG_SYS_TEXT_BASE):$(objtree)/u-boot.bin
IFDTOOL_FLAGS += -w $(CONFIG_SYS_X86_START16):$(objtree)/u-boot-x86-16bit.bin
+IFDTOOL_FLAGS += -C
ifneq ($(CONFIG_HAVE_INTEL_ME),)
IFDTOOL_ME_FLAGS = -D $(srctree)/board/$(BOARDDIR)/descriptor.bin
diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig
index 01ed760..5e42d7d 100644
--- a/arch/x86/Kconfig
+++ b/arch/x86/Kconfig
@@ -229,9 +229,16 @@
depends on HAVE_FSP
default 0x2000000
help
- Stack top address which is used in FspInit after DRAM is ready and
+ Stack top address which is used in fsp_init() after DRAM is ready and
CAR is disabled.
+config FSP_SYS_MALLOC_F_LEN
+ hex
+ depends on HAVE_FSP
+ default 0x100000
+ help
+ Additional size of malloc() pool before relocation.
+
config SMP
bool "Enable Symmetric Multiprocessing"
default n
@@ -307,10 +314,10 @@
0x90000 from the beginning of a 1MB flash device.
menu "System tables"
+ depends on !EFI && !SYS_COREBOOT
config GENERATE_PIRQ_TABLE
bool "Generate a PIRQ table"
- depends on !EFI
default n
help
Generate a PIRQ routing table for this board. The PIRQ routing table
@@ -321,7 +328,6 @@
config GENERATE_SFI_TABLE
bool "Generate a SFI (Simple Firmware Interface) table"
- depends on !EFI
help
The Simple Firmware Interface (SFI) provides a lightweight method
for platform firmware to pass information to the operating system
@@ -336,7 +342,6 @@
config GENERATE_MP_TABLE
bool "Generate an MP (Multi-Processor) table"
- depends on !EFI
default n
help
Generate an MP (Multi-Processor) table for this board. The MP table
@@ -344,6 +349,15 @@
multiprocessing as well as symmetric I/O interrupt handling with
the local APIC and I/O APIC.
+config GENERATE_ACPI_TABLE
+ bool "Generate an ACPI (Advanced Configuration and Power Interface) table"
+ default n
+ help
+ The Advanced Configuration and Power Interface (ACPI) specification
+ provides an open standard for device configuration and management
+ by the operating system. It defines platform-independent interfaces
+ for configuration and power management monitoring.
+
endmenu
config MAX_PIRQ_LINKS
diff --git a/arch/x86/cpu/baytrail/valleyview.c b/arch/x86/cpu/baytrail/valleyview.c
index 6c3dfe8..4baaae6 100644
--- a/arch/x86/cpu/baytrail/valleyview.c
+++ b/arch/x86/cpu/baytrail/valleyview.c
@@ -9,7 +9,6 @@
#include <pci_ids.h>
#include <asm/irq.h>
#include <asm/post.h>
-#include <asm/fsp/fsp_support.h>
static struct pci_device_id mmc_supported[] = {
{ PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_VALLEYVIEW_SDIO },
@@ -41,14 +40,9 @@
int arch_misc_init(void)
{
- int ret;
-
if (!ll_boot_init())
return 0;
- ret = pirq_init();
- if (ret)
- return ret;
- return fsp_init_phase_pci();
+ return pirq_init();
}
#endif
diff --git a/arch/x86/cpu/coreboot/sdram.c b/arch/x86/cpu/coreboot/sdram.c
index 9c3ab81..32f595d 100644
--- a/arch/x86/cpu/coreboot/sdram.c
+++ b/arch/x86/cpu/coreboot/sdram.c
@@ -7,14 +7,7 @@
*/
#include <common.h>
-#include <malloc.h>
#include <asm/e820.h>
-#include <asm/u-boot-x86.h>
-#include <asm/global_data.h>
-#include <asm/init_helpers.h>
-#include <asm/processor.h>
-#include <asm/sections.h>
-#include <asm/zimage.h>
#include <asm/arch/sysinfo.h>
#include <asm/arch/tables.h>
@@ -22,9 +15,10 @@
unsigned install_e820_map(unsigned max_entries, struct e820entry *entries)
{
+ unsigned num_entries;
int i;
- unsigned num_entries = min((unsigned)lib_sysinfo.n_memranges, max_entries);
+ num_entries = min((unsigned)lib_sysinfo.n_memranges, max_entries);
if (num_entries < lib_sysinfo.n_memranges) {
printf("Warning: Limiting e820 map to %d entries.\n",
num_entries);
@@ -34,8 +28,18 @@
entries[i].addr = memrange->base;
entries[i].size = memrange->size;
- entries[i].type = memrange->type;
+
+ /*
+ * coreboot has some extensions (type 6 & 16) to the E820 types.
+ * When we detect this, mark it as E820_RESERVED.
+ */
+ if (memrange->type == CB_MEM_VENDOR_RSVD ||
+ memrange->type == CB_MEM_TABLE)
+ entries[i].type = E820_RESERVED;
+ else
+ entries[i].type = memrange->type;
}
+
return num_entries;
}
@@ -90,15 +94,15 @@
struct memrange *memrange = &lib_sysinfo.memrange[i];
unsigned long long end = memrange->base + memrange->size;
- if (memrange->type == CB_MEM_RAM && end > ram_size &&
- memrange->base < (1ULL << 32))
- ram_size = end;
+ if (memrange->type == CB_MEM_RAM && end > ram_size)
+ ram_size += memrange->size;
}
+
gd->ram_size = ram_size;
if (ram_size == 0)
return -1;
- return calculate_relocation_address();
+ return 0;
}
void dram_init_banksize(void)
@@ -109,8 +113,7 @@
for (i = 0, j = 0; i < lib_sysinfo.n_memranges; i++) {
struct memrange *memrange = &lib_sysinfo.memrange[i];
- if (memrange->type == CB_MEM_RAM &&
- memrange->base < (1ULL << 32)) {
+ if (memrange->type == CB_MEM_RAM) {
gd->bd->bi_dram[j].start = memrange->base;
gd->bd->bi_dram[j].size = memrange->size;
j++;
diff --git a/arch/x86/cpu/qemu/Makefile b/arch/x86/cpu/qemu/Makefile
index 9a66b16..1c00d1d 100644
--- a/arch/x86/cpu/qemu/Makefile
+++ b/arch/x86/cpu/qemu/Makefile
@@ -8,4 +8,5 @@
obj-y += car.o dram.o
endif
obj-y += qemu.o
+obj-$(CONFIG_GENERATE_ACPI_TABLE) += acpi.o dsdt.o
obj-$(CONFIG_PCI) += pci.o
diff --git a/arch/x86/cpu/qemu/acpi.c b/arch/x86/cpu/qemu/acpi.c
new file mode 100644
index 0000000..7752f80
--- /dev/null
+++ b/arch/x86/cpu/qemu/acpi.c
@@ -0,0 +1,176 @@
+/*
+ * Copyright (C) 2015, Saket Sinha <saket.sinha89@gmail.com>
+ *
+ * SPDX-License-Identifier: GPL-2.0+
+ */
+
+#include <common.h>
+#include <asm/acpi_table.h>
+#include <asm/ioapic.h>
+#include <asm/tables.h>
+
+void acpi_create_fadt(struct acpi_fadt *fadt, struct acpi_facs *facs,
+ void *dsdt)
+{
+ acpi_header_t *header = &(fadt->header);
+ u16 pmbase;
+
+ pci_dev_t bdf = PCI_BDF(0, 0x1f, 0);
+ pci_read_config_word(bdf, 0x40, &pmbase);
+
+ /*
+ * TODO(saket.sinha89@gmail.com): wrong value
+ * of pmbase by above function. Hard-coding it to
+ * correct value. Since no PCI register is
+ * programmed Power Management Interface is
+ * not working
+ */
+ pmbase = 0x0600;
+
+ memset((void *)fadt, 0, sizeof(struct acpi_fadt));
+ memcpy(header->signature, "FACP", 4);
+ header->length = sizeof(struct acpi_fadt);
+ header->revision = 3;
+ memcpy(header->oem_id, OEM_ID, 6);
+ memcpy(header->oem_table_id, ACPI_TABLE_CREATOR, 8);
+ memcpy(header->asl_compiler_id, ASLC, 4);
+ header->asl_compiler_revision = 0;
+
+ fadt->firmware_ctrl = (unsigned long) facs;
+ fadt->dsdt = (unsigned long) dsdt;
+ fadt->model = 0x00;
+ fadt->preferred_pm_profile = PM_MOBILE;
+ fadt->sci_int = 0x9;
+ fadt->smi_cmd = 0;
+ fadt->acpi_enable = 0;
+ fadt->acpi_disable = 0;
+ fadt->s4bios_req = 0x0;
+ fadt->pstate_cnt = 0;
+ fadt->pm1a_evt_blk = pmbase;
+ fadt->pm1b_evt_blk = 0x0;
+ fadt->pm1a_cnt_blk = pmbase + 0x4;
+ fadt->pm1b_cnt_blk = 0x0;
+ fadt->pm2_cnt_blk = pmbase + 0x50;
+ fadt->pm_tmr_blk = pmbase + 0x8;
+ fadt->gpe0_blk = pmbase + 0x20;
+ fadt->gpe1_blk = 0;
+ fadt->pm1_evt_len = 4;
+ /*
+ * Upper word is reserved and
+ * Linux complains about 32 bit
+ */
+ fadt->pm1_cnt_len = 2;
+ fadt->pm2_cnt_len = 1;
+ fadt->pm_tmr_len = 4;
+ fadt->gpe0_blk_len = 16;
+ fadt->gpe1_blk_len = 0;
+ fadt->gpe1_base = 0;
+ fadt->cst_cnt = 0;
+ fadt->p_lvl2_lat = 1;
+ fadt->p_lvl3_lat = 0x39;
+ fadt->flush_size = 0;
+ fadt->flush_stride = 0;
+ fadt->duty_offset = 1;
+ fadt->duty_width = 3;
+ fadt->day_alrm = 0xd;
+ fadt->mon_alrm = 0x00;
+ fadt->century = 0x32;
+ fadt->iapc_boot_arch = 0x00;
+ fadt->flags = ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
+ ACPI_FADT_SLEEP_BUTTON | ACPI_FADT_S4_RTC_WAKE |
+ ACPI_FADT_DOCKING_SUPPORTED | ACPI_FADT_RESET_REGISTER |
+ ACPI_FADT_PLATFORM_CLOCK;
+ fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
+ fadt->reset_reg.bit_width = 8;
+ fadt->reset_reg.bit_offset = 0;
+ fadt->reset_reg.resv = 0;
+ fadt->reset_reg.addrl = 0xcf9;
+ fadt->reset_reg.addrh = 0;
+ fadt->reset_value = 0x06;
+ /*
+ * Set X_FIRMWARE_CTRL only if FACS is
+ * above 4GB. If X_FIRMWARE_CTRL is set,
+ * then FIRMWARE_CTRL must be zero
+ */
+ fadt->x_firmware_ctl_l = 0;
+ fadt->x_firmware_ctl_h = 0;
+ fadt->x_dsdt_l = (unsigned long)dsdt;
+ fadt->x_dsdt_h = 0;
+ fadt->x_pm1a_evt_blk.space_id = 1;
+ fadt->x_pm1a_evt_blk.bit_width = 32;
+ fadt->x_pm1a_evt_blk.bit_offset = 0;
+ fadt->x_pm1a_evt_blk.resv = 0;
+ fadt->x_pm1a_evt_blk.addrl = pmbase;
+ fadt->x_pm1a_evt_blk.addrh = 0x0;
+ fadt->x_pm1b_evt_blk.space_id = 0;
+ fadt->x_pm1b_evt_blk.bit_width = 0;
+ fadt->x_pm1b_evt_blk.bit_offset = 0;
+ fadt->x_pm1b_evt_blk.resv = 0;
+ fadt->x_pm1b_evt_blk.addrl = 0x0;
+ fadt->x_pm1b_evt_blk.addrh = 0x0;
+ fadt->x_pm1a_cnt_blk.space_id = 1;
+ /*
+ * Upper word is reserved and
+ * Linux complains about 32 bit
+ */
+ fadt->x_pm1a_cnt_blk.bit_width = 16;
+ fadt->x_pm1a_cnt_blk.bit_offset = 0;
+ fadt->x_pm1a_cnt_blk.resv = 0;
+ fadt->x_pm1a_cnt_blk.addrl = pmbase + 0x4;
+ fadt->x_pm1a_cnt_blk.addrh = 0x0;
+ fadt->x_pm1b_cnt_blk.space_id = 0;
+ fadt->x_pm1b_cnt_blk.bit_width = 0;
+ fadt->x_pm1b_cnt_blk.bit_offset = 0;
+ fadt->x_pm1b_cnt_blk.resv = 0;
+ fadt->x_pm1b_cnt_blk.addrl = 0x0;
+ fadt->x_pm1b_cnt_blk.addrh = 0x0;
+ fadt->x_pm2_cnt_blk.space_id = 1;
+ fadt->x_pm2_cnt_blk.bit_width = 8;
+ fadt->x_pm2_cnt_blk.bit_offset = 0;
+ fadt->x_pm2_cnt_blk.resv = 0;
+ fadt->x_pm2_cnt_blk.addrl = pmbase + 0x50;
+ fadt->x_pm2_cnt_blk.addrh = 0x0;
+ fadt->x_pm_tmr_blk.space_id = 1;
+ fadt->x_pm_tmr_blk.bit_width = 32;
+ fadt->x_pm_tmr_blk.bit_offset = 0;
+ fadt->x_pm_tmr_blk.resv = 0;
+ fadt->x_pm_tmr_blk.addrl = pmbase + 0x8;
+ fadt->x_pm_tmr_blk.addrh = 0x0;
+ fadt->x_gpe0_blk.space_id = 1;
+ fadt->x_gpe0_blk.bit_width = 128;
+ fadt->x_gpe0_blk.bit_offset = 0;
+ fadt->x_gpe0_blk.resv = 0;
+ fadt->x_gpe0_blk.addrl = pmbase + 0x20;
+ fadt->x_gpe0_blk.addrh = 0x0;
+ fadt->x_gpe1_blk.space_id = 0;
+ fadt->x_gpe1_blk.bit_width = 0;
+ fadt->x_gpe1_blk.bit_offset = 0;
+ fadt->x_gpe1_blk.resv = 0;
+ fadt->x_gpe1_blk.addrl = 0x0;
+ fadt->x_gpe1_blk.addrh = 0x0;
+
+ header->checksum = table_compute_checksum((void *)fadt, header->length);
+}
+
+unsigned long acpi_fill_madt(unsigned long current)
+{
+ /* create all subtables for processors */
+ current = acpi_create_madt_lapics(current);
+
+ /*
+ * TODO(saket.sinha89@gmail.com): get these
+ * IRQ values from device tree
+ */
+ current += acpi_create_madt_ioapic((struct acpi_madt_ioapic *)current,
+ 2, IO_APIC_ADDR, 0);
+ current += acpi_create_madt_irqoverride(
+ (struct acpi_madt_irqoverride *)current, 0, 0, 2, 0);
+ current += acpi_create_madt_irqoverride(
+ (struct acpi_madt_irqoverride *)current, 0, 9, 9, 0xd);
+ current += acpi_create_madt_irqoverride(
+ (struct acpi_madt_irqoverride *)current, 0, 0xd, 0xd, 0xd);
+ acpi_create_madt_lapic_nmi(
+ (struct acpi_madt_lapic_nmi *)current, 0, 0, 0);
+
+ return current;
+}
diff --git a/arch/x86/cpu/qemu/acpi/cpu-hotplug.asl b/arch/x86/cpu/qemu/acpi/cpu-hotplug.asl
new file mode 100644
index 0000000..a290a4c
--- /dev/null
+++ b/arch/x86/cpu/qemu/acpi/cpu-hotplug.asl
@@ -0,0 +1,80 @@
+/* CPU hotplug */
+
+Scope(\_SB) {
+ /* Objects filled in by run-time generated SSDT */
+ External(NTFY, MethodObj)
+ External(CPON, PkgObj)
+
+ /* Methods called by run-time generated SSDT Processor objects */
+ Method(CPMA, 1, NotSerialized) {
+ /*
+ * _MAT method - create an madt apic buffer
+ * Arg0 = Processor ID = Local APIC ID
+ * Local0 = CPON flag for this cpu
+ */
+ Store(DerefOf(Index(CPON, Arg0)), Local0)
+ /* Local1 = Buffer (in madt apic form) to return */
+ Store(Buffer(8) {0x00, 0x08, 0x00, 0x00, 0x00, 0, 0, 0}, Local1)
+ /* Update the processor id, lapic id, and enable/disable status */
+ Store(Arg0, Index(Local1, 2))
+ Store(Arg0, Index(Local1, 3))
+ Store(Local0, Index(Local1, 4))
+ Return (Local1)
+ }
+ Method(CPST, 1, NotSerialized) {
+ /*
+ * _STA method - return ON status of cpu
+ * Arg0 = Processor ID = Local APIC ID
+ * Local0 = CPON flag for this cpu
+ */
+ Store(DerefOf(Index(CPON, Arg0)), Local0)
+ If (Local0) {
+ Return (0xf)
+ } Else {
+ Return (0x0)
+ }
+ }
+ Method(CPEJ, 2, NotSerialized) {
+ /* _EJ0 method - eject callback */
+ Sleep(200)
+ }
+
+ /* CPU hotplug notify method */
+ OperationRegion(PRST, SystemIO, 0xaf00, 32)
+ Field(PRST, ByteAcc, NoLock, Preserve) {
+ PRS, 256
+ }
+ Method(PRSC, 0) {
+ /* Local5 = active cpu bitmap */
+ Store(PRS, Local5)
+ /* Local2 = last read byte from bitmap */
+ Store(Zero, Local2)
+ /* Local0 = Processor ID / APIC ID iterator */
+ Store(Zero, Local0)
+ While (LLess(Local0, SizeOf(CPON))) {
+ /* Local1 = CPON flag for this cpu */
+ Store(DerefOf(Index(CPON, Local0)), Local1)
+ If (And(Local0, 0x07)) {
+ /* Shift down previously read bitmap byte */
+ ShiftRight(Local2, 1, Local2)
+ } Else {
+ /* Read next byte from cpu bitmap */
+ Store(DerefOf(Index(Local5, ShiftRight(Local0, 3))), Local2)
+ }
+ /* Local3 = active state for this cpu */
+ Store(And(Local2, 1), Local3)
+
+ If (LNotEqual(Local1, Local3)) {
+ /* State change - update CPON with new state */
+ Store(Local3, Index(CPON, Local0))
+ /* Do CPU notify */
+ If (LEqual(Local3, 1)) {
+ NTFY(Local0, 1)
+ } Else {
+ NTFY(Local0, 3)
+ }
+ }
+ Increment(Local0)
+ }
+ }
+}
diff --git a/arch/x86/cpu/qemu/acpi/dbug.asl b/arch/x86/cpu/qemu/acpi/dbug.asl
new file mode 100644
index 0000000..38a6526
--- /dev/null
+++ b/arch/x86/cpu/qemu/acpi/dbug.asl
@@ -0,0 +1,25 @@
+/* Debugging */
+
+Scope(\) {
+ /* Debug Output */
+ OperationRegion(DBG, SystemIO, 0x0402, 0x01)
+ Field(DBG, ByteAcc, NoLock, Preserve) {
+ DBGB, 8,
+ }
+ /*
+ * Debug method - use this method to send output to the QEMU
+ * BIOS debug port. This method handles strings, integers,
+ * and buffers. For example: DBUG("abc") DBUG(0x123)
+ */
+ Method(DBUG, 1) {
+ ToHexString(Arg0, Local0)
+ ToBuffer(Local0, Local0)
+ Subtract(SizeOf(Local0), 1, Local1)
+ Store(Zero, Local2)
+ While (LLess(Local2, Local1)) {
+ Store(DerefOf(Index(Local0, Local2)), DBGB)
+ Increment(Local2)
+ }
+ Store(0x0a, dbgb)
+ }
+}
diff --git a/arch/x86/cpu/qemu/acpi/hpet.asl b/arch/x86/cpu/qemu/acpi/hpet.asl
new file mode 100644
index 0000000..983151e
--- /dev/null
+++ b/arch/x86/cpu/qemu/acpi/hpet.asl
@@ -0,0 +1,31 @@
+/* HPET */
+
+Scope(\_SB) {
+ Device(HPET) {
+ Name(_HID, EISAID("PNP0103"))
+ Name(_UID, 0)
+ OperationRegion(HPTM, SystemMemory, 0xfed00000, 0x400)
+ Field(HPTM, DWordAcc, Lock, Preserve) {
+ VEND, 32,
+ PRD, 32,
+ }
+ Method(_STA, 0, NotSerialized) {
+ Store(VEND, Local0)
+ Store(PRD, Local1)
+ ShiftRight(Local0, 16, Local0)
+ If (LOr(LEqual(Local0, 0), LEqual(Local0, 0xffff))) {
+ Return (0x0)
+ }
+ If (LOr(LEqual(Local1, 0), LGreater(Local1, 100000000))) {
+ Return (0x0)
+ }
+ Return (0x0f)
+ }
+ Name(_CRS, ResourceTemplate() {
+ Memory32Fixed(ReadOnly,
+ 0xfed00000, /* Address Base */
+ 0x00000400, /* Address Length */
+ )
+ })
+ }
+}
diff --git a/arch/x86/cpu/qemu/acpi/isa.asl b/arch/x86/cpu/qemu/acpi/isa.asl
new file mode 100644
index 0000000..d6b3d9b
--- /dev/null
+++ b/arch/x86/cpu/qemu/acpi/isa.asl
@@ -0,0 +1,102 @@
+/* Common legacy ISA style devices. */
+Scope(\_SB.PCI0.ISA) {
+
+ Device(RTC) {
+ Name(_HID, EisaId("PNP0B00"))
+ Name(_CRS, ResourceTemplate() {
+ IO(Decode16, 0x0070, 0x0070, 0x10, 0x02)
+ IRQNoFlags() { 8 }
+ IO(Decode16, 0x0072, 0x0072, 0x02, 0x06)
+ })
+ }
+
+ Device(KBD) {
+ Name(_HID, EisaId("PNP0303"))
+ Method(_STA, 0, NotSerialized) {
+ Return (0x0f)
+ }
+ Name(_CRS, ResourceTemplate() {
+ IO(Decode16, 0x0060, 0x0060, 0x01, 0x01)
+ IO(Decode16, 0x0064, 0x0064, 0x01, 0x01)
+ IRQNoFlags() { 1 }
+ })
+ }
+
+ Device(MOU) {
+ Name(_HID, EisaId("PNP0F13"))
+ Method(_STA, 0, NotSerialized) {
+ Return (0x0f)
+ }
+ Name(_CRS, ResourceTemplate() {
+ IRQNoFlags() { 12 }
+ })
+ }
+
+ Device(FDC0) {
+ Name(_HID, EisaId("PNP0700"))
+ Method(_STA, 0, NotSerialized) {
+ Store(FDEN, Local0)
+ If (LEqual(Local0, 0)) {
+ Return (0x00)
+ } Else {
+ Return (0x0f)
+ }
+ }
+ Name(_CRS, ResourceTemplate() {
+ IO(Decode16, 0x03f2, 0x03f2, 0x00, 0x04)
+ IO(Decode16, 0x03f7, 0x03f7, 0x00, 0x01)
+ IRQNoFlags() { 6 }
+ DMA(Compatibility, NotBusMaster, Transfer8) { 2 }
+ })
+ }
+
+ Device(LPT) {
+ Name(_HID, EisaId("PNP0400"))
+ Method(_STA, 0, NotSerialized) {
+ Store(LPEN, Local0)
+ If (LEqual(Local0, 0)) {
+ Return (0x00)
+ } Else {
+ Return (0x0f)
+ }
+ }
+ Name(_CRS, ResourceTemplate() {
+ IO(Decode16, 0x0378, 0x0378, 0x08, 0x08)
+ IRQNoFlags() { 7 }
+ })
+ }
+
+ Device(COM1) {
+ Name(_HID, EisaId("PNP0501"))
+ Name(_UID, 0x01)
+ Method(_STA, 0, NotSerialized) {
+ Store(CAEN, Local0)
+ If (LEqual(Local0, 0)) {
+ Return (0x00)
+ } Else {
+ Return (0x0f)
+ }
+ }
+ Name(_CRS, ResourceTemplate() {
+ IO(Decode16, 0x03f8, 0x03f8, 0x00, 0x08)
+ IRQNoFlags() { 4 }
+ })
+ }
+
+ Device(COM2) {
+ Name(_HID, EisaId("PNP0501"))
+ Name(_UID, 0x02)
+ Method(_STA, 0, NotSerialized) {
+ Store(CBEN, Local0)
+ If (LEqual(Local0, 0)) {
+ Return (0x00)
+ } Else {
+ Return (0x0f)
+ }
+ }
+ Name(_CRS, ResourceTemplate() {
+ IO(Decode16, 0x02f8, 0x02f8, 0x00, 0x08)
+ IRQNoFlags() { 3 }
+ })
+ }
+}
diff --git a/arch/x86/cpu/qemu/acpi/pci-crs.asl b/arch/x86/cpu/qemu/acpi/pci-crs.asl
new file mode 100644
index 0000000..a336dce
--- /dev/null
+++ b/arch/x86/cpu/qemu/acpi/pci-crs.asl
@@ -0,0 +1,61 @@
+/* PCI CRS (current resources) definition. */
+Scope(\_SB.PCI0) {
+
+ Name(CRES, ResourceTemplate() {
+ WordBusNumber(ResourceProducer, MinFixed, MaxFixed, PosDecode,
+ 0x0000, /* Address Space Granularity */
+ 0x0000, /* Address Range Minimum */
+ 0x00ff, /* Address Range Maximum */
+ 0x0000, /* Address Translation Offset */
+ 0x0100, /* Address Length */
+ ,, )
+ IO(Decode16,
+ 0x0cf8, /* Address Range Minimum */
+ 0x0cf8, /* Address Range Maximum */
+ 0x01, /* Address Alignment */
+ 0x08, /* Address Length */
+ )
+ WordIO(ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange,
+ 0x0000, /* Address Space Granularity */
+ 0x0000, /* Address Range Minimum */
+ 0x0cf7, /* Address Range Maximum */
+ 0x0000, /* Address Translation Offset */
+ 0x0cf8, /* Address Length */
+ ,, , TypeStatic)
+ WordIO(ResourceProducer, MinFixed, MaxFixed, PosDecode, EntireRange,
+ 0x0000, /* Address Space Granularity */
+ 0x0d00, /* Address Range Minimum */
+ 0xffff, /* Address Range Maximum */
+ 0x0000, /* Address Translation Offset */
+ 0xf300, /* Address Length */
+ ,, , TypeStatic)
+ DWordMemory(ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
+ 0x00000000, /* Address Space Granularity */
+ 0x000a0000, /* Address Range Minimum */
+ 0x000bffff, /* Address Range Maximum */
+ 0x00000000, /* Address Translation Offset */
+ 0x00020000, /* Address Length */
+ ,, , AddressRangeMemory, TypeStatic)
+ DWordMemory(ResourceProducer, PosDecode, MinFixed, MaxFixed, NonCacheable, ReadWrite,
+ 0x00000000, /* Address Space Granularity */
+ 0xe0000000, /* Address Range Minimum */
+ 0xfebfffff, /* Address Range Maximum */
+ 0x00000000, /* Address Translation Offset */
+ 0x1ec00000, /* Address Length */
+ ,, PW32, AddressRangeMemory, TypeStatic)
+ })
+
+ Name(CR64, ResourceTemplate() {
+ QWordMemory(ResourceProducer, PosDecode, MinFixed, MaxFixed, Cacheable, ReadWrite,
+ 0x00000000, /* Address Space Granularity */
+ 0x80000000, /* Address Range Minimum */
+ 0xffffffff, /* Address Range Maximum */
+ 0x00000000, /* Address Translation Offset */
+ 0x80000000, /* Address Length */
+ ,, PW64, AddressRangeMemory, TypeStatic)
+ })
+
+ Method(_CRS, 0) {
+ Return (CRES)
+ }
+}
diff --git a/arch/x86/cpu/qemu/dsdt.asl b/arch/x86/cpu/qemu/dsdt.asl
new file mode 100644
index 0000000..2b10f90
--- /dev/null
+++ b/arch/x86/cpu/qemu/dsdt.asl
@@ -0,0 +1,412 @@
+/*
+ * QEMU ACPI DSDT ASL definition
+ *
+ * Copyright (c) 2006 Fabrice Bellard
+ *
+ * Copyright (c) 2010 Isaku Yamahata
+ * yamahata at valinux co jp
+ * Based on acpi-dsdt.dsl, but heavily modified for q35 chipset.
+ */
+
+DefinitionBlock (
+ "dsdt.aml", /* Output Filename */
+ "DSDT", /* Signature */
+ 0x01, /* DSDT Compliance Revision */
+ "UBOO", /* OEMID */
+ "UBOOT ", /* TABLE ID */
+ 0x2 /* OEM Revision */
+ )
+{
+
+#include "acpi/dbug.asl"
+
+ Scope(\_SB) {
+ OperationRegion(PCST, SystemIO, 0xae00, 0x0c)
+ OperationRegion(PCSB, SystemIO, 0xae0c, 0x01)
+ Field(PCSB, AnyAcc, NoLock, WriteAsZeros) {
+ PCIB, 8,
+ }
+ }
+
+
+/* PCI Bus definition */
+
+ Scope(\_SB) {
+ Device(PCI0) {
+ Name(_HID, EisaId("PNP0A08"))
+ Name(_CID, EisaId("PNP0A03"))
+ Name(_ADR, 0x00)
+ Name(_UID, 1)
+
+ /* _OSC: based on sample of ACPI3.0b spec */
+ Name(SUPP, 0) /* PCI _OSC Support Field value */
+ Name(CTRL, 0) /* PCI _OSC Control Field value */
+ Method(_OSC, 4) {
+ /* Create DWORD-addressable fields from Capabilities Buffer */
+ CreateDWordField(Arg3, 0, CDW1)
+
+ /* Check for proper UUID */
+ If (LEqual(Arg0, ToUUID("33DB4D5B-1FF7-401C-9657-7441C03DD766")))
+ {
+ /* Create DWORD-addressable fields from Capabilities Buffer */
+ CreateDWordField(Arg3, 4, CDW2)
+ CreateDWordField(Arg3, 8, CDW3)
+
+ /* Save Capabilities DWORD2 & 3 */
+ Store(CDW2, SUPP)
+ Store(CDW3, CTRL)
+
+ /*
+ * Always allow native PME, AER (no dependencies)
+ * Never allow SHPC (no SHPC controller in this system)
+ */
+ And(CTRL, 0x1d, CTRL)
+
+ If (LNotEqual(Arg1, One)) {
+ /* Unknown revision */
+ Or(CDW1, 0x08, CDW1)
+ }
+ If (LNotEqual(CDW3, CTRL)) {
+ /* Capabilities bits were masked */
+ Or(CDW1, 0x10, CDW1)
+ }
+ /* Update DWORD3 in the buffer */
+ Store(CTRL, CDW3)
+ } Else {
+ Or(CDW1, 4, CDW1) /* Unrecognized UUID */
+ }
+ Return (Arg3)
+ }
+ }
+ }
+
+#include "acpi/pci-crs.asl"
+#include "acpi/hpet.asl"
+
+
+/* VGA */
+
+ Scope(\_SB.PCI0) {
+ Device(VGA) {
+ Name(_ADR, 0x00010000)
+ Method(_S1D, 0, NotSerialized) {
+ Return (0x00)
+ }
+ Method(_S2D, 0, NotSerialized) {
+ Return (0x00)
+ }
+ Method(_S3D, 0, NotSerialized) {
+ Return (0x00)
+ }
+ }
+ }
+
+
+/* LPC ISA bridge */
+
+ Scope(\_SB.PCI0) {
+ /* PCI D31:f0 LPC ISA bridge */
+ Device(ISA) {
+ /* PCI D31:f0 */
+ Name(_ADR, 0x001f0000)
+
+ /* ICH9 PCI to ISA irq remapping */
+ OperationRegion(PIRQ, PCI_Config, 0x60, 0x0c)
+
+ OperationRegion(LPCD, PCI_Config, 0x80, 0x2)
+ Field(LPCD, AnyAcc, NoLock, Preserve) {
+ COMA, 3,
+ , 1,
+ COMB, 3,
+
+ Offset(0x01),
+ LPTD, 2,
+ , 2,
+ FDCD, 2
+ }
+ OperationRegion(LPCE, PCI_Config, 0x82, 0x2)
+ Field(LPCE, AnyAcc, NoLock, Preserve) {
+ CAEN, 1,
+ CBEN, 1,
+ LPEN, 1,
+ FDEN, 1
+ }
+ }
+ }
+
+#include "acpi/isa.asl"
+
+
+/* PCI IRQs */
+
+ /* Zero => PIC mode, One => APIC Mode */
+ Name(\PICF, Zero)
+ Method(\_PIC, 1, NotSerialized) {
+ Store(Arg0, \PICF)
+ }
+
+ Scope(\_SB) {
+ Scope(PCI0) {
+#define prt_slot_lnk(nr, lnk0, lnk1, lnk2, lnk3) \
+ Package() { nr##ffff, 0, lnk0, 0 }, \
+ Package() { nr##ffff, 1, lnk1, 0 }, \
+ Package() { nr##ffff, 2, lnk2, 0 }, \
+ Package() { nr##ffff, 3, lnk3, 0 }
+
+#define prt_slot_lnkA(nr) prt_slot_lnk(nr, LNKA, LNKB, LNKC, LNKD)
+#define prt_slot_lnkB(nr) prt_slot_lnk(nr, LNKB, LNKC, LNKD, LNKA)
+#define prt_slot_lnkC(nr) prt_slot_lnk(nr, LNKC, LNKD, LNKA, LNKB)
+#define prt_slot_lnkD(nr) prt_slot_lnk(nr, LNKD, LNKA, LNKB, LNKC)
+
+#define prt_slot_lnkE(nr) prt_slot_lnk(nr, LNKE, LNKF, LNKG, LNKH)
+#define prt_slot_lnkF(nr) prt_slot_lnk(nr, LNKF, LNKG, LNKH, LNKE)
+#define prt_slot_lnkG(nr) prt_slot_lnk(nr, LNKG, LNKH, LNKE, LNKF)
+#define prt_slot_lnkH(nr) prt_slot_lnk(nr, LNKH, LNKE, LNKF, LNKG)
+
+ Name(PRTP, Package() {
+ prt_slot_lnkE(0x0000),
+ prt_slot_lnkF(0x0001),
+ prt_slot_lnkG(0x0002),
+ prt_slot_lnkH(0x0003),
+ prt_slot_lnkE(0x0004),
+ prt_slot_lnkF(0x0005),
+ prt_slot_lnkG(0x0006),
+ prt_slot_lnkH(0x0007),
+ prt_slot_lnkE(0x0008),
+ prt_slot_lnkF(0x0009),
+ prt_slot_lnkG(0x000a),
+ prt_slot_lnkH(0x000b),
+ prt_slot_lnkE(0x000c),
+ prt_slot_lnkF(0x000d),
+ prt_slot_lnkG(0x000e),
+ prt_slot_lnkH(0x000f),
+ prt_slot_lnkE(0x0010),
+ prt_slot_lnkF(0x0011),
+ prt_slot_lnkG(0x0012),
+ prt_slot_lnkH(0x0013),
+ prt_slot_lnkE(0x0014),
+ prt_slot_lnkF(0x0015),
+ prt_slot_lnkG(0x0016),
+ prt_slot_lnkH(0x0017),
+ prt_slot_lnkE(0x0018),
+
+ /* INTA -> PIRQA for slot 25 - 31
+ see the default value of D<N>IR */
+ prt_slot_lnkA(0x0019),
+ prt_slot_lnkA(0x001a),
+ prt_slot_lnkA(0x001b),
+ prt_slot_lnkA(0x001c),
+ prt_slot_lnkA(0x001d),
+
+ /* PCIe->PCI bridge. use PIRQ[E-H] */
+ prt_slot_lnkE(0x001e),
+
+ prt_slot_lnkA(0x001f)
+ })
+
+#define prt_slot_gsi(nr, gsi0, gsi1, gsi2, gsi3) \
+ Package() { nr##ffff, 0, gsi0, 0 }, \
+ Package() { nr##ffff, 1, gsi1, 0 }, \
+ Package() { nr##ffff, 2, gsi2, 0 }, \
+ Package() { nr##ffff, 3, gsi3, 0 }
+
+#define prt_slot_gsiA(nr) prt_slot_gsi(nr, GSIA, GSIB, GSIC, GSID)
+#define prt_slot_gsiB(nr) prt_slot_gsi(nr, GSIB, GSIC, GSID, GSIA)
+#define prt_slot_gsiC(nr) prt_slot_gsi(nr, GSIC, GSID, GSIA, GSIB)
+#define prt_slot_gsiD(nr) prt_slot_gsi(nr, GSID, GSIA, GSIB, GSIC)
+
+#define prt_slot_gsiE(nr) prt_slot_gsi(nr, GSIE, GSIF, GSIG, GSIH)
+#define prt_slot_gsiF(nr) prt_slot_gsi(nr, GSIF, GSIG, GSIH, GSIE)
+#define prt_slot_gsiG(nr) prt_slot_gsi(nr, GSIG, GSIH, GSIE, GSIF)
+#define prt_slot_gsiH(nr) prt_slot_gsi(nr, GSIH, GSIE, GSIF, GSIG)
+
+ Name(PRTA, Package() {
+ prt_slot_gsiE(0x0000),
+ prt_slot_gsiF(0x0001),
+ prt_slot_gsiG(0x0002),
+ prt_slot_gsiH(0x0003),
+ prt_slot_gsiE(0x0004),
+ prt_slot_gsiF(0x0005),
+ prt_slot_gsiG(0x0006),
+ prt_slot_gsiH(0x0007),
+ prt_slot_gsiE(0x0008),
+ prt_slot_gsiF(0x0009),
+ prt_slot_gsiG(0x000a),
+ prt_slot_gsiH(0x000b),
+ prt_slot_gsiE(0x000c),
+ prt_slot_gsiF(0x000d),
+ prt_slot_gsiG(0x000e),
+ prt_slot_gsiH(0x000f),
+ prt_slot_gsiE(0x0010),
+ prt_slot_gsiF(0x0011),
+ prt_slot_gsiG(0x0012),
+ prt_slot_gsiH(0x0013),
+ prt_slot_gsiE(0x0014),
+ prt_slot_gsiF(0x0015),
+ prt_slot_gsiG(0x0016),
+ prt_slot_gsiH(0x0017),
+ prt_slot_gsiE(0x0018),
+
+ /*
+ * INTA -> PIRQA for slot 25 - 31, but 30
+ * see the default value of D<N>IR
+ */
+ prt_slot_gsiA(0x0019),
+ prt_slot_gsiA(0x001a),
+ prt_slot_gsiA(0x001b),
+ prt_slot_gsiA(0x001c),
+ prt_slot_gsiA(0x001d),
+
+ /* PCIe->PCI bridge. use PIRQ[E-H] */
+ prt_slot_gsiE(0x001e),
+
+ prt_slot_gsiA(0x001f)
+ })
+
+ Method(_PRT, 0, NotSerialized) {
+ /*
+ * PCI IRQ routing table,
+ * example from ACPI 2.0a
+ * specification, section 6.2.8.1
+ * Note: we provide the same info
+ * as the PCI routing table
+ * of the Bochs BIOS
+ */
+ If (LEqual(\PICF, Zero)) {
+ Return (PRTP)
+ } Else {
+ Return (PRTA)
+ }
+ }
+ }
+
+ Field(PCI0.ISA.PIRQ, ByteAcc, NoLock, Preserve) {
+ PRQA, 8,
+ PRQB, 8,
+ PRQC, 8,
+ PRQD, 8,
+
+ Offset(0x08),
+ PRQE, 8,
+ PRQF, 8,
+ PRQG, 8,
+ PRQH, 8
+ }
+
+ Method(IQST, 1, NotSerialized) {
+ /* _STA method - get status */
+ If (And(0x80, Arg0)) {
+ Return (0x09)
+ }
+ Return (0x0b)
+ }
+ Method(IQCR, 1, NotSerialized) {
+ /* _CRS method - get current settings */
+ Name(PRR0, ResourceTemplate() {
+ Interrupt(, Level, ActiveHigh, Shared) { 0 }
+ })
+ CreateDWordField(PRR0, 0x05, PRRI)
+ Store(And(Arg0, 0x0f), PRRI)
+ Return (PRR0)
+ }
+
+#define define_link(link, uid, reg) \
+ Device(link) { \
+ Name(_HID, EISAID("PNP0C0F")) \
+ Name(_UID, uid) \
+ Name(_PRS, ResourceTemplate() { \
+ Interrupt(, Level, ActiveHigh, Shared) { \
+ 5, 10, 11 \
+ } \
+ }) \
+ Method(_STA, 0, NotSerialized) { \
+ Return (IQST(reg)) \
+ } \
+ Method(_DIS, 0, NotSerialized) { \
+ Or(reg, 0x80, reg) \
+ } \
+ Method(_CRS, 0, NotSerialized) { \
+ Return (IQCR(reg)) \
+ } \
+ Method(_SRS, 1, NotSerialized) { \
+ CreateDWordField(Arg0, 0x05, PRRI) \
+ Store(PRRI, reg) \
+ } \
+ }
+
+ define_link(LNKA, 0, PRQA)
+ define_link(LNKB, 1, PRQB)
+ define_link(LNKC, 2, PRQC)
+ define_link(LNKD, 3, PRQD)
+ define_link(LNKE, 4, PRQE)
+ define_link(LNKF, 5, PRQF)
+ define_link(LNKG, 6, PRQG)
+ define_link(LNKH, 7, PRQH)
+
+#define define_gsi_link(link, uid, gsi) \
+ Device(link) { \
+ Name(_HID, EISAID("PNP0C0F")) \
+ Name(_UID, uid) \
+ Name(_PRS, ResourceTemplate() { \
+ Interrupt(, Level, ActiveHigh, Shared) { \
+ gsi \
+ } \
+ }) \
+ Name(_CRS, ResourceTemplate() { \
+ Interrupt(, Level, ActiveHigh, Shared) { \
+ gsi \
+ } \
+ }) \
+ Method(_SRS, 1, NotSerialized) { \
+ } \
+ }
+
+ define_gsi_link(GSIA, 0, 0x10)
+ define_gsi_link(GSIB, 0, 0x11)
+ define_gsi_link(GSIC, 0, 0x12)
+ define_gsi_link(GSID, 0, 0x13)
+ define_gsi_link(GSIE, 0, 0x14)
+ define_gsi_link(GSIF, 0, 0x15)
+ define_gsi_link(GSIG, 0, 0x16)
+ define_gsi_link(GSIH, 0, 0x17)
+ }
+
+/* General purpose events */
+
+ Scope(\_GPE) {
+ Name(_HID, "ACPI0006")
+
+ Method(_L00) {
+ }
+ Method(_L01) {
+ }
+ Method(_L02) {
+ }
+ Method(_L03) {
+ }
+ Method(_L04) {
+ }
+ Method(_L05) {
+ }
+ Method(_L06) {
+ }
+ Method(_L07) {
+ }
+ Method(_L08) {
+ }
+ Method(_L09) {
+ }
+ Method(_L0A) {
+ }
+ Method(_L0B) {
+ }
+ Method(_L0C) {
+ }
+ Method(_L0D) {
+ }
+ Method(_L0E) {
+ }
+ Method(_L0F) {
+ }
+ }
+}
diff --git a/arch/x86/cpu/queensbay/tnc.c b/arch/x86/cpu/queensbay/tnc.c
index c465642..9682cff 100644
--- a/arch/x86/cpu/queensbay/tnc.c
+++ b/arch/x86/cpu/queensbay/tnc.c
@@ -36,8 +36,6 @@
if (ret)
return ret;
- unprotect_spi_flash();
-
return 0;
}
@@ -80,5 +78,7 @@
int arch_misc_init(void)
{
+ unprotect_spi_flash();
+
return pirq_init();
}
diff --git a/arch/x86/cpu/start.S b/arch/x86/cpu/start.S
index e94ddc4..d072825 100644
--- a/arch/x86/cpu/start.S
+++ b/arch/x86/cpu/start.S
@@ -115,8 +115,10 @@
#endif
#else
/*
- * When we get here after car_init(), esp points to a temporary stack
- * and esi holds the HOB list address returned by the FSP.
+ * U-Boot enters here twice. For the first time it comes from
+ * car_init_done() with esp points to a temporary stack and esi
+ * set to zero. For the second time it comes from fsp_init_done()
+ * with esi holding the HOB list address returned by the FSP.
*/
#endif
/* Set up global data */
@@ -141,6 +143,14 @@
jz skip_hob
movl %esi, GD_HOB_LIST(%edx)
+ /*
+ * After fsp_init() returns, the stack has already been switched to a
+ * place within system memory as defined by CONFIG_FSP_TEMP_RAM_ADDR.
+ * Enlarge the size of malloc() pool before relocation since we have
+ * plenty of memory now.
+ */
+ subl $CONFIG_FSP_SYS_MALLOC_F_LEN, %esp
+ movl %esp, GD_MALLOC_BASE(%edx)
skip_hob:
#else
/* Store table pointer */
diff --git a/arch/x86/dts/bayleybay.dts b/arch/x86/dts/bayleybay.dts
index 8f0e192..d646987 100644
--- a/arch/x86/dts/bayleybay.dts
+++ b/arch/x86/dts/bayleybay.dts
@@ -230,6 +230,12 @@
update@0 {
#include "microcode/m0230671117.dtsi"
};
+ update@1 {
+#include "microcode/m0130673322.dtsi"
+ };
+ update@2 {
+#include "microcode/m0130679901.dtsi"
+ };
};
};
diff --git a/arch/x86/dts/crownbay.dts b/arch/x86/dts/crownbay.dts
index 3af9cc3..3e354c4 100644
--- a/arch/x86/dts/crownbay.dts
+++ b/arch/x86/dts/crownbay.dts
@@ -91,7 +91,6 @@
#address-cells = <3>;
#size-cells = <2>;
compatible = "pci-x86";
- device_type = "pci";
u-boot,dm-pre-reloc;
ranges = <0x02000000 0x0 0x40000000 0x40000000 0 0x80000000
0x42000000 0x0 0xc0000000 0xc0000000 0 0x20000000
@@ -100,14 +99,16 @@
pcie@17,0 {
#address-cells = <3>;
#size-cells = <2>;
- compatible = "intel,pci";
- device_type = "pci";
+ compatible = "pci-bridge";
+ u-boot,dm-pre-reloc;
+ reg = <0x0000b800 0x0 0x0 0x0 0x0>;
topcliff@0,0 {
#address-cells = <3>;
#size-cells = <2>;
- compatible = "intel,pci";
- device_type = "pci";
+ compatible = "pci-bridge";
+ u-boot,dm-pre-reloc;
+ reg = <0x00010000 0x0 0x0 0x0 0x0>;
pciuart0: uart@a,1 {
compatible = "pci8086,8811.00",
@@ -115,6 +116,7 @@
"pciclass,070002",
"pciclass,0700",
"x86-uart";
+ u-boot,dm-pre-reloc;
reg = <0x00025100 0x0 0x0 0x0 0x0
0x01025110 0x0 0x0 0x0 0x0>;
reg-shift = <0>;
@@ -128,6 +130,7 @@
"pciclass,070002",
"pciclass,0700",
"x86-uart";
+ u-boot,dm-pre-reloc;
reg = <0x00025200 0x0 0x0 0x0 0x0
0x01025210 0x0 0x0 0x0 0x0>;
reg-shift = <0>;
@@ -141,6 +144,7 @@
"pciclass,070002",
"pciclass,0700",
"x86-uart";
+ u-boot,dm-pre-reloc;
reg = <0x00025300 0x0 0x0 0x0 0x0
0x01025310 0x0 0x0 0x0 0x0>;
reg-shift = <0>;
@@ -154,6 +158,7 @@
"pciclass,070002",
"pciclass,0700",
"x86-uart";
+ u-boot,dm-pre-reloc;
reg = <0x00025400 0x0 0x0 0x0 0x0
0x01025410 0x0 0x0 0x0 0x0>;
reg-shift = <0>;
@@ -168,7 +173,7 @@
compatible = "intel,irq-router";
intel,pirq-config = "pci";
intel,pirq-link = <0x60 8>;
- intel,pirq-mask = <0xdee0>;
+ intel,pirq-mask = <0xcee0>;
intel,pirq-routing = <
/* TunnelCreek PCI devices */
PCI_BDF(0, 2, 0) INTA PIRQE
diff --git a/arch/x86/dts/microcode/m0130679901.dtsi b/arch/x86/dts/microcode/m0130679901.dtsi
new file mode 100644
index 0000000..11aaaa0
--- /dev/null
+++ b/arch/x86/dts/microcode/m0130679901.dtsi
@@ -0,0 +1,3284 @@
+/*
+ * ---
+ * This is a device tree fragment. Use #include to add these properties to a
+ * node.
+ *
+ * Date:
+ */
+
+compatible = "intel,microcode";
+intel,header-version = <1>;
+intel,update-revision = <0x901>;
+intel,date-code = <0x4212014>;
+intel,processor-signature = <0x30679>;
+intel,checksum = <0x69c4e6f1>;
+intel,loader-revision = <1>;
+intel,processor-flags = <0x1>;
+
+/* The first 48-bytes are the public header which repeats the above data */
+data = <
+ 0x01000000 0x01090000 0x14202104 0x79060300
+ 0xf1e6c469 0x01000000 0x01000000 0xd0cb0000
+ 0x00cc0000 0x00000000 0x00000000 0x00000000
+ 0x00000000 0xa1000000 0x01000200 0x01090000
+ 0x00000000 0x00000000 0x18041420 0x01320000
+ 0x01000000 0x79060300 0x00000000 0x00000000
+ 0x00000000 0x00000000 0x00000000 0x00000000
+ 0x00000000 0xf4320000 0x00000000 0x00000000
+ 0x00000000 0x00000000 0x00000000 0x00000000
+ 0x3b6ec6fe 0xc0fda75e 0xb4ea6a9f 0x8fd6ed15
+ 0xd537f374 0x669bf3bb 0xebedec72 0xb4cbc889
+ 0xdb666815 0x5a17bfc4 0x4fca009d 0x099ae8b3
+ 0x198e2c7d 0x7c665bbf 0xc07a1a7a 0x7dbcee26
+ 0x867296b2 0xc885b6ce 0xe602baff 0x68544b14
+ 0xc928c400 0x3add156d 0x531946f9 0x92a03216
+ 0xda352322 0xd967ee1f 0x3c5170a7 0xf6de834e
+ 0x5a2ed8b3 0x9fb8f050 0x450de17f 0xfd5ef070
+ 0x4954575f 0xa3a071ab 0xb56e2afb 0xe2b48302
+ 0x6655a958 0x57c9a438 0x1b2f688a 0x09309bc4
+ 0x0be95612 0x529c1633 0xc48515d9 0x29eb78df
+ 0x9933409f 0xda58dea9 0x58c805fd 0xbc110f5a
+ 0x40780ec0 0x6ad59bb3 0xc7387fb8 0x591c1490
+ 0xf9335932 0x32130e0b 0xef4b3c96 0xacd903f2
+ 0x5b362539 0xe7f85529 0xcb17c41f 0xe7e440d8
+ 0xfaf7e925 0x969b76fb 0x5edab8c7 0xf00012e8
+ 0x121c2971 0xe5b18959 0xadfd07c0 0x1f09c9d7
+ 0x9781006a 0x39550073 0x6c438b6d 0x436f60bc
+ 0x11000000 0xf03f27bc 0x3ed2262b 0xe1f8f63d
+ 0xc164c68f 0x92e5df39 0x46108645 0x99a9968f
+ 0x1dfa58a4 0xd1ebfd99 0xca4dae70 0xe466a06a
+ 0x49575333 0xe30f49f0 0x814e5961 0xfa4bb7bd
+ 0x2e212282 0x31912456 0x7d722c47 0x9cda0657
+ 0x111985e9 0xd28d3b0b 0xec52f0c2 0x956b5b95
+ 0x0806f491 0xa8096786 0x1e4c1248 0x42ea1ecf
+ 0xea09d662 0xa821f68e 0x4b84d60a 0xa6f61348
+ 0xfc95c139 0xebcebc32 0xd68ffe3e 0xa9aefabe
+ 0xf653aafc 0x2a9f10e4 0xdaf3d51d 0x5f25aaa5
+ 0xdedacabe 0xf2e08b12 0x6fb9f444 0x31b13d4e
+ 0x13074cd3 0x68905491 0x08ce3a00 0xb3e5a3dc
+ 0x9554ca97 0x5955c3a4 0x2e9951fd 0x5d708c9f
+ 0xf3abe824 0xcb9105a1 0x3f51122e 0xd2152f23
+ 0x2873cd28 0x463c0ff3 0x7bb81500 0xaa360665
+ 0xbe69bdf9 0xa32415d6 0x111af68c 0xd129eaf6
+ 0xdd102779 0x098a2b08 0x90363b85 0xdb5d3420
+ 0xd1d116e3 0x9e5dd54e 0xb4a93d32 0xb5ee99fe
+ 0x409f0bca 0x40302319 0xe175ddaa 0xfd7c8d00
+ 0x2c28edb9 0x698d27f4 0x2e7945f1 0xc0150485
+ 0xf9c599fc 0x139824cb 0x1571f70e 0x222565e8
+ 0x3377eb7a 0x70fdee6f 0xd409f0a6 0xc875d05f
+ 0x70d6a86b 0x66201d61 0xf8fcb733 0x14279707
+ 0xc204e0e4 0x124c89be 0x8b298d1d 0x79bfe168
+ 0xdbf7fe94 0x0358af09 0x8291ef8a 0x3e74a2ea
+ 0xb7780782 0x0194d445 0x0bab231d 0xd76f85b2
+ 0xc7510861 0x4b9a5c80 0x6c9c8583 0x4e18d7db
+ 0x7dfeaea8 0x59be4d17 0x8e96f5b7 0x51bcb2da
+ 0x5f3afeed 0xd3f46ecd 0x10da04eb 0x29dd87db
+ 0xb7df24c5 0xd58dc2dc 0xede0603f 0xadf00cf7
+ 0x50090b9f 0xc9130c82 0x854fc603 0x13b8b4be
+ 0x10e2e41f 0x5c1d2246 0x0ee11843 0x6d38356d
+ 0xd3bd47ae 0xb419f115 0xb118cac7 0x9c61aa7d
+ 0xca22cf8a 0xd41af2f1 0x0b5ebfab 0xc0889746
+ 0x078c705f 0x9e5b2b7a 0xb886ff49 0x1ab413e4
+ 0x085cebc5 0xe3a44ab5 0x8844df92 0x075a79cf
+ 0xb8fdc33b 0x1766265c 0x9340a734 0x4af860c9
+ 0xa933586e 0x3e8a9a5c 0xf6419a1b 0xa70a1556
+ 0xf930240e 0xe294fb1f 0x9bba35c5 0x4051819b
+ 0x6799015f 0x7eb725ad 0x3953fe03 0xb8760679
+ 0x54c7978c 0x3dfd36c2 0x631212bb 0xdeaca312
+ 0x56d994dc 0x3a1696d1 0x214451fd 0x6dc505f7
+ 0x7bbf210f 0xa266b569 0x8fb5eb6f 0xa6b76bf8
+ 0xc9e782a1 0x8456765d 0x0a9eb223 0xa67e533f
+ 0x211016f4 0xd8783c3e 0xc35574b8 0xd97e9b52
+ 0x28ad2911 0xbffc5dad 0xd807d783 0x3050f3d1
+ 0xcc33efa8 0xb9cf97c2 0xee5dfc8c 0x2adad5bb
+ 0x4011c50b 0xa16f5d93 0x5e2ac188 0x521c977f
+ 0x6af1b858 0xcd7e4b4c 0xfc988f66 0xc0e4cee9
+ 0x82ac99ea 0x54353832 0x2308e02f 0xd084d198
+ 0x03574ad5 0xbe4b698f 0xe1d7d294 0xd772d08d
+ 0xb7a4fb2a 0xf7c93bb8 0x42fb2f4b 0x98cb1a11
+ 0xf564f28e 0xd6ace35f 0xc43f6639 0x85be741d
+ 0x079b8c1f 0xb5b45522 0xfedab918 0xf7fa7494
+ 0x32204c16 0x1c8d5434 0xc39e58e4 0x99c7a2c4
+ 0x3ccfbc3a 0x3f5ba9ef 0xf919921b 0xcffbeb79
+ 0xd2927d86 0x5a50486d 0x62bdb218 0x22731dcd
+ 0xbad1db2c 0x2f4af4a5 0x8f7eded6 0xeca3dcca
+ 0x0bb5ecf7 0x05e6f3c6 0xa38cddff 0xc7cae177
+ 0x1d115485 0x711ea542 0x33729cf9 0x59000680
+ 0xcaf26070 0xd2647235 0x4ce354fc 0x76d9bdbe
+ 0x53e39ec2 0x2d8acfb3 0x193c03b9 0xb3cef3ba
+ 0x1da26bd5 0x8dfeeaa5 0xc199d90d 0xcfc8ee2d
+ 0x4cb1bd52 0x521d197c 0x008bf34b 0xb6ff25ca
+ 0xf4922b7c 0xa91893a8 0xbd3d7874 0x32865e72
+ 0xca72c49d 0x02733201 0x6156051d 0x47464b81
+ 0x353a3c14 0xa87475c8 0x9681a015 0x4b58832d
+ 0xea65c6a2 0xfefef1fb 0xd5fa7dbf 0x13aeee80
+ 0x2915b47b 0xe4a54fca 0x31615326 0xbad80f83
+ 0x21eedfcc 0x2a2787da 0x6eaa2c9c 0x9de76356
+ 0x8a34d823 0x2e7641b8 0xef16714d 0x8267bad4
+ 0xacdfff45 0x09a93862 0xf63863de 0x7eec7d8b
+ 0x70b4cf72 0xc7a8118c 0x4ed89774 0xc12a5e0d
+ 0xe77cc023 0xcdee8fd8 0x20ffe6d9 0x88bcfaa0
+ 0xd945e4fb 0xf496fccc 0xe7587e99 0x42252ec4
+ 0xcc47d738 0xcc549ca3 0xd5059657 0xfbf502a5
+ 0x2788945d 0x4f8ca4d6 0x41b7c069 0x618ebdf6
+ 0x0354452c 0xf7249d75 0xe048dd38 0x4ca484b3
+ 0x0347342c 0x23608b20 0x8a76cb28 0xd445886d
+ 0xfe0e1e6a 0x46678478 0x230c0ef0 0x3add3053
+ 0xa6a158c1 0x22c589d3 0x3b728538 0x5f78bfe8
+ 0xab0bb3ab 0xb39e20b7 0xbb913a69 0xdf8bb73c
+ 0xc2d5bb32 0xbd3e928c 0x30374965 0x9accaf18
+ 0x60bb410e 0xa7786a6d 0xd368444d 0xc5eda57d
+ 0x7a835abd 0x9f5f74e9 0x33b14a30 0xc0129833
+ 0xc5d2e117 0x5f884f0f 0xae6fd2f7 0x3ef71ba2
+ 0x0f0b944c 0x1a8dd932 0x2448f0ed 0xfb8ca949
+ 0x9d08756f 0x7914384d 0xdd70f795 0x8cf8daff
+ 0x6755785b 0xf4e6a191 0x8c5a9a2e 0xfdc19939
+ 0x66f39dc0 0x3da9fcc2 0x2c22797b 0x63f892d3
+ 0xdcb75a66 0xa043c021 0xcb0f9292 0x887eb1a2
+ 0x9d588452 0x9fdc185f 0xf481d465 0xbfef53b9
+ 0x38da9baa 0x9d35c4f4 0xa652c843 0xf80f0007
+ 0xb482a32c 0x7ae4df5b 0x74ad41c2 0x15d849b3
+ 0xc4235054 0x36d44d98 0xc06ad604 0xdc83d81f
+ 0xd4b87511 0xab79b430 0x832a7ce1 0xafe26f16
+ 0x9f7d26db 0xd00816cd 0xec6e7b8b 0x0392bd20
+ 0xfe4b6e2f 0x87795026 0xf9e4eef8 0x06cd2ec8
+ 0x91670e6a 0x17aad6af 0x399050d1 0x043d05f8
+ 0x5dd8e105 0xa2938113 0x2c47ea5e 0x64a062f8
+ 0x14dd01cf 0x6773f479 0xf2b4a773 0xeefe3b89
+ 0x8cf35404 0x0f02b236 0x430023ff 0x04ecae31
+ 0x6949cdfb 0x65b63ba6 0x86c5a7c6 0xd53cc1b5
+ 0xdc1ee770 0x30ebc654 0x67a95215 0x2e4508a9
+ 0x9df37690 0x33baf9e5 0x9a58d5c0 0xe99baa0c
+ 0x4b7446eb 0xfc7c8340 0xfa5ee60a 0xd1d873b4
+ 0x302f882f 0xcff8ac83 0x56d809d2 0xcab281e6
+ 0xadca5551 0x50691975 0x7766b753 0xdb7adecd
+ 0x131c83af 0x1b09ee46 0x87fdd3ef 0xfe3037c2
+ 0xcd2b5362 0x5f21384b 0xacd78f4e 0x145a4793
+ 0x131a6a20 0x0fc1adf5 0x3707f20b 0x5d37ba20
+ 0x6c8448e6 0x76f721a4 0x348b0456 0x608453ed
+ 0xb1185c8a 0x18bbdaa1 0x7c1c6e05 0x46fa7cdf
+ 0x390cf9b7 0xe9c825bf 0xf77554c5 0x7dd5a47c
+ 0x49cfca16 0x5fd7e6dd 0xf707ac36 0xdb6f0142
+ 0xaabda9b0 0xe7ac02e7 0x0a1eb844 0x225686b2
+ 0x7852c1cf 0x3912115d 0x89d65081 0xc3f4faee
+ 0xfedeba97 0x073395d9 0x33d20ce3 0x56c6c126
+ 0x378f822e 0xf575b487 0x043da151 0x1ccae8c2
+ 0x5fa2279b 0x0608f618 0x4c90662b 0x30591d0c
+ 0xcf217166 0xacdbf6fe 0x1a653b17 0x6fa76090
+ 0xc804480e 0x44c5b06b 0x1ebb8a6d 0x2f6f6f08
+ 0x6bbeb75c 0x21c5c48d 0xd4c4cc2d 0xfdeab68f
+ 0x25cd39e3 0x62970aa2 0x48aa915f 0xca38c833
+ 0x9cfd1d10 0x81dbc61d 0x51702e45 0x8f80e492
+ 0x07e89651 0x920e9f7d 0xdfa9f973 0x8cbfa187
+ 0xbd3e7a14 0xee191486 0xb0077d2e 0x7345adcf
+ 0xce36b2ea 0xc73aec7d 0x9278ac37 0xe07c6d96
+ 0xf90f78a5 0x38f5584c 0x4941da80 0x67ff3048
+ 0x3c263914 0x49656179 0x22f066a5 0x1f5a5e3e
+ 0xce9ce83f 0x8e7446a2 0x85473d62 0xd7622673
+ 0x3941bc22 0xf879d494 0x0936a517 0x2bba925e
+ 0x516761b3 0xe238a8e3 0x11a0c8bf 0xd53cb861
+ 0x60c0f0d5 0x63f7f157 0xb23dd4f9 0x5a4fd86c
+ 0x3851d435 0x483b98c7 0x71c55b1d 0x1931d219
+ 0x7bd54621 0x108bb4af 0xa72c8b97 0x51d985e2
+ 0x598a521e 0x7efcf984 0x69b02671 0x5746157d
+ 0x60cfc339 0x629567fe 0x2236a93a 0x520d0094
+ 0x61811f40 0x856aeba6 0x4fc0a2b3 0xedcc9fb2
+ 0x8fce6123 0x2ba53b1b 0x6fc610d4 0xabb564f4
+ 0x957158aa 0x1d2b7989 0xaca5dedc 0x684a7086
+ 0x1610e1ef 0x2abdf9b0 0xd9e9d205 0x0119ab86
+ 0x6da64982 0x71f274b0 0xf425e61b 0x029dc92f
+ 0xb13ff88f 0x064ecf92 0x4070c36d 0x58bd6ebd
+ 0x629bcf8a 0x9091566a 0xc947a42e 0xd0475c87
+ 0xe7773220 0x7b61f2fc 0xae0c08e3 0x44582521
+ 0x557dfbaa 0x92fba0ef 0x529900aa 0x90fef908
+ 0x570b0495 0x704125df 0xd8f9448e 0x9a7cf1f3
+ 0xd83a747b 0xe27e3d56 0x4da6aaa3 0x55439398
+ 0xce0d1c02 0xdebd6473 0x580f141b 0xcd5a5e57
+ 0x1c64cc23 0x53f8f9c7 0xcfb5b464 0xa4939b05
+ 0xc0bb3066 0x37923d76 0xe5e9b428 0x6f4f2894
+ 0xe5144757 0xa9cfdc46 0xe3448b78 0x7e0bac3a
+ 0x38066245 0x0d7c86fa 0xb7fd09a6 0x075426bf
+ 0x3de7c82a 0x1f8d1b36 0x34144ca2 0x6c03ad9d
+ 0x34305ef0 0x0a5269ce 0x82a9eeed 0x3be63f82
+ 0x2001cea7 0xbba641a8 0xa4dad9e4 0x92e0fb69
+ 0xa166dfad 0xd1ae10ab 0x0372e102 0x88469aeb
+ 0xaa11bae9 0xf1006dc9 0xa8648217 0xe171b6e8
+ 0x590ba849 0xa593cf1f 0x4cf079d4 0xe451e193
+ 0x4355a93f 0x54dfcade 0x1a918a74 0x88eff191
+ 0xd5a2bf54 0xb9962550 0x58d478ab 0xc78828a9
+ 0xe2cff385 0x9ff810e7 0x9643953f 0x84764dee
+ 0xe4950d03 0xdf17e0e5 0x4da892d6 0x48145872
+ 0xb7453254 0x41240a2a 0x7ddf94bc 0x898771f1
+ 0x61a423be 0xcfb46db4 0x7db27a89 0x2feeaa82
+ 0x24d86326 0x043f5b1c 0x8cc6bd73 0x934b7b3e
+ 0xac4a1262 0xebc494bd 0x53921696 0x115c4d9a
+ 0x1d73de18 0x6417f141 0x9fdce4cd 0x8f72ccdd
+ 0x3bb26030 0xdaf43da3 0x1e26758b 0xad1234be
+ 0xe5bdf477 0xd2dd9e46 0x1270838f 0x557f3bd2
+ 0xaa5a28c1 0x61e0d535 0xdc5aa028 0x9af22a6d
+ 0x9b669fbb 0x979b5586 0xabf8264f 0xbcf91b17
+ 0xda92e3cf 0xaaa87ae0 0x52336f6d 0x5beef95f
+ 0x7c310125 0x8858f708 0x3c6e6d73 0x6720d3c6
+ 0xed51b365 0xa9e50de2 0x865a7fc1 0x756b5758
+ 0xbe13f4ca 0xf2eb039e 0x187d1641 0xc6e37977
+ 0xbc3a2d64 0x6523583c 0x70db0cf9 0xebdba06e
+ 0x632e8e5a 0x7b44144b 0x338bf7e2 0xf43dd8e4
+ 0x2d91d815 0x9aff02dc 0x700ebe20 0xe9b6ea5f
+ 0x776cdc38 0x43324788 0x53458290 0x2e22910d
+ 0xed0fdf3b 0x279fc3ca 0x5a01f65c 0xc4ad1598
+ 0x7a1fa09f 0xd12f97bf 0x34d99bad 0xfcecf69c
+ 0x2b5567af 0x57a93cb3 0xfcf93005 0x3a403789
+ 0xecaad383 0xc63fe190 0x5b8de563 0xbd9b876d
+ 0xa20b875b 0x79db86f9 0x1917cad6 0xe925d5e9
+ 0x8a233ed2 0xda8e6369 0x43028013 0x91b72d39
+ 0x6b75eb99 0xc7bb03bb 0xab135e5f 0xb73cbade
+ 0xfb7b0cfa 0x62ef94cc 0xdfdaa5ee 0x75c0f3ef
+ 0xf020108a 0x6c54535f 0xc9583167 0x68fdd582
+ 0xc6c95829 0x7fa6f2b4 0x9c7f494c 0xde5daac7
+ 0x10088178 0xc27f2052 0x84714bf4 0xd2eb0ba2
+ 0x23fd2e08 0x7c2fceb7 0x119bfd3a 0x029faaba
+ 0x41c8cd67 0x2461da7f 0x25acc8ef 0xece252ec
+ 0x997d4b00 0x3f19f111 0x68237934 0x518f427d
+ 0x6c2a04d9 0x27f61e6d 0x68ebf9c6 0xf3ca994f
+ 0x43e5c576 0xc4e1fd3b 0xe2393151 0xbf97bbec
+ 0xefd161e9 0x5e3a816b 0x1d8b9bd3 0xecbc57f5
+ 0x042c1237 0xcb1c852c 0x546f4d72 0x01b37ce2
+ 0x20e30817 0x3fbd20d1 0x2ca11cc3 0x63cf6770
+ 0xa65064ac 0x32d2cbab 0x9c1fb334 0x37c097ea
+ 0x63ea10fd 0x7db8fc2f 0x8a4425dc 0x752ca318
+ 0x9a570211 0x50f90038 0x90abfad1 0xe81169f7
+ 0xd804a9b7 0x18b7efa2 0x6daabb80 0xf098566e
+ 0xb5df2af6 0x8f23ef8d 0xed7dac93 0x4fbed0de
+ 0x929b870e 0x60b5c69b 0x5589cc4d 0x588914af
+ 0xfd78c6f8 0xd4018180 0x43d22344 0x873ee413
+ 0x0ad0f12a 0x15200a82 0x749bff31 0x6fd4ca58
+ 0xeea48890 0xc1507520 0x7a750a56 0x87c85e9b
+ 0x2bc19182 0x9e7084d6 0xee8595b0 0x3c35ef78
+ 0xaa19db33 0xbc4d7c20 0xa7b2c1ef 0x51ccd346
+ 0x72b24c95 0xedf9e250 0x88a582df 0x42a27480
+ 0x8fe7bfa3 0xb5f08d25 0x2cfb9e8c 0xcc118d13
+ 0x50d9c479 0xf4abe2bd 0x1b22edbf 0x8f525f45
+ 0xac39c5d6 0xb35d5c21 0x0e588e14 0x4715d55a
+ 0x1b0ecbad 0x16e9e58d 0xcefb1002 0x8a37403e
+ 0x70e90356 0x9b7a48f6 0x43bcf700 0x70470d6e
+ 0x8e0dd0ea 0x7620f026 0xb4809687 0x8a3d8bef
+ 0xdc0261a9 0x3e8d2dbc 0x6d48a5b3 0x4107a6d9
+ 0x2dc369b0 0x671d66a3 0x559e6e50 0x4b8098ba
+ 0x28209e38 0xf2bd6114 0x0a6f4f54 0x77a82065
+ 0x406470a2 0x93cae58d 0xcf774ed5 0x7f4cdd72
+ 0xfb869931 0x4ab42cd8 0x8251ded1 0x2c85fccd
+ 0x14a8ae06 0x92333b50 0x53f605f9 0x3347f24f
+ 0xf190509f 0xf72b525e 0x13a0f3ae 0xc04c7e10
+ 0xa735fbf2 0x94df568b 0x71f6306e 0xcad6592e
+ 0x1690c07f 0x64dda7ef 0xb03c8822 0x41f58140
+ 0xc1953b66 0x2b4bae6a 0x278c23d4 0x0a02a425
+ 0x10942d48 0x70557bb5 0x94981643 0x63214c9e
+ 0xaa7ea265 0x505bf23b 0xa66c7082 0xf428671e
+ 0xd1fdc33d 0x5817c28b 0x2ad4649a 0xb22b1eb1
+ 0x17f29535 0x0423d04e 0x8b4d30cb 0xc36089f1
+ 0x492dcfa4 0xe7842e60 0x7d4805de 0x02d4f43f
+ 0xd3b6933d 0xa763e450 0x4301f667 0x58318b37
+ 0x78d9dd14 0x84343bf2 0xf62e93a3 0x76d9d617
+ 0x82c37d71 0xc3fa7cda 0x3dffa327 0xa171b148
+ 0x4654011a 0x7cbd5689 0xaabe734f 0xb8226cd0
+ 0x9d846c68 0xb9233e88 0xfc0b0bcc 0x2138ccfe
+ 0xaff53d8f 0x9b0b8b80 0xb2be2912 0xcc871084
+ 0x47a380a1 0x593c82ed 0x3cc8424f 0x5e77c12d
+ 0x813626a2 0x8021e31e 0xeede3c2c 0xb8fea5ea
+ 0x236a7fc6 0x783bdc5b 0x0d67a0ab 0x8987c13f
+ 0xb6381e65 0x3b313687 0x52ad7a81 0x759ae49d
+ 0x468ab620 0x8b735c2e 0x60937053 0xb3cf5867
+ 0xb48525fe 0xd8bc07fa 0xf092e18b 0x6d8ce7a3
+ 0xfeec327d 0x752e3f43 0xf106ac62 0xfe3489b7
+ 0xa699af8d 0x1c5dcb5a 0x3a931d51 0xc1409944
+ 0x843c3667 0xb923eb17 0x67c3d38f 0xd1edd5bb
+ 0x4bffe68e 0x8b7acab6 0xe0058382 0x79de2e31
+ 0x1e48cc0f 0xc4b8ad1e 0x5a00cf89 0xa4f6b8e4
+ 0x29d42e0a 0x3d483f3e 0x746de9bf 0x0ce78994
+ 0xcb6df646 0xe287b7f6 0x85907659 0x333127fb
+ 0x6aac4a54 0x5ff7c669 0xd42ea2ac 0x92ae55b9
+ 0x952f68e5 0x3273a013 0xec6cedbe 0x9ede1ad3
+ 0x76d7c595 0x167c73fe 0x7c2572f4 0x8f653319
+ 0xa1c726a4 0xf7ba8a71 0x5bc9b17c 0xc0d89104
+ 0xc0ba5907 0x0e8c9c27 0xc8205b68 0x74f8aebf
+ 0x02acd438 0x28783ffd 0x143ea70d 0x9c82abd6
+ 0x9eb156e1 0x5951d075 0x5afb06d9 0xd14bac91
+ 0x6ae19745 0x728cd46e 0x775cf71d 0x1126cf7e
+ 0x058d4dcb 0x7f5f648d 0x5f37a908 0xd2fd843e
+ 0x8dd64fb8 0xcdaa761a 0x105c38c1 0x9b5f440f
+ 0x2dad00c4 0xd3c25b11 0xcc07bfb0 0xbc432852
+ 0xc2d34e0c 0x0b1978f9 0x95a119ee 0xfc4dbdfd
+ 0xae6d3b7a 0xff06ff00 0x30976600 0x9e47e68f
+ 0x3308cf27 0x0a2d1580 0xe91ea75e 0xcbf12170
+ 0xc7da3143 0xbe0a6ded 0x74d03d5a 0xb0869deb
+ 0xbb94dec7 0xec2a053f 0xcb4fd13f 0x04912071
+ 0xb1af28a2 0xee094f0f 0xa78a4965 0xcdded4aa
+ 0x6d4959cb 0x93ee7709 0x2901d3af 0x6ad494ad
+ 0xb95203f0 0x1fa160d4 0x7a06d88f 0x35f89a76
+ 0x5e151830 0x27feb3eb 0xa9a9805f 0xc43b9387
+ 0x5b6bf76e 0x3372d23a 0xbe2d27f1 0xad9b7282
+ 0x5d67323b 0x2e96328d 0x3d90fe8a 0x9e4d4522
+ 0xa2eba985 0xe1ed3264 0x28eab708 0x2551ba26
+ 0xc143badb 0x3bebdacd 0x4da62bf1 0x875ffcaa
+ 0xcc643e34 0x1b75c14d 0x13b84e83 0x8abb6f10
+ 0xb82dd0fb 0xf31e4572 0xca8a5f58 0xb98da99f
+ 0xec33fc4c 0x952384ca 0xd673c525 0x45f36727
+ 0x269b8efb 0xfe5bc4a4 0x90325548 0xb8aefb93
+ 0x6a2381c6 0xdc4ecc1e 0x7fc546b2 0x5348ca20
+ 0x8eca0f26 0x5a49fa01 0x4b0822fd 0x862e680f
+ 0x5abdf88e 0xeb23e8fb 0x2c023eb8 0x092cdb59
+ 0xa15e0fbf 0x03f1e5e9 0x2c343bfd 0x8876aa74
+ 0x5b80428d 0x4a4fba83 0xeea3da82 0x414a610d
+ 0xecb123db 0x0f81b8b2 0xfdd1c970 0x8de71d6f
+ 0x0ca553b1 0x57fc98ad 0x47d44eb3 0x17827c70
+ 0x2d91f5b1 0xecf63cb7 0xb4fdb928 0xc49c42ed
+ 0xeea589bd 0x62cf916b 0x02a553a6 0x50cb4523
+ 0x959d3831 0xebfa026e 0xd2483d91 0x140364c2
+ 0xa8ddcdd6 0xca343670 0x589a154f 0x6bf369ed
+ 0x40eff32d 0xd7b49920 0xf4bff896 0x5a62c192
+ 0x0a4cb0bc 0x449533d6 0xace20ca3 0xfae7465b
+ 0xb6e0edda 0xda214fa1 0xcc08b6be 0x54c342cb
+ 0xc09f8db1 0xead565c0 0xe38b2187 0xd0d0be68
+ 0x16748998 0xced5a632 0xa0636b45 0xc71ab63f
+ 0xfe161e04 0xe8b66fdb 0x878e2039 0x17af26c2
+ 0x6851cb01 0x9484d4a5 0x697e6981 0x9946e0fc
+ 0x970cbede 0x87d887f2 0xd987bd44 0x10dcae60
+ 0x20239b60 0xe9ef795c 0x536f0f3b 0x2d4de85d
+ 0xd50035c9 0x335410a8 0xee350c4f 0xcf94d278
+ 0x688c98c6 0x3c0402d5 0xa8b8a81c 0x952c67e6
+ 0xdf432d95 0xb74dd56d 0x77316d7c 0x56df9401
+ 0xb8aad070 0xf5d1cbb6 0x206f18bd 0x59fdf55d
+ 0x5de26069 0x31ab08b6 0x719a4d81 0x8f1c8212
+ 0xc792bd91 0xd6f262c9 0xab4bd545 0x36f3c600
+ 0x917c135e 0x1aa0455b 0xc1de8100 0x855db3e9
+ 0x42d41a24 0x40955a66 0x8475c651 0xc7f44c6a
+ 0x4e1f0df2 0x7cc5cd54 0x35a47bec 0xe6ac8550
+ 0x8b43af30 0x6fcd1cb0 0xf37de1ef 0x00c70de7
+ 0x63913125 0xb33688d5 0x8c296f13 0x93570308
+ 0x6d8aafbf 0x67a574e9 0xf297b1a6 0x53600c84
+ 0xfdea2e69 0xe75cf59a 0x1b0e3dd0 0x7f7fa8c2
+ 0x7e463346 0x97c7069a 0x671ce307 0x2441f370
+ 0xbbeb3a08 0xc2e4448b 0x2157fe23 0x70954499
+ 0x3038e792 0x4a8a2fb0 0xa1f4541d 0x7c88605a
+ 0x6a4edc03 0x689fe83b 0x93835e79 0x19c99c39
+ 0x9ea7dfa9 0x36bd28c2 0x64ac057b 0xa2987c35
+ 0x9c3f17ad 0x0be5e9f8 0xef63c94d 0xee32f2b1
+ 0x3781a3ae 0x9ebe229f 0x77467a2a 0x1dfd79fe
+ 0x24ed349a 0x3008c1c8 0xb77520f3 0xbf831d15
+ 0x11dc4dee 0x7b5e47fc 0xfefa0f69 0x2a820af8
+ 0x8e133d47 0xa021cf99 0x7886d896 0x8edadf3d
+ 0x89a10318 0xb048ce73 0xd9843457 0xe000594b
+ 0xff3c1ea8 0xd93a7c02 0x8471da9b 0xf24ccfcc
+ 0x6f0576b7 0xeb024ef8 0xaf75787b 0x508fca52
+ 0x18315250 0x74482410 0x169985c9 0x911c14ef
+ 0x96575aa6 0xd4791358 0x1bcd07b0 0xf91ff654
+ 0xc3b9c8d0 0x101e8aaa 0x84b8352b 0x16f57154
+ 0x843a47f1 0x88269e3d 0xa625bd0d 0x99c91f9c
+ 0xfe79c26c 0xd1844839 0xaa59ec6d 0x1e1b9ca5
+ 0xb99e4bf7 0xc8c06104 0x29985a13 0x2aa0dea8
+ 0xa92de35e 0x8242311d 0x61e0a059 0x09232eac
+ 0xc7e8f2b4 0x05fbcfa5 0x41d2cac9 0x5d2026f9
+ 0x69b970c0 0x0274700a 0x1f5f23d6 0xb98aea3b
+ 0xd879d256 0x69230276 0xbec32596 0x6d4dcd0c
+ 0x04efed6b 0xcf5ca09b 0xddd17a77 0x821a0172
+ 0xe656d7e6 0x70dd6839 0x75710294 0x59765f6f
+ 0xa3174d9b 0x4227c2a1 0x23ddd6c4 0x1d7d8c79
+ 0xb2e50bb1 0x98744c39 0x853152f9 0x4d439b89
+ 0xf852ac32 0x89ad2fd8 0x613c8c1d 0x47ab4071
+ 0xdd62c705 0xe623a5ec 0x93f4bf07 0x5053a3fe
+ 0x2545e42c 0x03e4ca84 0xa5dcf9cf 0xc279dd6e
+ 0x6e3e2248 0x51c6338b 0x1b79f55d 0x871d7595
+ 0x1991ba98 0x697bf68a 0x634bef62 0x415df824
+ 0x007523ec 0x595fe4f3 0xd2018516 0xcfa8f6b3
+ 0x1e3d33da 0x141858c4 0xa553fa95 0x0ba00794
+ 0x923edb17 0x86a18480 0x4aa94d38 0x429814d8
+ 0xdd0d853b 0x375808f6 0xcf857aba 0x6f6d5dc9
+ 0xdc27fee9 0x7c49718b 0xb3eb09ee 0xf48ba9f7
+ 0xa7f8deaa 0xa0afa80f 0x84a0ea27 0x63858132
+ 0xa552f06d 0xcce0bc50 0x70a6b770 0xe21c7251
+ 0x1fb70601 0x2e93b5f3 0x1f257ad1 0xab09dde3
+ 0x176c80a3 0xa1845a72 0xcf68a2e2 0xe3bdd613
+ 0xa41d6e7e 0xde870606 0xc292df07 0x7093562d
+ 0x692e5e51 0x179dd237 0x01dc96ea 0x3a2efdfc
+ 0x6088f181 0x7c3d290f 0xbd38e29c 0x340cead8
+ 0xdca8ea9a 0xa43a7899 0xf6541b9c 0xafabfe18
+ 0xb5557f4b 0x995bcd2a 0x5355ea0e 0xf3dcdf66
+ 0x02216d50 0xaa3a8f23 0x1c63637e 0xb8950554
+ 0x7199e726 0x20fed1f2 0x027d67e3 0x7d5a236d
+ 0xd1e01da6 0x2db0e750 0xfba1d718 0xa58b42ea
+ 0x839b80e9 0xcc55d1aa 0xb1da75e5 0x50789516
+ 0x818913cc 0x03facba2 0x6e2bda29 0x1e3c1120
+ 0x8fe64712 0x12317a15 0x6e6bb39f 0x7edd5bbb
+ 0x900bf72d 0xc6a822c8 0x3353d602 0xd9965f2a
+ 0xfc290ed8 0x9c8210e3 0xaa84d5ae 0xdf9f1507
+ 0xbd10f9ff 0x50a4d9f4 0x22111607 0xd4043bad
+ 0xfb7b42e2 0xe0285329 0x4e76e1a7 0x4188ed50
+ 0x88cd2a99 0x4727768e 0xba625d6a 0xf8ad5d67
+ 0xcc1595cd 0x36984dda 0x7c9f8fcb 0x4e9ec35e
+ 0x37f95b62 0x8e70690a 0x8e43aeec 0xf3434e0c
+ 0xa4b3ccee 0x99c0d714 0xee0082c0 0x9d9f002d
+ 0x3eab3543 0x829e9098 0xafe4e802 0x5337a928
+ 0x9bfd2d3c 0x43b69305 0x2c10167b 0x8b06b92e
+ 0x949049c3 0xc98231a3 0xf77c9543 0x9961f18a
+ 0x36a63fa0 0x039932f1 0x1179d978 0xb43063e0
+ 0x89bc1a9a 0x2a61348d 0x34113ada 0x1866335c
+ 0x8b0249ef 0x94c2a8a9 0xd002ae9c 0x029e1f71
+ 0x989a3204 0x57b1aaea 0xf2d06793 0x62f17706
+ 0x656e06b8 0x022897b3 0x09c381bf 0xafd90766
+ 0x8c79df8e 0x665a6727 0x33c2cd0c 0x2e61c4aa
+ 0x9dd83f35 0x01b2b241 0x70f5d0e4 0x0e98f63f
+ 0x800dc70c 0x8eb5c772 0x7defbb2f 0x763810f0
+ 0x7ff959ab 0x07640942 0x7ca07fa5 0xa7bace66
+ 0x208a078f 0x2975dd73 0xa4866e67 0x271f5bac
+ 0xdca36998 0xe5e1d1fd 0x511f9ffc 0xafac1c08
+ 0x827968f9 0x8823df83 0xba2c243c 0x3e2a0d33
+ 0x77e0cd0a 0x623d50a3 0x278f115b 0xb79a27e0
+ 0x51ab943e 0xdda62a6a 0xb42ea0e4 0x2ae47d5f
+ 0x5ceb281f 0x022dfce9 0xe1f879f7 0x6fe70f50
+ 0x1d98abe7 0x0828e611 0x8ad0ba15 0x61bbd7be
+ 0x5cde8df9 0xd78b7375 0xe1cf9350 0x9faae80b
+ 0x5564c0dd 0x3d735e25 0x64985c05 0x20ac585d
+ 0x57e9da3d 0x495cf386 0x1889c50e 0xc313efb3
+ 0xb3f5e423 0xbb87a9b0 0x3cd06b09 0xdf51b230
+ 0xeb2801dd 0x6d5d43cf 0x1fba7400 0x08791e6f
+ 0xf90e0873 0xa65df0b8 0x64369b67 0xc22c9200
+ 0xd840f9f0 0xcc49d4de 0x9987db7f 0x8fec9974
+ 0xc826c852 0x657bd87c 0xcaddde2c 0xeb0dc447
+ 0x4a45ffa9 0x035d22b0 0x236eceff 0xa3ba5f8c
+ 0xccee0a9a 0xbad5d1dd 0x1cc8b587 0x5f11d469
+ 0x99f8c63e 0x64311906 0x43c19b36 0xef9d5e86
+ 0x00705473 0x78100dd0 0xedab57b3 0xf3b00610
+ 0xfc6e3467 0x6c4bff2f 0x97227c44 0x38ca257b
+ 0x4e79fd63 0x0c8b3466 0xa2ae7e62 0xb01fba5c
+ 0xdeee261d 0x2a4c6387 0xb9dce78a 0x2f0905c3
+ 0xa76a7929 0x5f3fa1f0 0xca4e5260 0xccba772d
+ 0x862fec80 0xb8257aa1 0x7c79cfac 0xc75d7230
+ 0x387e536a 0xaff486e5 0x3c549063 0xeea5fc5c
+ 0xc433a55c 0xbfb619b4 0xf36fb0c5 0x4faab4e4
+ 0xbcd75d84 0x6eb5ee8c 0xaa4e29a9 0x551db0d6
+ 0x1ccbc659 0x9b5e8c52 0x1e33bab4 0xcfd30d60
+ 0x6366c21d 0x3f0d7056 0x7f2247da 0xaba4f322
+ 0x7b0ec4fe 0xdd64dd73 0xcd538711 0x67dfcd4b
+ 0x02d1b6f0 0xef0b6e60 0x1058738d 0x0c056ad5
+ 0xb40abdbc 0xfc2549e2 0x6fb269b6 0x08f7ec08
+ 0xea0a76de 0x7e97ee14 0x4eed0856 0x75ba49db
+ 0x8145dd79 0x43101098 0xac911399 0xf8aab5ed
+ 0x1e9d391b 0xb2a3fbe1 0xa394939f 0x12b8300e
+ 0xa5f5200f 0xc350dcc7 0x1b2380d2 0xa599b322
+ 0xe219e0d0 0xe4912308 0x0ad305cb 0x2e22d468
+ 0x599eacdc 0xcf3b7eba 0x65fe5903 0x44f6cb16
+ 0x0ab29b19 0xa74185e6 0x41736bf9 0xeaf231f9
+ 0x762d0e7f 0x8b445ce4 0x173d3775 0x138da565
+ 0xe4f7f652 0xe62e4ae8 0x91ce0ed8 0x1fc94878
+ 0xe44acd84 0xe4402b5c 0x6437aaff 0xe7b0d8d8
+ 0x514fbcf5 0x4b3bf5bf 0x0696b5d0 0x89a562ee
+ 0x02408e77 0x94cc3287 0x47860ed4 0x42aedc7e
+ 0xe9f0f3a2 0x4cf19812 0x3181341b 0xd72803a2
+ 0x42f5c8b3 0x5735456a 0xef70c247 0x5943b8e4
+ 0x7c62b0e9 0xc507e2e6 0x85a2c82f 0x95c6d92d
+ 0xfeefff6e 0x5740c004 0x1958f117 0x44ebaa15
+ 0x9f061786 0x732a8720 0x9483f974 0x839d5b20
+ 0xeefb728b 0xae2d4b7c 0x49bcb243 0xd86db07b
+ 0x73b0542f 0xc5a34fd7 0x5b9401fd 0x7f75e686
+ 0xb239ec36 0x41e7943d 0x2bc517f7 0x27057733
+ 0xf6c9cbd1 0x2965ef66 0x969b44e6 0x77b66e0f
+ 0x68b93916 0x31d581c2 0x8520df18 0x16ce6af1
+ 0x70bbf865 0x6d1ea78e 0x989ed713 0xf97c0d1d
+ 0x538aef6b 0xf1ac3c76 0xf65f8bf6 0x4f4d3a8d
+ 0x639d90ee 0x43079e8c 0xc9d50f0a 0x9b12ec49
+ 0xaebe3d8a 0xd1bc3cc6 0x8b92e348 0xd056119c
+ 0x7aec25f3 0xb3d2cf65 0x32c03540 0x53287cff
+ 0x0bfa781b 0xf8610282 0x18a2d96a 0x541a6f1a
+ 0x6052aac0 0x4f79e46a 0x7c868b93 0x6547a94d
+ 0x58326c30 0x98e46f02 0x77cdd3c2 0x204ce551
+ 0xa5e32028 0x679e3153 0xc7880c16 0xf32743f0
+ 0x63c8892b 0x51d8a6ea 0x42bc6417 0xdb8ae71d
+ 0x04c71f86 0x1a5bd80b 0x810f3b56 0x049580a6
+ 0xd384d2b4 0x92cd10c8 0xaf4e6ce2 0xac955cc4
+ 0xf57b42b7 0x1017f2b4 0x3031fafb 0x3d1a8024
+ 0x3aca42cb 0x75514d81 0x454b1806 0x5505c3e5
+ 0x26d2c642 0x57454f1b 0x5e2d3c9b 0x6535eaf5
+ 0x370de383 0x6adfbbe2 0x513a5d0f 0xfc48c333
+ 0xa0a70bcd 0x35777e16 0x5ecec516 0xb7879d7b
+ 0x08928fd4 0x88c8048f 0x4a0d2896 0x5bdae2f1
+ 0x8761b488 0xfae8bb60 0x3c8e8abc 0x13939d3c
+ 0xc29493ca 0x585a71c8 0x43205f16 0x06a3be38
+ 0x4be88f47 0xd2be8c8e 0x3d721e2a 0x43051f74
+ 0x922a9a30 0x6391fc85 0xc4965afc 0x61f082e9
+ 0xc2686e37 0x4f77b6a1 0xac47fa16 0x1eb05157
+ 0xe6f767a0 0x24177985 0xdf80b368 0xb54d959c
+ 0xa5719425 0x656c70de 0xf35dfd40 0x702d5063
+ 0x4e7ac001 0xc4bb4fb2 0x4af7b9e5 0xe0eb5c48
+ 0xf08b19c0 0x468b1471 0x74af9030 0x51d171e9
+ 0x81a59926 0x55b893e4 0x17adeb1e 0x72084962
+ 0x7f358bec 0xbd4363b9 0x75a56726 0x3a033a75
+ 0xd0fbf874 0xa6bf634f 0xa5e4be7f 0x4cd8338c
+ 0xef6838b8 0x1d458215 0xff7698ba 0x4ba19dec
+ 0x87f58c07 0x2c7933a6 0x1cd4f99a 0x158bba9f
+ 0xffcedb5d 0x256eb5d7 0xcb6dadde 0x980349bc
+ 0x6169dcf3 0x94267861 0x168ba5e4 0xd2063474
+ 0x156c9738 0xc4bd2c2d 0x31ad709c 0x58cd43e6
+ 0x76ba9c33 0x070f490b 0x357c3929 0x103bef50
+ 0x82ebacfe 0x5affdca2 0x96d0965d 0x60911a5f
+ 0x65d4f52a 0x795b3094 0xf56291dc 0x6e614bb5
+ 0xf701246d 0x4953b1b4 0x15e4e5fa 0xb6954973
+ 0x43ada767 0x4c0a9f27 0xa47f78da 0x52375c95
+ 0x79770885 0x479c5aed 0xca2ac2b8 0xee74cc5d
+ 0x752f00d4 0x2b5532d6 0xd3641edd 0x05eb0e05
+ 0x5118c9a9 0x47a0e0b5 0x5f12d793 0x92019247
+ 0x27d77d98 0x0e413c92 0x76e4aea0 0x9fa8e3f1
+ 0x3c57e54d 0xf4a60ba2 0x5bb37f64 0x8b214f1d
+ 0x320f3bec 0x1cfd1f0f 0xb0cf5b70 0xf26a138e
+ 0x37bb143f 0x993d3fa6 0xde4138c2 0x9fa287ba
+ 0x137617ff 0x591624c0 0x1d10f02a 0xf7e350a2
+ 0x76bc2933 0x12af6e72 0x1777e320 0x3e161b20
+ 0x6c9fd66a 0x0b30f462 0x9cb717cc 0xee2902ba
+ 0x466d7b9e 0xe97c26a4 0x7406b88a 0xf15a7209
+ 0x3d2815c1 0x3eb961e1 0xe5321371 0x05f60ece
+ 0x39168ef2 0x201a9dfc 0x90fdb132 0xe4531401
+ 0xbef01e52 0xade4b385 0x6ca0c911 0x7586ff60
+ 0xe457457c 0xfbfa3688 0xc826a1e9 0x10360416
+ 0x192b51d4 0x18471973 0x3f0dd5ae 0xea2bbfc1
+ 0xbe099b58 0x8bd8efda 0xdfc56e40 0x9e50f4e9
+ 0xceeaab0a 0xd1eeb5d2 0x840a3cd2 0x6b739449
+ 0x4a94e95f 0xe53720e7 0x68c70986 0x1cec3aeb
+ 0x2423ad9a 0xe83b9246 0x7ac4b815 0x3796ec1c
+ 0x65ec7484 0x79e5b0cb 0xd25f4790 0x55573d75
+ 0x0f24c1ae 0x6d5d9b62 0xf3b2788c 0x2c695087
+ 0x0980abb0 0x5086c2b1 0x26a247e9 0x72071084
+ 0xe76c66a2 0xcc9c0bba 0xc67723b5 0x19a809d9
+ 0xddc03879 0x7161b52d 0x24ee285c 0x5a345427
+ 0x0626ef30 0xb734a77e 0x8ff087f3 0x80222e05
+ 0x91b6c40a 0x4fe76862 0xef66e1df 0xeedb9f06
+ 0xb785ea7e 0x0e84aab2 0xd0a669d6 0x7ccc77d0
+ 0x264df92e 0xe9d1b14a 0x4b517134 0x05444463
+ 0x408e7bb2 0xe7ad2bc4 0x5d8cb4c5 0x61e508ab
+ 0x9798953a 0xa6848924 0xf26be53c 0x8940d4f6
+ 0x56f11005 0x6d8d60ef 0x03c374a9 0xce0dbc18
+ 0x341e634f 0x64e7d2f8 0xeb201eb7 0x2dee184b
+ 0x57ecd83f 0xd8f644a9 0xca4493e8 0x66347804
+ 0x542e06e8 0x55f607ea 0x7f425fa6 0x362807b4
+ 0x731c87c3 0x4b5d6e1f 0x03e70201 0xbc5f4080
+ 0x899cfd7b 0xa651d567 0x9c333e24 0x8b0eedc1
+ 0x53ff0c74 0x7db69633 0x6637bbda 0x5ce53c7c
+ 0xe93bd003 0x91234974 0xe8a626f2 0xc6550418
+ 0x1b4157aa 0xc42ff7e4 0x1b9213ae 0x70d84165
+ 0xc7cb09cc 0x38bf0221 0x238ff6b7 0x3688fd5b
+ 0x5694728f 0x4a8e4cfb 0x3cd7e1d2 0x72a41c1a
+ 0x2d098e4c 0x5a0ab21d 0xc8a40160 0xf252b062
+ 0xc172763a 0xaedea2e4 0xeedcbcf9 0x4c0d2216
+ 0x02b5eba5 0x410139da 0xde4ff14c 0xa53ca456
+ 0x8c30792f 0x6af27a7b 0x734b1dab 0xf4f60014
+ 0x79fc3cc7 0xfc578e4f 0x20948f41 0xb4fbe4c4
+ 0xdbb21292 0xac1aa341 0x7ffb8913 0xa498296d
+ 0xae1e8f6a 0x167d82cb 0x094513fd 0x8f0810c7
+ 0xd01d348f 0x700d0063 0xeaacbad2 0x23d45e0a
+ 0xe3b3a244 0xf2f7100b 0xf680fb9b 0x529efdd1
+ 0x01dc5480 0x263328c6 0x686fbe31 0xbf3a1057
+ 0x34c763da 0xae45207e 0xcb5abb2b 0x011c0faf
+ 0xde2b6f4e 0x3d95034b 0xacec6e7a 0xc792595e
+ 0xeb3cd922 0x7894f0d5 0xd9a7e62a 0x1a3c2ea9
+ 0xa8f22d99 0x1ffaa636 0x47c6f1ff 0x69feca71
+ 0xcf8d73d6 0x1c85d0fd 0xcce984c1 0x993f7a9f
+ 0xc095c139 0x1c013486 0x675a753e 0x01030902
+ 0xccab4cd7 0x0c14c605 0x5ebc19b1 0x60ad33a1
+ 0xe80e1200 0xdf49db31 0x855aee7a 0xbfa37ef2
+ 0x135d844f 0xdde541e3 0x0522f180 0xa27312bc
+ 0x57046808 0xb96fe1b6 0x77c2806e 0xb90ac06f
+ 0xa425864e 0x857ff22f 0x16eca5a6 0xbaa58ca6
+ 0xab30772e 0xb20507fc 0xa593f6cb 0x9e7e8409
+ 0xac4ecd8d 0xa9c0561b 0x0c462492 0xb3ee5aa1
+ 0x83d3d56c 0x5bc20412 0x03365294 0x09758ede
+ 0xe9e6968a 0x80ffc576 0xe62ddfd6 0xd5934635
+ 0xe07f36e1 0x99c0db4e 0x2dcdb7ed 0x68749a34
+ 0x4f718748 0x630b1315 0xe632adbb 0x4c111085
+ 0x13bbfaf1 0xb70bd522 0xf22068d1 0x4ed37edb
+ 0x7c50ff42 0xa6b61456 0x828deb4d 0xf19dc8ae
+ 0x7ed7560e 0xb47a1aed 0xb79beb35 0x720d104f
+ 0xff5ecb74 0x1e7d9f8c 0xa69f72fc 0x743e81bc
+ 0xa11aacfc 0xab8fdc17 0x263ea36e 0x840bc0ec
+ 0xb994aefc 0xcc5922c4 0x08411c01 0x0073895d
+ 0x7b661458 0x8bf91a68 0x93112089 0x541e53ed
+ 0x37706daf 0xc8733951 0xe74fa74e 0x638cfb72
+ 0xe696bdc6 0x87f4b7c7 0x413acce6 0x16642eec
+ 0x83b0ecf9 0xcf770d15 0xa4aad143 0x2ecd9f9a
+ 0x5bd7a2c0 0x07dca9c3 0xf6ab7c5d 0xaa4a55c2
+ 0xd410d6a8 0xdb84dc85 0x6b8e3aa6 0x8f268bb5
+ 0x1e9604cd 0xb5fabbcd 0xc8a519d7 0x07fdab7f
+ 0xceee08f1 0x08b9566e 0xaa646716 0x4ba7ca9f
+ 0xe0166e0d 0xb31e9561 0xbb9315cd 0x42201352
+ 0x5eae88f3 0x8b8e8eee 0xd63d0610 0xe64a45bd
+ 0xc2e8a084 0x2e421cb3 0xda754ee9 0xcdfe2c8b
+ 0x52b5544c 0xe5c0616e 0x387916c6 0x204c7ca3
+ 0xdc507264 0xca026018 0xb4dc7a91 0xa9f27453
+ 0xfb6995c8 0x349b640d 0xe59e1670 0x53d18974
+ 0xa61ee5e8 0xdc8b88d7 0x78d2f8f8 0x72ddf8c1
+ 0x7345705a 0x1e6ecb19 0xff0f4f31 0x197ae361
+ 0xc2e43f5f 0x80a2bf1e 0x274d46c4 0xbb3ae1ff
+ 0xd59798f3 0x5bf16015 0x871d2acc 0x4044c5b1
+ 0x9ea15fc0 0x9a735765 0x1683fd6f 0xfeb503d9
+ 0xc3de1998 0x14405d5b 0x86b76966 0xb3893dbd
+ 0xdb365404 0x6636d465 0x63558798 0x758d5f12
+ 0x6e225d18 0xad787cc5 0x775a5c1b 0x68112320
+ 0x23e1ea3d 0x8cf63961 0x0596cb9d 0xe9ca89e5
+ 0x96cb88a3 0xb7cac802 0x3b38edc2 0xb455d1ae
+ 0xfb215ed9 0x9cfe7580 0x0410155a 0xc6b75ca3
+ 0x359ef846 0xf96db47a 0x9800cc06 0x9ab0eeac
+ 0x1c86094d 0x19537992 0x3cc54b13 0xe877a758
+ 0x35c01849 0x396470de 0x8c229cb6 0x2b01a145
+ 0x54ae9638 0x33b0bb07 0x5d38fbfa 0x3a08d46b
+ 0xab433b4a 0x6be993fa 0xe85fe0e6 0xd4d2b82c
+ 0xc35398ca 0x66200602 0x51df5ed3 0xddb67c76
+ 0x6a4c2d36 0x9a02eb04 0x8ce871ce 0x66753dbc
+ 0x5441d00a 0x3d331728 0x80c55fcc 0xac286e97
+ 0x71fad042 0xe99c0cdb 0x3120ef01 0xfabe32e3
+ 0x265699eb 0xa73e31be 0xdd44e3fa 0x668531dc
+ 0xd4ba1078 0x0f13c8fb 0xa136ed20 0x010f3c83
+ 0xb3f8eaa6 0xc6d95837 0x0e09bd46 0xf0ecb760
+ 0x8dd905c0 0x02cbe8fd 0xfa898489 0x14ab16b4
+ 0x6ae99a74 0x516a171a 0xaa60c4c8 0xc075f0cb
+ 0xef530ecc 0xf6fffd33 0xe1d2af99 0x6913b9ec
+ 0xc96666c1 0x20743c9d 0xf65cd424 0xa671b903
+ 0xcbff34ba 0x60df0c1c 0x0d610133 0x4281a959
+ 0x656230ac 0x1693d52a 0xf4d37186 0x203caa5c
+ 0xa54cad8d 0xea1c8816 0x5bd54f8c 0x2a3c33c3
+ 0x151f72b6 0x63061580 0x0bc7f244 0x882f7656
+ 0x243d76fe 0x9b3bf7c6 0x3337a21b 0x8b9e3e63
+ 0x106289a1 0x74ae0571 0x8a43a5a9 0x7ad8c804
+ 0xb6867d45 0x45732f84 0x0d1773f6 0x9fc01aa7
+ 0x7b192c33 0xeeab4a4c 0xc96ae493 0xb5aad8be
+ 0x8b32c8cf 0x8ebf63c8 0x5f2a5e17 0x43a2899c
+ 0x35ec1fc2 0x7c675072 0x6673d01f 0xc1d85b58
+ 0xf73dec41 0xc1c89c18 0xff8fac98 0x434c3c5d
+ 0x184ee2bc 0x3469f366 0x2558fbf7 0xa0e5622a
+ 0xebb39f69 0xe9020554 0x3cd80512 0x767bcd48
+ 0x2e388fca 0x32eaa226 0xeaf4f6a4 0xbf7fb5ce
+ 0xdde75b24 0x30365d1b 0x48fd5203 0xca805f98
+ 0x82526a04 0x51a8dd82 0x61fdd2d0 0x3ef56891
+ 0x6d5d53d0 0xd83646eb 0x1d7a7086 0x7ac52300
+ 0x69e4359c 0x7c8058f5 0xf47d703a 0x21b863a1
+ 0x608b8362 0xb9a78389 0xa9d2280e 0x16672055
+ 0x05501917 0xf2e01be2 0x261a10f7 0xfe455dd0
+ 0x902a0cf3 0xbed63a74 0xeb4bfe27 0xab8b091c
+ 0x4cd8f22e 0x48dbda13 0xb3d29b0b 0x65bf3d3f
+ 0xe9be4080 0xfdbf0a24 0x9181ebdc 0x5faf48d6
+ 0xaaf1acb3 0xe2a2aaff 0xe1ae56f7 0xbd475702
+ 0xbfbe292a 0xa6133579 0xadfd6723 0x289485b4
+ 0x92667c06 0xee16866a 0xfbc71087 0x0cd78050
+ 0xfd40dfba 0xc9834441 0x5cfac60c 0x844b44ba
+ 0xe1e4d8ac 0xd6775e4f 0xd4f01979 0xab5faf6a
+ 0x63e03982 0x7789e272 0xb75dd171 0x39d0666e
+ 0xbd90a902 0xa4eebba3 0x2640274b 0xbcedd52b
+ 0x87033b15 0x2048812d 0xc13c2230 0xa7d345d9
+ 0x84b4fb4d 0xbc0960cc 0x4c7422ec 0x4bff7ea9
+ 0x16315057 0x1a9c50ee 0x5441830e 0x61cc7b9d
+ 0x2f7cd3eb 0x6ae05c81 0xc264d759 0x4c6dd592
+ 0x3d47dbbe 0xf8797367 0x4ae67c6a 0xdb42d373
+ 0x0f6a6e9f 0x3d6c6b82 0x16906b77 0x80f7dbbc
+ 0x6ee0683a 0x1afb8d53 0x4df1322e 0xc7d489a0
+ 0x9d06aab8 0x08c5ebc4 0xd8cf4766 0x0be222da
+ 0xd45596ee 0xa8113953 0x1a42b7c0 0xf4de2c73
+ 0xe5741505 0xeb9032d7 0x480ab9f4 0x595e824f
+ 0xc87c4e6a 0xe636b3c0 0xddb3438a 0x03f6ba20
+ 0xd43d9bf5 0x3bbe086f 0x6385fdd6 0x0b9d62ae
+ 0x1b9fc458 0xf6d1cffa 0x168ec5f7 0x93c98771
+ 0x018c51fc 0x3a6c5880 0xbc4d25c9 0xb90c47db
+ 0xccee6371 0x289878aa 0xb63ebf23 0x9fdff591
+ 0x863d71c7 0x1301cab8 0xead66f03 0xf8a74303
+ 0x91439b31 0xcbfc5008 0xc78a05c7 0x172ddb38
+ 0x16254ebb 0xf490cd3e 0x9724bdba 0x915c5eaa
+ 0x2d971801 0x672389af 0x25023172 0x69fb7e23
+ 0xc5d66742 0xdb578a72 0xbb6fe6ef 0x9ff3920f
+ 0x9e04e6bb 0x9bd9079c 0xe70a3479 0x1f423c00
+ 0xd3a901dd 0x7fceda2a 0xf1999db6 0xeb73cb34
+ 0x891cf0c9 0x55313b9a 0xe74ad3b2 0x98fc0593
+ 0x9ec6c756 0x7b84cb06 0xb06c9cf4 0x604b8b04
+ 0x112e4063 0xeec6c6a8 0xab9b6bb0 0x33e24999
+ 0x14c1cb98 0xac0fdd7f 0x2b9a1d04 0x7fb3667d
+ 0xd4375e71 0xe0b840e4 0x1c0789d3 0xe67c6b6e
+ 0x00b8439f 0xc0be1ba8 0xfd6bac10 0x3a7e3be0
+ 0x3c6a0d2a 0x38eb71ab 0x43711d1e 0xdbce233d
+ 0xce91e57b 0x2f386b58 0x88ca7857 0xbe5bf50e
+ 0x487a5b5d 0xb6470361 0x91e09471 0x18ee543d
+ 0xe1857917 0x60d489ae 0x5d44c618 0xc6f46454
+ 0x3cc37b33 0x9f8cf96f 0xd365b8f1 0x721f6448
+ 0xdbe1a2e8 0x81651a33 0xcf105b61 0xf4ef4f94
+ 0xc4693805 0x801e2a58 0xc932d045 0x6352f5b8
+ 0x731cb8aa 0x3b2a6546 0xad87d205 0xa6b41613
+ 0x8cc971a6 0x5cb47978 0x86b89ba4 0xb482b4a0
+ 0xe326080c 0x821b137c 0x2a154131 0x094b02a8
+ 0x56a1868b 0xa8a38181 0x8815878e 0x749bb12a
+ 0x8bab2a16 0xfbe0bfd1 0xabef2266 0xd59d9169
+ 0x975b6018 0xdb45a39d 0x6e31771d 0xa373d6a0
+ 0x214d69c0 0xa4cfc886 0x30a8b314 0x558b670c
+ 0x7cb96533 0x9c6c1dbd 0x3bae20a8 0x6a792685
+ 0x1a5d6816 0xd085f694 0xcf367101 0x908cc2d7
+ 0x9a7eed70 0x1e19978c 0xbf77c25e 0x5098a627
+ 0x2129095d 0xcb5c81c7 0xa2888a61 0xc9df4b0f
+ 0x0f20511c 0x6a16bb53 0xda26eb80 0x9a0190c2
+ 0x372ff753 0xe1ae8ecb 0xe54e1e31 0x967b935a
+ 0xd58c26d6 0x7d4a5515 0xa8f41efd 0x737a8b53
+ 0xb2a33b65 0x7d04ef67 0xfd491b9c 0xffe6c29c
+ 0x54424355 0x50c502e3 0xd8400ac4 0x6f17dffe
+ 0x8be39f17 0x6b3055b6 0x20c445f3 0x6cef7ee4
+ 0x821cfb2b 0xab19d476 0x540476d6 0xa6d1099c
+ 0x223acfda 0xbda49356 0x403d63a5 0x2b83600e
+ 0x45e5e0db 0x10323cf9 0x80675f78 0x6acc9d72
+ 0xf0d7b6bc 0x122fbbaf 0xafef53d0 0xa606b680
+ 0x13e91e0b 0x95a464dd 0x54ae9057 0xf12e1c07
+ 0xde806b00 0xce8904ca 0x44ef27a3 0x14f85e0a
+ 0xbc1bd0a7 0xa19863a4 0x7bb14eab 0xc3fe7ff3
+ 0x1c915fe0 0xfa45a07f 0xab471bb8 0x335918ae
+ 0xbc91e280 0xd27ab8c6 0xf79a0fec 0x0d54b501
+ 0xf870aaee 0x44c1b504 0x60d2338c 0xe2f01abb
+ 0xad4ca3b9 0xe8f97018 0xb3810e3b 0x3f885db3
+ 0x6890f6a4 0x8568faf9 0x503d9690 0x709dc422
+ 0x11f02c4f 0x57305bce 0xc1e07251 0x3b8b0c3d
+ 0x3da8d742 0xe5956aa6 0xf394f116 0x07daa257
+ 0xfd5b1b25 0x354b3d77 0xc2587f36 0x6fa8083c
+ 0x6b8b8a0a 0x71cebc82 0x799e5566 0xd66e6525
+ 0x3d80e29e 0x0a1dd883 0x7886487e 0x5d80604e
+ 0xf7533c54 0x53c428c2 0xdb5c0cb9 0x211fbb3a
+ 0xc7fd4590 0x409ec2d9 0xce50ff5b 0x142bcc4b
+ 0x475f8d75 0xdc4b4f3a 0x1f230600 0x863d868a
+ 0x5a8cfd49 0xc761fa43 0xa2ee8f88 0x5e8dbe56
+ 0x9a140e41 0xf5c00dcb 0x04786e5f 0x6c2baa7f
+ 0x9e4cb1d6 0x4074ee5d 0xbb4f106e 0x9afa4259
+ 0xefa345c2 0x806cd3a0 0xf51afbd2 0x653502a7
+ 0xcdf6fac2 0xdf756b85 0xb89ef192 0xba0b2652
+ 0xea1b3853 0x4edf3f15 0xccaf559c 0x11721dba
+ 0x36ab3f38 0x198d218d 0x5bdd7b39 0x3be8d3cf
+ 0xea3e6882 0x6ed8fc9d 0xbffeed09 0xe513b75e
+ 0xdbb9f2c9 0xf693d870 0x7bed8b14 0xe98cae50
+ 0x591d36d1 0xba55333c 0x20048cad 0x7104e6ea
+ 0x08a1335a 0x6dc416cf 0x431d8dfb 0x3f4db80e
+ 0x3ae3f65d 0xdec93bf5 0xe1773712 0x8b9d6e9e
+ 0x7a3599f4 0xa6292450 0xb7b68277 0xe57c20ce
+ 0x3cf4eb70 0xf00d3dd3 0x9da300bd 0xa4b25418
+ 0x6273314b 0xc5be2c6d 0xf297eb77 0x851334b9
+ 0x9eba7308 0x7a015151 0xa3416ae4 0x7c54c0b7
+ 0x352083c7 0x5c56ffda 0x1cf4d4e3 0x6ffef4b0
+ 0xa8c972d1 0x6db1761c 0x4b2f3400 0xfab16aaa
+ 0x437f0125 0x0c3ba2ac 0x89680f6f 0x7e48432a
+ 0x0e465f0a 0x943cc778 0x075156f7 0x46249153
+ 0xcbc017fb 0x0de6f92e 0xf380bcf4 0x9732a788
+ 0x6e01dc94 0x5329275a 0xec971ab8 0xea971178
+ 0xc1e3cbee 0xe598c0af 0xc5ca63a9 0x06018d8c
+ 0xc55446d0 0x18e04c29 0xd19da94b 0x74536dd4
+ 0x9837bbec 0x64bba10b 0xa63810e6 0x2189497c
+ 0xfab9e5a0 0xde0267ed 0xbfb94a58 0x377e52fb
+ 0xc8f5016f 0xd34b0180 0x2a5e942c 0x2ca6fe08
+ 0xfd52fd5e 0xcc2f838b 0x7aeb73c7 0x43832892
+ 0x2a44684b 0x0d8a7b22 0x9b84347a 0xacfedd86
+ 0x966aed18 0x66eb4a8e 0x890108b1 0xda13caac
+ 0x36c0f2c2 0xe2d85d85 0xc51f9f4e 0x9594e1b0
+ 0x0707929f 0x63fa9d30 0x2b461080 0x18566f8d
+ 0x40e12ea7 0x83e37963 0xa8d0eab6 0xb242700d
+ 0xd928ecb1 0x6f5d6d73 0x603f5d48 0x4902cf34
+ 0x9a477f4f 0x1b282220 0x3645ae11 0x09acad23
+ 0xf772e479 0xd3c5b6b6 0x09abad03 0xdcbffe41
+ 0xc971e22a 0x360a0c86 0x102ee956 0x9162221c
+ 0x6a59f30b 0x9685277a 0x6dc283ba 0xcffd7ce3
+ 0x0e487e66 0xd4dd807b 0x686bd0f2 0xc44a3392
+ 0x6422fa86 0x6716d62b 0x2ac73404 0xc88fe77f
+ 0xc49b6e01 0x8f011f47 0x5bb1ac5d 0x1d0ba4e8
+ 0x7eb0d0c7 0x9db01b4e 0x6cbdaccb 0xd46f1c0d
+ 0x96cc24e9 0xdbbaf254 0x9c5c45d6 0x325aadfd
+ 0xca9638fb 0x1aeb36f3 0x8be8295b 0x705d0bab
+ 0x9ceab5e3 0x5eb5288e 0xd7ec61fc 0x69bb3afa
+ 0xad60164b 0xc435c21c 0xeb79ab88 0x145a58f4
+ 0xae1e30ea 0x29987183 0x0a2a0432 0x160daa37
+ 0x14e295e9 0x978315c9 0xf323f88f 0xe24d5136
+ 0xae6ed24d 0x4a812cf8 0xd1e45d3a 0x64894447
+ 0xf47d0453 0xb6fb5f02 0x34685ba2 0x8c700222
+ 0x4dec7d3b 0xf035a0dc 0x9a802102 0xc3e27d5f
+ 0x1928580f 0xeaa68f5c 0x46aad88c 0xfa913719
+ 0x4fb0b232 0x3a638afb 0x4cd2068a 0xf26e4c98
+ 0xe9da3c5e 0xc7ad41bd 0x3f1cc280 0x1fca9886
+ 0xa777ff80 0x1ca76273 0x6a63123f 0x46d87fb4
+ 0xd9282597 0xab9e06bf 0x3e244814 0xd9653380
+ 0x48ab7d76 0x65d98e81 0x06047ee3 0x29b7ce31
+ 0xae94d96c 0x856f9e8f 0x158f1b6b 0x9de1570b
+ 0xca4ce67d 0x6f09907f 0xc891e152 0x6867c97c
+ 0x02a5b2d4 0xf2e7c715 0x84f6da46 0xd603e51d
+ 0xd837b33c 0x70de8d6a 0x598dd9df 0xed29a7a6
+ 0x42da0f62 0x893fc276 0x56b43a06 0x949d4f05
+ 0x7dde2d34 0x8b3f4c32 0xccc9c0af 0x01fdbdd1
+ 0x2a3a3cdf 0xb6763454 0x7377862d 0xb99dd58f
+ 0x9ad6cf20 0x2f80a8b8 0xc11b356d 0x4adae4cb
+ 0xe808d693 0x3e8605d2 0x005cbfb2 0xfe966e1d
+ 0x713b365a 0x4d12fc2f 0x1664286b 0xb5d41f0a
+ 0x4420d15f 0x63e106bc 0xc2fe4169 0xe5f440c4
+ 0x7fc0ae73 0x35ba3ba1 0x7a228157 0xfc50c107
+ 0x2bd1f472 0xa9d03dd6 0x62d1a612 0xf93c55e6
+ 0x6677a632 0xcd874d7b 0xa76ba1f1 0x2d82a8a8
+ 0xa65e30ef 0xe48eaccf 0x4d7a4adf 0x8c276f69
+ 0x0e229210 0x0096b100 0xa039ae73 0xea245d6b
+ 0x0ea50d26 0x99b480cf 0x159ea81e 0xfa45f5a4
+ 0xafd411d8 0xe1190cd5 0xc9e85cff 0x1e037ea1
+ 0xf4be41e6 0x48fd1c6d 0x24d52f02 0x3780b91f
+ 0x8e31dd07 0x1d392b15 0xb07e9d5d 0xf05b19bc
+ 0x4f52d03d 0x846cf6a0 0x4d51d2e6 0xe4144ab9
+ 0xa8f9558a 0xdbea007c 0x770f27bd 0xef95e02f
+ 0xc01ba9db 0x8ad80d07 0x039bfc69 0x8f5d2e43
+ 0x8640ff02 0x31872f4d 0xb959380e 0x027a8268
+ 0xf39dd7d6 0x7c84199f 0x8f977814 0x6830b481
+ 0x46495e33 0xd5c68952 0x6f2c3636 0x8de0e29d
+ 0xc03f0b39 0xbc54910d 0xfa46af50 0xe81542c8
+ 0x462d1ff8 0xb229a9cc 0x6a234b00 0xc96f857d
+ 0x0a932f55 0xbd7fcba7 0xf937d965 0xc90cfd53
+ 0x2ff150f6 0x0f5a40a8 0x805bfff9 0x92056edd
+ 0xf6326626 0xe18371b2 0x9b9ce558 0x252d7e17
+ 0xfbb7fdfa 0x3cf275e9 0x8ddc0be6 0x7e83319f
+ 0xc61ee1ef 0xee1751d6 0xe267323c 0xd7229015
+ 0x4a9cda9c 0x841730a9 0xd924dc44 0x619f2cee
+ 0xb5172002 0x210144df 0xf6fda998 0x64f75cb0
+ 0x3cd50175 0xdc7d3564 0xad0e94bd 0x18c876d5
+ 0x7532124e 0x3b99841f 0x1a2c6219 0xe7d5ffe8
+ 0x9f76b0ed 0x63437918 0x2b14f1ce 0x898a1cc3
+ 0xfad43f4c 0xde5adcb2 0x8b9d0166 0xb4f2370c
+ 0x1d212e4b 0x1f55058f 0x26bc79ad 0x681d1014
+ 0xe0ddd0bd 0x4c256b7d 0x7268e89e 0xa422562d
+ 0xd7a55326 0x6955e943 0x86ccb09f 0x03133a0e
+ 0x2fe2399d 0xd9601d6d 0xdd128b8b 0x182251f6
+ 0xa041ce84 0x5b5bc49f 0xbad64d6f 0xa7594fcf
+ 0xb6dce9ff 0x69c7e4bc 0x83d16d70 0x41c2593e
+ 0x282d55c7 0xcdcdddf9 0xd9855130 0x83fca027
+ 0x32379a19 0xf8fa8dfe 0x0720d059 0xcba2a7b7
+ 0xeab4e686 0x228601ac 0x660b45f0 0xecde3baa
+ 0x4047d983 0x4ced2e8f 0x77aa1d0c 0x7e6cd6a5
+ 0x80e06058 0x95d27baf 0x071433d6 0xc7d3d431
+ 0x7856634a 0xa1b894d8 0x2faedc1d 0x1e05a846
+ 0xa9bc7fa7 0x0ca15e02 0xbcc96351 0xb483c979
+ 0x239681be 0x24354ba0 0x5c743a31 0x7ed77958
+ 0x20a4d718 0x7b37986f 0x43a9e233 0x02091eb0
+ 0xebdbf21c 0xffd2069b 0x6f191684 0x111e2666
+ 0x8adb42dd 0xf26db866 0xff83d42a 0xc7d28a0e
+ 0xec1bf909 0x10434bd9 0x6404e8c0 0xae30d43f
+ 0xf415a59e 0x3daeca66 0xe1be615b 0x04db2d3f
+ 0xa53b33b3 0x5fd6479c 0xab5ffe67 0x2cdaaaef
+ 0x61087f2e 0xd805a00c 0x11d85656 0xc1ae3754
+ 0x1fe38c7d 0x108e2ccd 0x3c6e1773 0x512eb70d
+ 0x86142b5f 0x826ec294 0x956a3025 0x8b04e083
+ 0xd69cd3bf 0x04f39016 0xf362b172 0x960466d0
+ 0x230a3139 0x19378fba 0x335f3518 0x206a29a3
+ 0x82465579 0xc1e4684b 0x9ac06746 0x1f0138e1
+ 0x875a9aae 0x35ed8dfa 0x030c59c3 0xb3ed8018
+ 0x2e91fa18 0x93739c48 0x172ed0d3 0x13722907
+ 0x8e4e0426 0x47f72379 0x8bc54eb7 0x8657e9b7
+ 0x0472cf9c 0x1424f3da 0xdf83007f 0x87aa810c
+ 0x0e14e6e1 0x9d0dcfdf 0x9e7696b0 0xe019c6aa
+ 0xa866fc9d 0xc19a1ff2 0xb187dffa 0x220adae1
+ 0x16deb6d0 0x57bb035e 0x8084703f 0xabca8b49
+ 0x577af6a8 0x520ff09f 0x3d87711f 0x1d2254a2
+ 0xe161d5be 0x23287038 0x11722e48 0xdc7c6153
+ 0x7e953ad9 0x1797ca90 0xd56bdecd 0xf7973432
+ 0x5804968f 0xb688ad25 0xfda5e113 0x584d2c84
+ 0xc5c02d74 0x7b6235b9 0x6c1712cf 0xb8ef7795
+ 0x26d414d0 0x4b705388 0xa5725233 0x4e29eb6a
+ 0x4e2f32b6 0x4996ed96 0x45b98f88 0x67ed828c
+ 0x34e7af7b 0x5640103f 0x6aacf602 0x354d85f7
+ 0xf6e8983e 0x1468e2dd 0xacae2dcb 0xd3bcf29a
+ 0xa176799f 0x57a1bd66 0x7971495d 0x44dfac4c
+ 0x32c643f6 0x57cc7b19 0xfee17e6e 0x1505f974
+ 0xbaef1420 0x3b930cd2 0x65fd2cad 0x92ce1aa5
+ 0x734f0807 0x65a5a815 0xa7124d4c 0x1ad9684b
+ 0x32eb33c0 0x761f49ca 0x10b49a88 0xf0af198e
+ 0xd7173b32 0x640b00ce 0xd3ffd60b 0x3a92cb20
+ 0x71eccf6b 0x7c1c49e4 0xc7401cfc 0xf3f52441
+ 0x736776c9 0xe8609667 0x8cbb06c9 0xc821f68e
+ 0x827c67ac 0x0a98a704 0xd71e62bc 0x349fe1e0
+ 0xac56ba89 0xd36baf48 0x54af6806 0xaeb2f143
+ 0x0247d79b 0xfd27b357 0xec131b3d 0xd9fecc41
+ 0xfdcb3993 0xec61c159 0x911a6bb6 0x849e85d1
+ 0x5e4794d1 0x3c771cb5 0xdbc45603 0x76ef6090
+ 0x4bfa505e 0x592b3fd9 0x05509bbf 0x2766b252
+ 0xd9b66afd 0xe80fb26a 0x1ea90db3 0x61b1e2e9
+ 0x5899953a 0x08c3bdea 0xe6393951 0xd2db7170
+ 0xaa7031f2 0x5afce44e 0xed13e406 0x2af7388f
+ 0xc6254e8c 0x3a846e5a 0x49de8429 0x56792361
+ 0xa9fa85eb 0x4d97a05d 0xbd804c72 0x9e3f10be
+ 0x94c6cb39 0x38a2729c 0xf71833f6 0xb9b36d59
+ 0x8d7a74cc 0x4d9d5b59 0xaa9a735a 0x4ebac1ef
+ 0xf073c9ee 0x38d2ea0f 0x87247f61 0x2e110dfd
+ 0xca47846c 0xbcfd03d4 0xea058e96 0x40cb9628
+ 0xaea31bc5 0xf39d05d9 0x246bec2d 0xb514efa1
+ 0x5861299d 0x148ef9d0 0x1f5e33bc 0x444e79ef
+ 0x52d62130 0xf391282b 0x93fcd860 0x6c3065e6
+ 0x8a739db1 0x51f6cd7f 0x2da05ac4 0xe8f8b6e0
+ 0x48adb62a 0x8c0c687a 0x2dc37ce7 0x993b198b
+ 0x31008c46 0x3e509467 0x514a6614 0xca7c1511
+ 0x5d3bca38 0x3a8188ee 0xedc7da67 0x3d243fe7
+ 0x209f9238 0x03b4bc67 0xbefb5ed1 0x644e60ef
+ 0x708021de 0xe7a8f948 0x8ec69a79 0xdde65d7f
+ 0x2304f3f8 0x616643fb 0x7343b800 0x102f165a
+ 0x848f5616 0xa85d42ef 0xc725fcf8 0x63207a50
+ 0xa10f827c 0xd23d11c4 0x9832e62f 0xe7e99da8
+ 0x492e1355 0x63882a0d 0xbeb2e2e6 0x02fdc22d
+ 0x1a696e02 0x9821f6db 0xadf34cb4 0x2b274251
+ 0xc40e4a88 0x7b22d05a 0x42574be2 0x004de66d
+ 0xccd4a41c 0xd19863df 0x2f1965ae 0x868d7221
+ 0x07cf8546 0x3fba2d34 0xb39e65cd 0x425bf20e
+ 0xa61be150 0x191d3530 0x4f975298 0x37e1f881
+ 0xd45df57f 0xbaba406d 0x06385459 0x4b105297
+ 0x1669f5df 0x0ff8db41 0x258d3667 0x8592fb19
+ 0x20f3da88 0x8bc12e8c 0x4247ed36 0x9d6ad7ec
+ 0x26128a8b 0xbfd08579 0x084e2fcb 0x9279b5dc
+ 0x3a33654d 0x1e40c91c 0x8f0a953d 0xdfd96c06
+ 0x8703d737 0xca1f3200 0x60ec2e4a 0xa8814a20
+ 0x6d9950a8 0x4b2438ea 0xc6ca6580 0x99f2f4ad
+ 0x42dc5043 0x1bec10b7 0xce44a349 0xa6b35911
+ 0x3583a4ec 0x65bcf9c1 0xd25c3af5 0xcb72222f
+ 0x97cb8371 0x85f75c9b 0x03b1d637 0x6f80294c
+ 0x3bdb3942 0x91126cd9 0xd3fbb35c 0x752a7251
+ 0x5ed886d2 0x19c91d06 0x7a883d41 0x550a9331
+ 0x371f617e 0x61543776 0xaf4b02a2 0xa390ca74
+ 0x99d106c5 0x3f8c2d8d 0x01ca467e 0x20e50f07
+ 0xa40edcb3 0xdd2b0317 0xf96342e4 0x94a6e3ae
+ 0x17431448 0x789ea7b0 0x7bb4fbf6 0x03839d5f
+ 0x13f86c23 0xc6efbe86 0x9f891cd2 0x3e3af545
+ 0x0b1d0457 0x481e80cf 0x406bd13a 0xb277b63b
+ 0xfb5d99bd 0x6fea0963 0x5b48c16e 0x0ac10b3d
+ 0xcfd388d4 0xe07a502b 0x4466cac6 0xaa21c31d
+ 0x806ba060 0xf175bac7 0xfee9f170 0x38d1af9e
+ 0xae1f0f7a 0x6252edb4 0xb23c56c1 0xede12e73
+ 0x5747e22d 0xc3b58928 0xaf586774 0x9b6e8b87
+ 0xeaf2016e 0xd1fa9a90 0x986a5882 0xdfe68064
+ 0x5657ea69 0x237bbb3e 0x01e22722 0xb7bd28e1
+ 0xb75d98c8 0x31ecee6a 0x861d60e1 0xebe8bebb
+ 0xdc35606a 0x447f0a45 0x9f50d631 0xcaab3492
+ 0x76035cd3 0x9d84a371 0x51b55a55 0x263fabd4
+ 0x62ff9ab5 0x8b1ee33a 0xdc85e9eb 0x0471df10
+ 0x29cabc6f 0x47467a07 0x6ee73133 0x536f5c8f
+ 0x15f2a4bd 0x2ad7e8af 0x631a9bb4 0x9ce75522
+ 0x228d008e 0x86fc05c2 0x5526b054 0x8db9d95c
+ 0xdea2c7d4 0x1336add2 0x901543ce 0x2a855d2a
+ 0x4c7e054d 0x967eab4f 0xca5c932d 0xec109941
+ 0xf1752baa 0xd4b3a39d 0xd999886a 0x1a6cd856
+ 0xb11f6348 0x60a21b64 0xea4467ca 0x51db6925
+ 0xf8ee33a9 0xc674ce6c 0x5fa834a4 0x17f2b8ad
+ 0x2eab9ce0 0x0ad42708 0xd8a6740d 0x164c4fe6
+ 0x1f9d12c5 0x3efb12ee 0xedf0e724 0x7e8880ba
+ 0xe9c55084 0xd9d6e9f0 0x8f4ec3ae 0x2d6aaa11
+ 0x480e0081 0x28b6c152 0xee01619c 0x79ddd62c
+ 0x4b17ea62 0xeda6fb70 0xd3673924 0x02e84486
+ 0x4c0d66ec 0x9ab8cd5c 0x340fa6eb 0xf8db9df6
+ 0xc72b2937 0xc09cdf2c 0x7ba60229 0x5318612b
+ 0x08a07717 0x81cfe5ca 0x32a3b0e9 0x03cc518e
+ 0x1085bd98 0x16069e72 0x6aa01ff2 0x0b512345
+ 0x5ce6b51a 0xb58b347d 0x0dad3da5 0x7bc5aae3
+ 0x81a88658 0xd9857a74 0x4fb95187 0xe03045db
+ 0xbe4ddc3a 0x68be74f7 0x9663e4ac 0x4d31a7d2
+ 0x7a2a70fd 0x03dde6ec 0x827e2f9a 0x17cf679d
+ 0xb34aefe8 0x085aaebe 0xcff354e3 0x18754a97
+ 0x10c4a4f6 0xb21d4e04 0x8e93af63 0x226ea564
+ 0x6c3608a8 0x9fa96865 0x24f420b6 0x7d4a31e3
+ 0xb7852762 0xd1c752f5 0xbcfe1a9f 0xe3cd44ba
+ 0x800d6669 0x08455dfc 0x2bbdab4b 0xcc8cb0a5
+ 0x268cd5d3 0x2b0cbe1b 0x40cd57e0 0x939c0f22
+ 0xb85a1372 0x6c06319b 0x2be94501 0x9e13089d
+ 0x2df0027a 0x47bb8a84 0x660234b0 0x6a05c46c
+ 0xde9eb668 0x2fbef0ec 0x8e7391db 0x875bd721
+ 0xa1e55bf5 0x31dc45aa 0xeb0fa893 0x36f0fbf8
+ 0x8edacf6d 0x61c11564 0x9fe655fc 0x34378418
+ 0xe032bb0a 0x5e996c49 0xaa576bb3 0x88f1f99d
+ 0x08562a6b 0xa4d7900e 0x3d124350 0xf10984ba
+ 0x65af441f 0x8329eb45 0xfa1c3069 0xd9c18941
+ 0x6bf28004 0x32d89f25 0x107ae0eb 0xf23bea70
+ 0x709b7c6f 0x7f6bc1b7 0x6829a1cb 0x770fec21
+ 0x6dc4d64e 0xa37d7219 0xe5551a04 0xcd470067
+ 0x81d6207e 0x81bc2a06 0x5330dc76 0xbe8b6aa2
+ 0x5080f90e 0x7f393edf 0x37194036 0x1b19bf9e
+ 0x4ff560fc 0xeb207634 0x2fa526e9 0x9c48acd4
+ 0x9b9be6b0 0xfa749280 0x715fb587 0x50287f59
+ 0x04bd42c6 0xf8674fd2 0x614fde7e 0xf0482894
+ 0xa402a285 0x54813092 0xf50e474a 0xfa420315
+ 0xfe7f82a9 0x835dbfdd 0x08540acd 0xabba517d
+ 0x197c438e 0x3f69c2c6 0xdf1b60b0 0xbcc4b1c5
+ 0xbb967e53 0x8a2e2be3 0xb78406f4 0x6cca685b
+ 0x2877516c 0x3159fdb2 0x3f48f0a2 0x88c2ed5a
+ 0xe8731530 0x227413ef 0x50b5610e 0xd0e7d76d
+ 0x68b8a8e9 0x2f251606 0x0ba3ca68 0x3f470646
+ 0xa473b7e8 0xa36ec586 0x0f41792e 0x4ef380fe
+ 0x938d7626 0xbdf5914a 0xde6b5c26 0x26306e15
+ 0xfbb123bc 0x9cd3a83f 0x5d621b36 0x9c391ee7
+ 0x0921d18e 0x261a36c2 0x28cf5843 0x1b65db1b
+ 0x28cf152a 0xd1308452 0x6aa9803c 0x8f11c7bf
+ 0x42797ebc 0xd02410f3 0x56b4c779 0x22e788d9
+ 0xc3fee627 0xa1673ded 0xa389d31d 0x47563835
+ 0x4e963ba3 0x2acbc139 0x70da7525 0x39b3ada3
+ 0xdf20f92b 0x1ff80e87 0xf847db4c 0xefae0a2b
+ 0x42139d4f 0xd311a9d8 0xc54ccfcb 0x3b7c939c
+ 0xb2eefc73 0x4908680b 0x30f160ab 0xa15abe60
+ 0x31cdcc4b 0x2b5d457e 0xa264ccd5 0x73dfc993
+ 0xa75c34aa 0x1b302cce 0xd5c93553 0x6982ca4f
+ 0xf83cfac6 0xb1235d67 0x25780fb9 0x78af4f8c
+ 0x76b1412e 0x139afea7 0x291cebe3 0xbd275519
+ 0x18c300d8 0x33502f82 0x86f1d060 0xc83323f7
+ 0xc8d57b77 0x928a2c82 0x9ba9d389 0x4942f49c
+ 0x04c5abcd 0xc5fa8ab3 0x3e4936d5 0x6c5a6c16
+ 0x69f97f82 0x277e2c29 0x4f5a84b1 0xcc546d60
+ 0x887d8de1 0xbe980c48 0x6fb583bb 0x8f0dda22
+ 0x64ed4be5 0xd3be3a6d 0x615532b2 0x260b87f7
+ 0xb54915d9 0x9222464c 0xd447b5fb 0x08ef3c9d
+ 0x1e68ebaa 0x16d60b49 0x67b5c5af 0xef5d90fa
+ 0xf2fd3185 0xdb03838d 0x17ffffae 0x43304284
+ 0xabdcf858 0xfa019d66 0x80a891f8 0x4b2898ac
+ 0x676c113d 0x711d2b3c 0x59323717 0x912dbb50
+ 0x55afd393 0xde134c0e 0xaaf1d1b7 0x97975a07
+ 0xb66e6cab 0xfb0f54c1 0x6dae6384 0x04405a5b
+ 0x95df053f 0x125f371c 0x6656c332 0x5801265f
+ 0xcf365f00 0x31c300a5 0x2a7617ca 0x65ce79bb
+ 0x4cc96bed 0x1af82f49 0xfefea103 0x49054f1e
+ 0xb9341875 0xb37952dc 0x1db40d2e 0xe23154e5
+ 0x5a4e8bcd 0xed67b774 0x6639eb56 0xa4b3a6f9
+ 0xc0918496 0x295261ff 0x08b0f294 0x54573333
+ 0xff925b65 0x7872e916 0xbd5552d8 0x5d72050d
+ 0x1cf126d7 0x9dfc6d65 0x3b107698 0x0b9f2951
+ 0xeba14913 0x5c065af1 0xb5dd50ea 0xbe47408c
+ 0x3c9da76d 0xbafbaad6 0xef2b0118 0xa97bf92a
+ 0xf2d0b2d6 0x39c8bf7d 0x3017810f 0x35583abd
+ 0x2f430d70 0x7d08a9a6 0x4304c566 0x295fbed9
+ 0x07412bc8 0x833dd8bc 0xf086a3c8 0xf0836418
+ 0x85985a3a 0xd620dec9 0x3c81fc7a 0x08fbadb5
+ 0x55d56912 0x6e63f48a 0x3e178cb9 0xaf43c5d2
+ 0xce83c97e 0x0b59010c 0x7806f1e8 0x5ceda01b
+ 0x0cbfd565 0x1234bea9 0xadf6ad5b 0x68c5c83f
+ 0x7b5ceb7d 0x55bcd3f5 0x1e1fe06e 0xe6c9bce5
+ 0x95b5563d 0x0318973d 0xc2c4b750 0x8297ff40
+ 0x1223837b 0x8264fea3 0x1e9a70df 0x69ed57ff
+ 0x9598bb0d 0x1647c7a6 0xc2f1e9ea 0xc47f77d7
+ 0x5e088380 0x31b7cf46 0x7aca1985 0xea1bcad7
+ 0x058afbcb 0x05929ff9 0x2d5c85fa 0x19b2eded
+ 0xfb6bd501 0xa0ea0987 0x4b8dae5a 0xc9bc0d84
+ 0x2d1841ff 0x58b4bbb3 0x5f3494c1 0xce489fcf
+ 0xf048eee3 0x8a146cfb 0xcb5d2fce 0xf24dc8ab
+ 0xac9a22f4 0x1c0e8be0 0x8f1982e2 0x979abeb6
+ 0x2e61de90 0x7096ecd1 0xe6326066 0xf6b2c331
+ 0xc8035863 0x23ac48f7 0xcc6a8a96 0x6d2a847c
+ 0xe3cd2dfc 0xcb224f09 0x5274254d 0x1052513b
+ 0xdd244a04 0x2b583887 0x24b623f9 0x1cde29e4
+ 0xf86fdcab 0xf3fbee4a 0x34804cb5 0xe4d2d1be
+ 0xe3ee0459 0xba8e1428 0xd0d61467 0x493d74a8
+ 0xda33b30c 0xef080476 0x6c4f86a2 0x3917c5f6
+ 0x14052bd1 0xc5d10f70 0x3eb72eb5 0x2939b07d
+ 0xcf722a48 0x330615a8 0x797bfb7e 0x9c604abd
+ 0x612ca005 0x716bdbee 0x8098f5f9 0x4a591363
+ 0xbd89a21f 0x5e3787ea 0x2acbffa1 0xff907f14
+ 0x42ca9221 0x4d15a235 0x76d4e9bc 0x2080e33b
+ 0x6437bd3d 0x3d5b4267 0x9ac9655b 0x857b5a56
+ 0x8db93b3d 0xe1c45c90 0x0872b3e1 0x4935532b
+ 0x314c8628 0xa43c7d03 0xba6468b3 0x93056b1d
+ 0x60e61ab4 0xb6995957 0xcd37b047 0xc50cd92b
+ 0x259a8690 0xc78684a3 0x96384186 0xd9bcb24d
+ 0x31b39f0a 0x0fbbae5f 0x869a70da 0x80f0714f
+ 0x50070cea 0x2643b25c 0x164c01e3 0xc77d8624
+ 0x48f047b4 0x0cbd2c71 0x4c0b13b2 0x667fc4a4
+ 0x848c28cf 0x05443953 0xfdbd5329 0x3aeae7b7
+ 0xeaa0de2d 0x498be6e8 0x9663391f 0x8d55c785
+ 0x20c68ab6 0xfc7591cc 0x5f757324 0xa30d684f
+ 0x6ccb9c33 0xe90c74ae 0x488bc0dd 0x08231a14
+ 0xe253a7fd 0x9196b1cc 0x25a54296 0x0f70ba47
+ 0x9ee0a233 0x43c2e7bf 0x2d927857 0x1fde792e
+ 0xc0598134 0x7aac6123 0x39da69f7 0x99233284
+ 0x5894e482 0x396fb16c 0xcc554518 0x61784cde
+ 0xf12b0d7d 0xf1e7ee64 0x53a93eaf 0x142d292c
+ 0x52c36ba0 0xd9037d20 0x9eba60f0 0x4a041620
+ 0x5462a0d2 0x9ae6663b 0x0a5dfe17 0x9307f8f7
+ 0xc3532fd2 0xd20b3393 0x82d40f2d 0x3b139fca
+ 0x6ec0948f 0x1434629e 0xa529a79f 0x3a607eee
+ 0x07ee780e 0xa407a5ac 0xbad8d686 0x888401a7
+ 0xf221e944 0xe8ba61c6 0xc3caabc4 0xd610be89
+ 0x0e5432fe 0xb38b44a2 0x65a48b8d 0xcc044491
+ 0x253a116a 0x96c20a3a 0x13bf416e 0xbd80a231
+ 0xc94420a6 0x8ffee6ea 0x35bd2c90 0x39bbc314
+ 0x762981a5 0x7217db3b 0x8ace0761 0x31e2506a
+ 0xf1d679eb 0xab0b8a9b 0xaaff2f04 0xf40502fd
+ 0xe56aa165 0x418522a3 0x2fb1212e 0xc25102c4
+ 0xae39da06 0xe708d400 0xfedfc55d 0xcf13fc39
+ 0x77cc3ff3 0xb70b7ee5 0x57e2732e 0x54eafd32
+ 0xee513833 0x2f2f685e 0x17c8b664 0x4b22ab02
+ 0x684951ca 0x67844071 0x27c3c09e 0x36f129d3
+ 0xf5d71bbc 0x251d6129 0x6cd71b6a 0x975e1d42
+ 0x89142f16 0x6c250a42 0x9058209b 0x7f713bc6
+ 0x7bfa7c2c 0xe6a5a5cc 0x90a74d5f 0x79902546
+ 0xd43e0042 0xc3b12519 0x2afa12af 0xf11aadc6
+ 0x5ee59722 0x802b403c 0xa282210c 0x7658c843
+ 0x88a81f68 0x25b8fcd9 0x967d3058 0x1ecbeac8
+ 0x9b1f0dc3 0x16dd19ac 0x3c279aa7 0xed5c8077
+ 0x2c03b915 0x3b0cd605 0x3677eef0 0xddddb73e
+ 0x407a5512 0xb8cbb129 0x7d6f0f97 0x96e41ef0
+ 0x7d1bbca8 0x7fa26a3b 0x025ed42a 0xceea965b
+ 0x4a10020b 0xc3c47832 0x171644f2 0x75baa013
+ 0x436abd20 0xc7000fa8 0x03123e13 0x3b80f711
+ 0xee4401b5 0x34bb57b4 0xb7fd072c 0xfb5cb343
+ 0xf6ed3bc1 0xd83b2953 0x9285bbb6 0xb9e9afb3
+ 0x23ef8322 0x46111ee3 0x1b5ee880 0x994b4698
+ 0x11348ba1 0x358ca0d0 0xf9e1e517 0x58150115
+ 0x31b69c9c 0xb59d1a14 0x736d1af4 0xa2b6fb4f
+ 0x6df398ad 0x5f5ee1c6 0x499e00ab 0x65024633
+ 0x32af0af6 0x61aecdc3 0x19dc2376 0x061c1132
+ 0x09eb3e31 0x53edd271 0x280ad517 0x167d6297
+ 0x11da637a 0xfee5d512 0x86ba451b 0x9ac4dd03
+ 0xae09fe4a 0x011fb154 0x5dde9f8d 0x66b77ebc
+ 0x348f5dc4 0x89d838c5 0xd1076c44 0xb7207c6b
+ 0x288ef144 0x4ddbbc30 0x8ab3181a 0xb3a9cd9c
+ 0xe8da4c2f 0x5f51ea25 0x25698b3c 0xe5d8be42
+ 0x9033461a 0x08ab6b56 0xd3ef4e5e 0x22fef14c
+ 0x40e6cbd2 0x8023d0d9 0xd3624fa1 0x05058ed6
+ 0x7f9e29d4 0x2d679020 0xbd8a9438 0xfc2c7ae1
+ 0x43ff62ce 0xa5c960de 0xca118741 0x1d3ff652
+ 0x7aad82fa 0x7e05c2b1 0xaa60d6b5 0x1b44c011
+ 0x3d8ed489 0x33e5569f 0x954c9df9 0x6a3f3eec
+ 0x185e0868 0x0b261932 0x4abcec9d 0xe91a01b5
+ 0x2dcb391b 0x2623c791 0x4054eeb7 0x39f859cf
+ 0x838a2034 0x89b408d4 0x58976dd9 0x130dc93c
+ 0xd7c36f4c 0x65a57934 0x87364549 0x5e9e1b78
+ 0x598c3e00 0x1267d53c 0x12655bdc 0x757ba8ec
+ 0x20897226 0x121f8469 0x4db11ce8 0x6c4457ce
+ 0x408c5799 0x0dafde84 0x34e803f9 0xe6c40be2
+ 0x76601d29 0x6f382889 0x60a7602d 0x0e9f8f86
+ 0xd02bde01 0x6bbe40f2 0xcfc7e18d 0x18bb288d
+ 0x7693588d 0x93b5bf2c 0x257a886d 0xa444942b
+ 0xddc30b6d 0x0c733fc6 0x59c7fb0c 0x1e7428e1
+ 0x00e95317 0x8bb2b789 0xd1e8d918 0xe79d96be
+ 0xcdaecf72 0x1f10292f 0x8550150c 0x3ac030fb
+ 0xa740ed6f 0x86ca944b 0x1cb36602 0xb7a210bd
+ 0xe3943a61 0x3a6eee17 0x26e3c293 0x48587d54
+ 0x2e3c250a 0x9f5139ca 0x4ba8e861 0x310f187d
+ 0xf30ef633 0x96708592 0x2c8219ed 0xba807709
+ 0xb84d2c21 0x683d5e31 0x7c73d54f 0x20a9f6bb
+ 0x8c571bfc 0x18f513b3 0x983064fd 0xfbc61cd8
+ 0x34d473d7 0xe0c16341 0x3a51b21a 0x3f7ffd24
+ 0x33d20d89 0x92ed2b84 0x711d3f75 0x4437d1d2
+ 0x19ffb997 0x03fc59d2 0xd73c4ce0 0x1c048be1
+ 0x3e1c70e6 0x2132c8dd 0x96883172 0x9e7ceb89
+ 0x03c9bd60 0x6a288f88 0x9b69b2e3 0x21de2320
+ 0x7ec42f80 0xfa9c1431 0x421447e9 0x82b422b8
+ 0x691d53b6 0xe5adfacd 0x58d1fd02 0x5e66ac2d
+ 0x1020615a 0xf1a5aa71 0x9ae9f314 0x61a8780f
+ 0xfd35d0c2 0x6d0acb7f 0x8665a3cc 0x638dfdae
+ 0xf77cd507 0x9e896caa 0xf023fe26 0x138ad408
+ 0xd4a3d2a9 0x20392108 0x4e259b7a 0x294084a2
+ 0x353ddca7 0x6b4e0d0b 0x2ecb3b7f 0x2e72b5f6
+ 0xbd09b0dd 0x4de2ddab 0x27bbaf57 0x93c0044b
+ 0x0c9ff149 0x5e06496d 0xae665015 0x422e1608
+ 0xfb06c77c 0x7f49815c 0x74b36569 0x97c6b34d
+ 0xb2171d9d 0xd85c83a7 0xd95e5cd4 0x474b6faf
+ 0x4276a8cc 0x3eebf9da 0x373c9404 0x0fe5b125
+ 0x2140e5d1 0x99fd5df9 0x1b624b9a 0xd277f04d
+ 0x57d365a0 0x49fef587 0x1e8c3af0 0x4d827485
+ 0x075a70d4 0x75569578 0x9d03ee73 0x2956bfcf
+ 0xc45c3dff 0xe15ef324 0x4389e20b 0xb2b6a465
+ 0x863fbaf3 0x7503fb46 0x41d8f4c8 0x871f04e5
+ 0xb677456b 0xc806932d 0x99d586ce 0x94ad33e6
+ 0x996a43b8 0x4c7ff253 0x441e68ea 0x3f2454f6
+ 0x7b33925a 0xed5a56d7 0xfa40f2f5 0x3e7a60f0
+ 0x45bae53b 0xc3237b7d 0x3d6fe60a 0x7ef17115
+ 0x6df8dbb2 0x26d1240a 0x7372d23d 0x5767532e
+ 0xa72e2c58 0x2a0d2f14 0x74d029c2 0x1bcf8b01
+ 0x513dd7e4 0x800a6440 0xe0f3a8be 0xf951cd2a
+ 0x5795eb8e 0x3384450b 0x46e7970e 0xb4434ac3
+ 0x468194b1 0xc562555b 0x76d9cb19 0xdf109cad
+ 0x57f1ac2f 0x1207af15 0x19d7cfda 0xfb4c069b
+ 0x306802c4 0xe8aedc76 0x0170ab97 0xd19b99d6
+ 0x7fe69394 0x60b6dd20 0x184caddf 0xd4c81b0d
+ 0x008ebffd 0xfd615c94 0x813a5a30 0xb3386934
+ 0x5c54130d 0xbe0a6b6f 0x91b127cb 0x7207bbff
+ 0x176cac26 0x450be167 0x53563516 0xd6f5ed1b
+ 0x90ce178b 0x80e28eba 0x4ddf538c 0xb8037a72
+ 0xceaaa6ff 0x3e0eabdc 0x2af375b6 0xfafdf3bf
+ 0x24bb3630 0xbcd6da54 0xc59375ce 0x4e9d08c9
+ 0x7953057e 0x81ef3d8b 0xcb641721 0x8fb73300
+ 0x07f1dd2f 0xda12a374 0xae008fff 0xd106aaac
+ 0x5a4f59a3 0xe01bd4ef 0xe1ff2c4e 0xd58c4500
+ 0x283e8041 0xb2c7ec64 0x81077f24 0x304fd646
+ 0xb5554330 0x098fe673 0x9e5976ba 0x2e24c1c4
+ 0x3dfad07f 0x3d64fa0b 0x78a9c65f 0x282c343f
+ 0x755810ff 0x363e7150 0x692be96c 0x62cc0559
+ 0xb7b9e8c1 0xe35abebf 0xf28d706e 0xea9b31da
+ 0xd4762701 0xce0654fd 0xc10a087e 0x0ee813cc
+ 0xc66364cf 0x56a8143a 0xb8eafc6c 0x085125a4
+ 0x758752b3 0xfd8df76e 0x483c550a 0xc155fb38
+ 0x20188374 0x118c9519 0x2e1dad79 0x45b648e2
+ 0x32eea6a4 0x73373bbd 0xce78e1b1 0x49b6150b
+ 0x826f31d7 0xf5b27772 0x76467cdb 0xab248975
+ 0xc98c52c2 0x331e7992 0xb7ca3cb9 0x65fba8de
+ 0x8d9df126 0xafb34641 0x83627ecf 0x4f6f5711
+ 0x0a18b1bd 0xbf9f7e56 0x5b532a14 0x2c1c7f27
+ 0xaaba76a3 0x0019b4c1 0xad0dec08 0x0a090710
+ 0x9d092403 0x4b7f63f4 0xdda21492 0x5ac79d8a
+ 0x53636303 0x8baacf07 0xd0e54e2a 0x06af65bc
+ 0x1776250d 0xe3b7a745 0x3ed99c2e 0xcdfa72f1
+ 0x28e2c19c 0x972ed696 0xc40238be 0x2eae4108
+ 0x16dbeec2 0xe5aab504 0xb752b0ec 0x908c027a
+ 0x5d6706f5 0x5dc64b1f 0xda6012bb 0xd823ba00
+ 0x21227a10 0x99c8a5f7 0xe13e863c 0x7271ad65
+ 0x37341fc0 0xed4f202f 0xe9394896 0x8c51a222
+ 0xc730618d 0x61f38ac7 0x077bbea0 0xf7068ed0
+ 0x9fe0eff4 0x09f20a63 0x692cb600 0x965b334c
+ 0xe4d16d0a 0xabfd76d4 0xcebb865d 0x52ae79e3
+ 0x54be2cc4 0xcada0fcf 0xdc531eda 0x0f6f5a07
+ 0x45c26e9b 0x1b65c5da 0x747e35ce 0x28e8f353
+ 0x8b14a4dc 0x70fec472 0x386766f5 0x452ec69d
+ 0xea3d1060 0x4ad0a84b 0x74947e04 0x241d736e
+ 0x67087154 0xa8429f6c 0x93f6fa81 0xc8ae48e8
+ 0x8bc37b91 0x3c412b3c 0x5a9b6ea0 0x77b1267c
+ 0x4e654c9e 0x3af8be15 0x0c1fcc1a 0xdd53e911
+ 0x4133f74d 0x19b478ea 0x935059e6 0x602d1c43
+ 0xef2f0dc5 0x606c328e 0x3bcb34f9 0xd3e43917
+ 0xa4b13432 0xe32ca0b7 0xe72cf4f7 0x89e64046
+ 0xf7665787 0x0e2ceb68 0xad0326bf 0x0df255df
+ 0xfbe35bd7 0x452ad738 0x151ded08 0x4977f8b4
+ 0xfb0d8ce6 0x55ba4d5e 0xacc482b6 0x685f74cc
+ 0x483dcc86 0x09346c6c 0x1bfb0413 0xc8454c50
+ 0xed0ab7fb 0xbd60dc85 0x2d4ce7f7 0x7e374d17
+ 0x97c4de4b 0x8e241f8e 0x0c63ba83 0xfe2b6605
+ 0x0d16e6b6 0xd2b65dc7 0x574904d1 0x57013653
+ 0x02bbbb72 0xa1a951e7 0x2e06e4c8 0xaf8a0ce2
+ 0xe45132d5 0xc335004b 0x7a80a191 0x70abfb32
+ 0x0e6dae78 0x47ae882d 0x2ffb0f2c 0xfbfb1549
+ 0x3f5d2a7b 0x9df9be34 0xb69b7919 0x051a54d4
+ 0x3e7822d9 0x83f3988b 0xf4f6a380 0x382ec90d
+ 0x19ec37e6 0x41da0b90 0x63edbfe6 0xb53fca2b
+ 0x4117bab8 0xe711495d 0x93b066cf 0xfa436ab7
+ 0xafeb2443 0x842a6a7e 0x92dbfd01 0x5536c8ab
+ 0x87706182 0x95b19ae4 0x20a5243b 0xd17d6e3a
+ 0xacc705bc 0x02124f77 0xcdd25a60 0x27f2cfd0
+ 0xab63270b 0x5d0d50c7 0x626b463b 0x8d1c6c67
+ 0xcd8faed9 0xdec15e02 0xeead3ca7 0x35e6b1b6
+ 0xa3404975 0xa40c4d99 0xba2aafa7 0x9fd543c8
+ 0x737fca65 0xf825b862 0xed028145 0xa19ab5c0
+ 0x7a5cf4c9 0x29275a49 0x4e70bfae 0xa68d7af7
+ 0x4027d4ad 0xc0f1f772 0xb1857bf2 0xeff36b41
+ 0x1cefd1be 0x609569f1 0x5e4a45ba 0x3982f52e
+ 0x2662da23 0x9995e160 0xa5236c1a 0xfc3dbe22
+ 0xe2cf629e 0x1927e9bb 0x890c2c5d 0x9b1a74a5
+ 0xd98da36d 0xd6394f24 0xea08f3ef 0xd7543732
+ 0x2c08cff2 0xb338420e 0x954ebee4 0x8f62faf8
+ 0x30001084 0x6209f495 0x4bf3151d 0x549fe524
+ 0xf0a233cc 0x3d9520f6 0xc3bb7564 0x724bf6b8
+ 0xf0364758 0x8c780cc2 0x85041d68 0x004c18d6
+ 0x7e1b0aed 0xe515764b 0x3f646ea8 0xfa14a4d7
+ 0x1d197044 0xf3eddc81 0x8aa91a1e 0x16256c4f
+ 0x8199c0df 0xbf9a50ac 0x568a0f09 0x2cb00264
+ 0xd72fd139 0x2705356f 0xcbca00f3 0xd1d48350
+ 0xd9ea820e 0x8cef5c8f 0x208f4413 0xa8cc4af4
+ 0xd3925d45 0xcacb25be 0xf5c478f0 0x2d98856a
+ 0x9b2ca15c 0xa866f9c0 0xd11e9a8c 0xecf63535
+ 0x26afb8e5 0x07582187 0x68e92d2c 0x701732d1
+ 0xcfa17e9d 0xcb923dcc 0xc6fd0935 0x2949f3f7
+ 0x2f819c1e 0xea483296 0xb234a335 0xe3e174f1
+ 0x2e79e24c 0xcebb3426 0xc7b11c2e 0x09c50c12
+ 0x1a776bec 0x9eb75be2 0x906fc75b 0xa951a0bc
+ 0x067984cb 0xeef41487 0x592d71bb 0x6d830d75
+ 0x9315da53 0xfc4a745d 0xf55687dc 0x41d554e7
+ 0xd9f4873c 0x51680147 0x70a32832 0x514a6b9b
+ 0xdb221d0c 0x5d8a04f2 0x56d0d2e7 0xea241411
+ 0x2fddf98e 0x4f114da4 0x5b08dece 0x4a1deb72
+ 0x8a05c6d7 0x5412556f 0xb34099d8 0x769a94dd
+ 0xa5e5f79d 0x2aeed8ec 0xb2c36124 0x4049a237
+ 0x14984601 0x1a595742 0x64490292 0x630c8cd2
+ 0x55e6bb46 0x6a0d06ab 0x2b0b11b4 0x7c616e40
+ 0x88ad3ace 0xd51e4e32 0x09b91afd 0xe7e15aeb
+ 0x0050ef89 0x4330509d 0x12cb2d58 0x8aa65df5
+ 0x6a3a7bfe 0x13110a63 0x6e0321e3 0xe00dafca
+ 0x71e02a28 0xbb179946 0xa46ec287 0xec8a407f
+ 0x71e4ecb1 0x9aa3eaf1 0xccc68628 0xc593d002
+ 0xadc7003a 0x4266b50b 0x3c1883ee 0x6dccb885
+ 0x417c946d 0xbed06b8c 0x333c5aae 0xb05e54ee
+ 0x16d7a8d5 0x2c4711e4 0x77f99748 0xea4f1ce3
+ 0x99077ba5 0x3efe0258 0xd6df1959 0xa68402c4
+ 0x17fb46f9 0x84dd7f43 0x2743ad55 0x4c3618ab
+ 0x066e70fb 0xa7ae2740 0xabfa9383 0x3550f323
+ 0x12df0416 0xf1453568 0xa72e19a3 0x858f6f03
+ 0xf17cc616 0x4ae587bd 0x18a72aff 0x3a7e96e0
+ 0x742fcbfa 0xf2978c0c 0x1c9b4647 0xead5df7c
+ 0xa4006862 0x4ff1f7ad 0xad9ef88a 0xf2e10660
+ 0x408e1435 0x54fce4ac 0x3b362a56 0x31215f74
+ 0xaa3c9bda 0x9e20dbdf 0x0d5fce6a 0x282c976f
+ 0x0edc8226 0x373f111f 0x3e98c061 0xf268555d
+ 0x2bc94957 0xaea989d8 0x509c71ba 0x12314a4c
+ 0xf763fd18 0x756c083a 0x210052bf 0xc8a587ec
+ 0xad316f0b 0x8bdc25ef 0x97d826c2 0x2b2274e0
+ 0xb2d83dc0 0x758a648c 0x98f048ed 0xc049ee18
+ 0x86a7ae90 0xb2cd2e74 0xbf05a5fa 0x99569e00
+ 0x91ef2ef3 0x0fa73191 0x8fbe0377 0xd833195b
+ 0xa8f92c91 0xd5180d87 0x78e66404 0xa6932c29
+ 0x63767065 0x212597be 0x71443fa5 0xc7f0f7e7
+ 0xee005d0f 0x3f554ee1 0x0ce921c3 0x11f7aa65
+ 0xab833603 0x226583ac 0xdc02270f 0x582acced
+ 0xe4873a4e 0x4789f1b5 0xe4556ae0 0x2db116e3
+ 0x4dcf008e 0x94848eef 0x33dd4850 0x763ee311
+ 0x8d129dec 0x37584ab5 0x2a72a7f1 0xc3812cba
+ 0x8b28d2f2 0x0adb3ef1 0x77c139ed 0xa024d006
+ 0x77b56ff4 0x237a0ef1 0x70c06866 0x3f678b49
+ 0x758b3ce4 0xac6fba3c 0x425f5226 0x736cb61c
+ 0x6d33908e 0x2db271b8 0x57a0b9e2 0xafa0c8eb
+ 0xe16670ac 0x01358d54 0x291458e7 0x20dbb518
+ 0x750ebeed 0x3b7ce363 0xab142fda 0x2f827c5c
+ 0xe4b63c2f 0x25b21550 0xd9a7d8a4 0x9a0d0235
+ 0x6ccbe996 0xbd16a832 0x408c6b6e 0x264e7057
+ 0xf76251cc 0x10b292aa 0x44e35c08 0xe10072a1
+ 0x8496f9f9 0xf3f14db0 0x903e0d04 0x437cbdab
+ 0x94bba5f6 0xd93cb547 0x6c8c5b9c 0xdaef1d7c
+ 0xc9245303 0xb8327055 0x17b4f91f 0x9609ed57
+ 0x276a2fef 0xd6547d96 0xd845e2a3 0xdb17e11c
+ 0xe06b1865 0x91ac2801 0x7499b2bf 0xfcc13e08
+ 0x4d2c3ad7 0x33f551e1 0x7d9409c7 0xafc9eb56
+ 0xd1b99328 0xfb86b03f 0x386621b1 0xc937917d
+ 0xd049796a 0xb61b9848 0x6e6c850d 0x9acceebb
+ 0x2335fff6 0xba4cc878 0x71410231 0xe2f8c5ab
+ 0x9af0d19d 0x28ec5cf5 0x756ac8b7 0xbef10a49
+ 0x0845244c 0x1d73e741 0x9062b8e2 0xda4ff7ed
+ 0x02b84967 0x1dfa2bce 0xa39fde98 0xb9754114
+ 0xf1d1128c 0xfe4a89f5 0x7f752ab4 0xc079051f
+ 0x9d280392 0x8e4405b6 0x9a78116b 0x93ccc928
+ 0x9423c484 0xd9d02b55 0x8b293206 0x4e1ba855
+ 0x8b163dac 0x86097281 0x5fed4e15 0xa3a9986f
+ 0x6aceb1fd 0x9840a4a6 0xb9159ba5 0x43a6a036
+ 0x48c6b148 0x741b03e3 0x2034fa35 0xa2238e26
+ 0xcbd2d186 0x543a2254 0x52bee0c4 0x3d86f09b
+ 0x91b2c0f1 0xbcc3b745 0x2f74849a 0x0330c741
+ 0xbe83b31b 0x2be0b1e3 0xb5289590 0xd70e1559
+ 0x575ed5ef 0x26095dad 0x243db065 0x7deef6bb
+ 0x65d12981 0xed493443 0x8bbb1d52 0xad9cceeb
+ 0x9d2347e0 0x6cca137f 0x17470bbb 0x7e3c2e70
+ 0xf8f031e4 0x089ffd36 0x54188a4b 0x0da3ca59
+ 0x89502f42 0x118865a6 0x188d2f03 0xbab32122
+ 0x8b7dce7e 0xd560dcf2 0x3b664c1f 0xc75878ec
+ 0x24483e82 0x5f98c3ad 0x30f8edb6 0x750517a4
+ 0x26b74663 0x4a92cf2c 0x34142eea 0x74434b26
+ 0xef952153 0x499bb195 0x0eef898b 0xc87096df
+ 0xebb06a79 0x6f85e09d 0x61582c0d 0xf067fa23
+ 0xe800ddac 0x5d94560b 0x7b3c3438 0xf8656d92
+ 0xbb2e740f 0x3919d1e9 0x4ae59719 0x9884c38e
+ 0xab33c8f3 0x2b6fe11e 0xbb918fe1 0x78b89ddf
+ 0x28ff265a 0x8d1be42f 0xc7ae521f 0x59021a63
+ 0xc8feb2b0 0xf4adb84d 0x1627d0ad 0xdf2f54b9
+ 0x6c34378c 0x19905a68 0x751ab74a 0x4ac834b3
+ 0x0482a8a0 0x3fa5727e 0xc67e56e6 0xe9a7fa62
+ 0x138c624b 0x8cfa9421 0x777be58a 0xa77e4a9c
+ 0x317880c6 0x784adbec 0xf24af624 0xca7b14cf
+ 0x0733ca3a 0x4df8fa2b 0xe737de97 0x8221ad28
+ 0x12318567 0x1143d1b5 0x6d785e96 0x96b4706f
+ 0x62b54a94 0x2cc3c8f4 0xf4509cba 0x013b1838
+ 0xeb30c28f 0xafdce478 0xb079b9e2 0xf7fde255
+ 0x369de668 0x51eaacb3 0x1a4857b1 0xdc155799
+ 0x14312bb5 0x88e95615 0x3baea03c 0xda51f1b7
+ 0x2ba9c897 0x02acb260 0x45d16629 0x69f4125c
+ 0xb814d67f 0xd9371fdb 0x2abe9516 0xcb4347a5
+ 0x8499fa6d 0x548d5caf 0xeaaea9a8 0xd2050d3e
+ 0xe7ffd097 0x1343ddc5 0x2c063604 0xd4860459
+ 0xe97d7e58 0x2b039549 0x7f9abb32 0xce9ae49e
+ 0x6a9f2bc8 0xf42c6e74 0xa2cc44a3 0xa586ee59
+ 0x9468aff1 0x9baa9f44 0xc672fa47 0x81af898d
+ 0xbe2e0747 0x2568ec6c 0x5a297908 0xa3a45a84
+ 0x86e7b0c8 0x25d653d0 0x2e1dd924 0xb8b8401d
+ 0xb6132a11 0x63380a89 0x70457a9c 0x5599343c
+ 0xdfe56efc 0x7347c609 0xd2a0254b 0xddb9eff8
+ 0x2ff89812 0xc3fb0b4c 0xaabcb56d 0x8ea167d7
+ 0x3058af81 0x90c13947 0xd2d066bc 0x9187a7c2
+ 0xea3f4bc7 0xde558f0c 0x553387c2 0xfe52ae90
+ 0x55e9dfc9 0x280c76a9 0x22029fbb 0x695decb6
+ 0x37e156cb 0x636cd8d0 0x314735a1 0x6b97c31e
+ 0x5990da35 0xa36210e3 0x731aa846 0x3e9f4591
+ 0x1c311983 0x1b05ca14 0xd26366ce 0x35108fc6
+ 0x6ec7c06a 0xe5479ece 0xabda431a 0xe876a3b9
+ 0x7306ec54 0x8ac2dbd7 0xb6025692 0x60e08291
+ 0xbd2d5771 0xae63c08b 0xb57f59d0 0xa0b7a4d2
+ 0xa1975545 0xd4246fff 0xb541c3e7 0x80579f75
+ 0x350f9ba5 0xc167fd9c 0xa4753b37 0x614432a2
+ 0x8c2a5225 0xcacb408d 0xc692b149 0x44eb19e3
+ 0x9e36674a 0x4221e3a5 0xc8847980 0x22188be7
+ 0x9f3b54db 0xca30b3a9 0x4f23026c 0x1ac563dd
+ 0x0cef9dbe 0xde1759e4 0x88a1ac44 0xdb249ed0
+ 0xcccf2728 0xc54995cd 0x1410f555 0xe68a533c
+ 0xbf63c4b7 0x53890c13 0x501696a3 0x09695674
+ 0x49675e62 0xd5859fac 0x62dfaa74 0xc2837e8f
+ 0x5693d6bd 0x6c4b7df7 0x19673414 0x436523f6
+ 0xd7476fa4 0x1c123daa 0xf160418d 0xb022c7e0
+ 0xa0798def 0x908aaeed 0xab420cd0 0xb42b83a2
+ 0x779b9257 0x8bd0dafd 0x17088cc8 0xe5707f57
+ 0x7e95cb37 0x2f0975fe 0xf6c69671 0x9adb2ac8
+ 0x9744adf6 0x534f59b4 0x70126a4c 0x094dc52f
+ 0xeb1bca01 0x8439872b 0xa9eb2393 0x93466ee6
+ 0xfaefa751 0x407578bc 0xf96695f3 0xece8916c
+ 0x90555ebe 0xd4bbb5e8 0x521e0328 0x733e7a44
+ 0x6b38d125 0xaf78c4f6 0x02a68e77 0xf0b3de08
+ 0x6b7055a7 0xe173c89d 0xf8d502e8 0x0af8722a
+ 0x0cb5d7c7 0x67fd3443 0xc3ece1f6 0xd1e3476a
+ 0x6c51b69e 0x1e4d6701 0xd30b9ed8 0xcae0b2cf
+ 0x107a07cf 0x9e995fe8 0x96be9a9e 0x9679a48c
+ 0x56e943fd 0x5840eba2 0x903172e8 0x030e7848
+ 0x01aa0b3c 0x3430ee93 0xd9074e67 0xba76da7c
+ 0xac651f8a 0x4776630f 0x335cc3e6 0xf196a501
+ 0x3946d5ab 0x9521219b 0xd5c1b923 0xea8a860d
+ 0xb68cd8e3 0x422fe195 0xee228116 0x7935c07c
+ 0xf9a777a8 0x5ebb5f11 0xca9af85c 0x2ced106a
+ 0x839746e2 0xb278a109 0xd80ac684 0xad50dc92
+ 0xcb1306fc 0x03b5953b 0xa1739037 0xb3d2eca5
+ 0xa2177c85 0x331d941e 0x07d760f1 0xaf91e655
+ 0x37859c68 0xa93f3fe7 0xfd8c0c27 0xfbaa7226
+ 0xf9ebb691 0x378f97ba 0xbff7118a 0xe2dcdddd
+ 0xbbcb31c6 0x690c39d0 0xa87db784 0x71e8f7e3
+ 0x6030ca21 0x4a0e52fd 0xfbfb507d 0x162bf88c
+ 0xaa2641c4 0x8df9c9b8 0x23266298 0xc3c49ddd
+ 0xd285aff8 0x3b867dd6 0x0be83ba1 0x0f4a797c
+ 0x1c934d37 0x0e0fcb24 0xa0a4d4bb 0xa4c9e180
+ 0x1f151322 0x44b9bce0 0x047feb93 0x3e05cf8a
+ 0xa9b3e489 0x43f0da55 0x6fcddbe2 0xa402623a
+ 0x5c8ad2f4 0xf7ea52fb 0x3da14b50 0xbf8849bd
+ 0xb45ca440 0x2893d691 0xf6d8ee21 0x9dc0cf25
+ 0xfa6be75a 0xeb27219e 0x9b160b84 0x1867d384
+ 0x5b536f15 0xdac9e97e 0x1d290193 0x683d4a93
+ 0x4c449e2d 0x493edc1b 0x8ae3a3aa 0x3a49ca51
+ 0xd6751c65 0x174ef916 0x94118e1d 0x0bc6adeb
+ 0x49c4b0cd 0x04668564 0xc9e39f39 0x19907555
+ 0x0320cb0e 0x32a643db 0x4ba9edc5 0xce11afee
+ 0xce71c45c 0xebe0c707 0x48d1d23f 0xb2704cfb
+ 0x94b97cba 0xaa934cb4 0x7e375bf3 0x7c9f87b7
+ 0xb34ebd26 0xb1ed5855 0xdd458d3f 0xcf071bd0
+ 0x3204188c 0x744959b0 0x20eb0748 0x1b863237
+ 0xc36fad4a 0xde026857 0x74c278b2 0x7be0749e
+ 0xd61895dc 0x509355a2 0xab890c09 0x210ef412
+ 0xae4678f3 0x3605af3b 0xc111b378 0x81f0173e
+ 0x4ac61ae9 0x2efebbd3 0xec8a55b0 0x5c60addb
+ 0x19ab7fa7 0xbf5bb0ab 0x7b55db2b 0xa246b5b0
+ 0x70739cad 0x20bcca0c 0x152a98a3 0xb1ada872
+ 0xf3a401eb 0xb169b481 0x1024e632 0xb285ec8a
+ 0x42f7bc38 0xe6ce9265 0x05ce19a1 0xf89e52ec
+ 0x2dd6f337 0x81b30e86 0x459ac80d 0xfa83fd49
+ 0xc0ba36eb 0xaeaf8c90 0xab621eec 0xe94ee998
+ 0x0f693a97 0x5d9a589e 0x439e79a6 0x565ea22d
+ 0x60d8e090 0xa021284f 0x4dd58eab 0x35cbe80c
+ 0x386c67b8 0xb260ff41 0x9b2685c2 0x37c33d86
+ 0x2b922b27 0x1aeb19d2 0x9d503c43 0x0fff6ce2
+ 0xf400393b 0x70be801b 0x8cfb132e 0xbb1781c6
+ 0xbeaf80e2 0x2a5a64c7 0xc02c7ebb 0x8f870c7b
+ 0x6bfecce5 0x8d885183 0x4f2c1b6a 0x0a3e6c0a
+ 0xb7d17ad8 0x7d593bb0 0xb1e00ea2 0x8d553de0
+ 0x07ecf8c5 0xde0c3afd 0x40f193a0 0x77030199
+ 0x458046a0 0x21b67cd9 0x836ef83b 0x53563580
+ 0x4edacbc3 0x1263d410 0x2b217042 0x4e3ad860
+ 0xd51576cc 0x714ba8f7 0xe02e102c 0xb38770fc
+ 0x34270f26 0xe7aa59c0 0x17a3461c 0xe6667980
+ 0x9d5ed074 0x4168f2da 0xdefefcf8 0xc6b3031c
+ 0x27c4d4f0 0x5e51e5be 0xf90cb81c 0x26ff3f7c
+ 0xabc25d19 0xd65e5687 0xa5ee2995 0xc4e545b1
+ 0x0184fab9 0xa44f4395 0x2aaef6da 0x33a682a0
+ 0x5f878a4d 0x0b808a4e 0xb95490e1 0x4e4b3902
+ 0xa1815407 0x3769d4f8 0x81943938 0x0d8b44d2
+ 0x89c90314 0xb779e2b3 0x1acfa29a 0x3ee54de2
+ 0x203c8450 0xfdbf24da 0x8b9bc91b 0x41a25706
+ 0xab9b74a3 0x6feaa6a3 0xed50c416 0x5dca2489
+ 0xf9d58d01 0x57682903 0xd951335c 0x55a323f2
+ 0xe6c10c4b 0x0983a265 0x50df7efa 0xc550b079
+ 0x1e670ce5 0xca74138e 0xa7e01118 0x4d1cd2e3
+ 0xcd3b73d7 0xc5c0d501 0xdd56b269 0xbc6bf217
+ 0xa3094ee9 0x794e6e21 0xc097fddf 0x191a1b70
+ 0xe6a45c45 0x47a1899e 0x29fe5a55 0xaf88ab14
+ 0x0a05bec0 0x05c97061 0x0b7654a3 0xfcb357b7
+ 0x31657eec 0xb5aeed41 0xc70ea45e 0x096075af
+ 0xf5236b88 0x6329310c 0xe1bdaf51 0x569053d0
+ 0x7679fcd0 0x04c70d46 0xcce2d566 0x0316e8c7
+ 0x391cdf9c 0x47045b03 0xac63bff0 0x1a7bdde9
+ 0xa5a725bf 0x6dc151e9 0xf02a3df4 0xfb01c649
+ 0xa6690e2f 0xd561a5df 0xbe0efc39 0xd35f7dd6
+ 0xddbe2e12 0x8f403837 0x1c92e116 0x1b47ecde
+ 0xabd75d5d 0x3b39c5a3 0xbc8a81e2 0x5beaaeef
+ 0x1206f28d 0x7aa1852e 0x96eb9ef2 0x30911a7b
+ 0xc1ed82f9 0x0940dcef 0x07c62124 0x1ec437a5
+ 0x688e0a9e 0xc26852a2 0x01bb985a 0x55429a26
+ 0xc90b329d 0xf618584f 0x1ed4fb9d 0xfe605231
+ 0xc20810d3 0x7cf66bbc 0xadf11084 0x80697ce9
+ 0x473457b6 0xd162e619 0x4e452b78 0xd39ddbdd
+ 0x8591db3a 0xb225b8e7 0x208855e9 0xefa860f0
+ 0xdd96e987 0x074a8ff1 0x1cf505b1 0x78d7b7d5
+ 0x8cd1cc29 0xae25f5c3 0x4fdb0160 0xc4cef03e
+ 0x9a9c5704 0x47032d85 0x3486b65f 0xd3ecb515
+ 0x58bd87e4 0xa408f421 0xca577e46 0xa5e921df
+ 0x5a295aa1 0xe53f571f 0xc03f9dd4 0xf1d6a0c4
+ 0x711016e1 0x300d5999 0xc321eef2 0x96669e94
+ 0x2925f8c6 0xf7096453 0x65d21402 0x6f7462ab
+ 0x826ee986 0xfd04606c 0x5554d246 0xb3d98bcf
+ 0x237e9d62 0x82224172 0x35ea607d 0x8142bbeb
+ 0xcb0edddd 0xc0a9233b 0x64be095a 0xf8b39e85
+ 0xde2d0b29 0x69e2d7a1 0x6737f156 0xf85e0d4f
+ 0xc194effb 0xed018c03 0x873a1908 0xa4fa5da8
+ 0xf6eb812f 0x04e4819c 0xd189a19b 0x94694499
+ 0xd0545215 0x371f62e8 0x2208dede 0xcb49f3ad
+ 0x192654ac 0xf36c1f49 0xeb3af0c4 0x54bfd20a
+ 0xb86f85aa 0x3d94435d 0x31a9a1ed 0xd02b0620
+ 0x0b44bc44 0xb4861a1f 0xb4605284 0x1c83e472
+ 0x055d7e70 0x717bb954 0x44d8e8bd 0xbd9af75d
+ 0x068d8de3 0xe25b73ad 0x8df23c60 0x4050ca9b
+ 0x86c000d7 0x67a9e98d 0x437bb833 0xe26ca015
+ 0xcc53371b 0xa0ce2a4c 0x83bfc220 0xc392520e
+ 0x38d7f316 0x4801955c 0xcebd086e 0x6a3b8eeb
+ 0x83d63b2a 0xcf516140 0x3f0d648a 0x58b62c57
+ 0x7ef3bffa 0xa6976628 0x8f3a5c55 0x42a3baa3
+ 0xedeb9c23 0xb477c88c 0x63d7c7bc 0x2bdd0e26
+ 0xfe7b9821 0x31fe5981 0xdb5425a8 0xc716b3c4
+ 0x0a6f1597 0x34a8a007 0x36b0614f 0x8362c856
+ 0x5e0f52b9 0x9398b4d7 0xc5c5590f 0x4af55ddb
+ 0x1ec59258 0xaf0222f6 0xcc2c7b6c 0xf0413081
+ 0x1ac15bcd 0xf0bf09a8 0xbdd23bc0 0xd75ed77f
+ 0x551c6a1e 0x5380ca48 0xf5f30a44 0x88ecff13
+ 0xa5f8130c 0x7cb60dc0 0x9eb26ba1 0x3f883068
+ 0xd954b9a3 0x95c87a30 0xefcc0c68 0xf7337080
+ 0x1eb12337 0x125c5a7f 0x25a0fee6 0x439a4a47
+ 0x02ac17fa 0x5d581e53 0xafb9d7be 0x914f9ebe
+ 0x82f5c4e8 0x7d29838a 0xe8d6c3ac 0x1192f816
+ 0xdbfa1251 0x239defaf 0x8d4a48d0 0xa48bf5a7
+ 0xae7149d2 0x9c349068 0xe7e1f6c3 0x8c28773a
+ 0xd441626e 0x81fbd796 0x3597d8c0 0xb8f39eef
+ 0xbafa40c7 0xe4e53aa9 0xb678c826 0x1ac82ff4
+ 0x9e7fa0bb 0xe8bb2559 0x064e4e96 0xb0e6f10f
+ 0x9ae0ee3d 0x7d9b0b42 0xadd1c5df 0xf095f8a0
+ 0x30f172ae 0x61caddf6 0x4ce89732 0x06099b54
+ 0x011266e7 0xbec76cea 0xf7f8d2f2 0xdfbb7f1b
+ 0xbb003bf7 0x425d3677 0xfdef38c8 0xadbe4b40
+ 0x634753c2 0xe53ae88c 0x1714dc8c 0xb788dd35
+ 0xcbaffa0e 0xffbda6ca 0xe1f91cc6 0xf92d121a
+ 0x9a260275 0x45b2c1ca 0x707a08b6 0x2a8db106
+ 0xa7df6894 0xe7189751 0x206259b0 0xde37dfea
+ 0xe468cebe 0x2476d774 0x1687f09f 0x2c06af20
+ 0x60fa742d 0x81aca355 0xef888aa1 0xc1847c88
+ 0x32036160 0x29a779b5 0x47d9e830 0xb9f83d5f
+ 0x3fa4e61b 0x038f4901 0xda804b60 0x231c9fff
+ 0x8070517b 0x2a4e6c70 0x9485f89a 0x7b57f832
+ 0x0d92d4cd 0x04aa0eba 0xdcf5c49a 0x3b3a772e
+ 0xe9df2e03 0xde378b39 0x3bdfbf09 0xa60790df
+ 0xdd8826c0 0x3de3b41d 0x68c3f5bc 0xd6f093d4
+ 0x41bd42c0 0xc68291ba 0x12f94625 0xae5ca753
+ 0x0abd919d 0xf48b4d3c 0x57c0c82a 0x5ba454cb
+ 0xce5a94ff 0xae3cab47 0x4aa33823 0x1afaffe8
+ 0x7d4136c6 0x2be28394 0xfb7602ee 0x39eb1300
+ 0xd12bae68 0xe4b7a0c0 0x94f94c06 0x048abf82
+ 0x4eb3e435 0x6fd07abf 0xd471636c 0x5c6c299f
+ 0x702a9e43 0xf239358f 0x82dc3598 0xc76a572b
+ 0x48b47811 0x1de592d8 0x258a64a6 0x9b61d81c
+ 0xf44f9c0f 0x737b3537 0xc6e0eef8 0x169efe91
+ 0x834cc9a3 0x67d42617 0xa3df949c 0x2e4601f3
+ 0x21630729 0x7bb68a4c 0x7e489647 0xfa9179b3
+ 0xf2588707 0x4fddeedb 0x7a1f612d 0xb55787d0
+ 0xafee1501 0xb3e7b9c6 0xba804c9e 0xd4ae95e0
+ 0xac524f6d 0x58cf914f 0xe057bd9d 0xf3ac907f
+ 0xb03a6d32 0x2260788c 0x4caaa555 0x984ca3f0
+ 0x2129f747 0xc8d68e34 0xa87c8179 0xa480412b
+ 0x63e15d82 0x41cbe3df 0xdf1a76d2 0xc60c1cde
+ 0x7648f22c 0xacd4fc11 0x06b9d04f 0x991c16ed
+ 0xcb417c7f 0x479c604b 0x5582e2c5 0x40f9c0e7
+ 0xc2d613be 0x136c76be 0x91e780bb 0x2063d01b
+ 0xc4e5d68c 0x6862f436 0xa56544a2 0x5d022a83
+ 0xf72335d0 0x85e89050 0x89306316 0x1f0514bb
+ 0xa5080fbb 0x2a7369e4 0xeac3af3d 0xca7607a5
+ 0x5c743d9a 0x7ffe728c 0x9e8fb02f 0xa0c5eab4
+ 0x0fab7728 0x4cb95891 0x2e79d596 0x018ccc65
+ 0x0b58f60f 0x2ca2b629 0x046ea589 0x3b30acb7
+ 0x8ba03fbc 0xf22519b6 0x8cb72f21 0x202dee89
+ 0xf9d00d21 0x2ec96d07 0x4b83c51b 0xa9fe32cc
+ 0x1d8f9267 0x1a432a84 0x6d823868 0xc7911f1d
+ 0xcb21bb51 0x3c2456f1 0x1a03390d 0x25052957
+ 0x20616d36 0x4fb85138 0xcdd69e20 0x42b7854b
+ 0x158e4668 0x6303770e 0x96e26c4d 0x71b527a5
+ 0x11319d1d 0x6d75f287 0x1dba9eaf 0xccd4fce8
+ 0xf5d9cfa1 0xe9fd8f1d 0xb6f43134 0x2d4cbbab
+ 0x1304d4a3 0x7a05977a 0xe773bf6f 0x30baa540
+ 0x61f204da 0xc5a5aaba 0xb9957e48 0x3262daf3
+ 0x78511464 0x2ab04e32 0xc89d96b6 0x14246913
+ 0x4b836fc9 0xf50f4f05 0xff2d221c 0xc14a1bbf
+ 0xe05e4591 0xf4c57aa1 0x935d6b79 0x0878ec6d
+ 0xdf4537d9 0x8a82fb47 0x6510da09 0x37a2a471
+ 0x216f3f32 0x40bac353 0xbd273df0 0x92a53e79
+ 0x54e1c315 0x494f9ef0 0xf206a246 0xb536ed59
+ 0xbd90d8ac 0xe7cd65db 0x1528ae70 0xa999b3ea
+ 0xfc3616b9 0xf26b0fb8 0x0d26f2e9 0xbf44ebf3
+ 0x690d86fd 0xbfa22568 0x760c8270 0xb51e0a14
+ 0x3f9d311e 0xac848312 0xfc101499 0x553fe2a4
+ 0x6a6b0f3e 0x6f970879 0x2be81e35 0x6144ac40
+ 0x501451ea 0x268aa441 0xc6cf124f 0x6bf90440
+ 0x08fa587c 0xc04bf04e 0x25bfb03a 0x3741f6db
+ 0x26242832 0x5bf071f0 0x8d6463b9 0x500e503c
+ 0x1a9468ce 0x5d23d18f 0xf2f8163c 0x0d7e519f
+ 0x98f0edd1 0xdd12a97d 0xba39e22d 0xc91cace2
+ 0xb2204698 0x87eaa42d 0x7968cfdc 0xe32a8876
+ 0x6799323a 0x5df22ef3 0xa674dfd7 0xb46117cb
+ 0x8294a996 0xac7d3b17 0x30c06dd6 0x3b827594
+ 0x1cd8770a 0x026d3220 0xb9efe807 0xb3d73bad
+ 0x68c78f8f 0x8f8a13ea 0x1ffb9590 0xe99cef6f
+ 0x03cd123d 0xfb1bb840 0xaff37d51 0x199b5161
+ 0x842c3d56 0xf31e3aa0 0x218ed36e 0x16bbd3f8
+ 0x733a6088 0xed5c4240 0x29ac4df9 0x65765620
+ 0x1645afd8 0xb9af1aa2 0xdad3a6b0 0xa1007b56
+ 0xe709a529 0x51a7d880 0xe58a2cd7 0x79c1915a
+ 0xf63df885 0x83e87bf9 0x33e3818e 0x3e3c0136
+ 0x59b684da 0xc03628d4 0xfc3e229f 0x67fdb30e
+ 0xe965e7c5 0xcd262320 0x171c70a9 0x85d68571
+ 0x1da4d76a 0x59e854d3 0x138428bd 0x0804e776
+ 0x948e121e 0x410cd3d9 0xdc4834a3 0xecaa7f10
+ 0x6d2993a3 0xfe17843d 0x518ec623 0x70c3f7f1
+ 0x418d09b8 0x04272bf6 0xbb6f5ac6 0x86993bb5
+ 0xae28afb6 0x1afa1ba2 0xf1231937 0x599c8856
+ 0x47eb85af 0x6cdf0c60 0xc08098ee 0xa26eaa47
+ 0xabcead3c 0x72e567a9 0x54196049 0x502ed324
+ 0x2c8773c1 0xb109a085 0xe8a25547 0xe13f68a0
+ 0x08ceb631 0x024c1b3f 0xb1701b83 0xe3602a0a
+ 0x2d9d092b 0x55f9960b 0x1eaeb777 0xcb422b9d
+ 0x15484e5b 0x3b040ae5 0x6851c37d 0xbe99e012
+ 0xdf731c32 0xf2a4ddc2 0x4f18a7b1 0xf244d571
+ 0x20a13803 0xcff77b0e 0x6a32c0ba 0x6db996c1
+ 0x83b3dba1 0x0287b69e 0xc8132123 0x1cf51166
+ 0xeae54e68 0x64c974a8 0x4d6add7b 0x58a87bc3
+ 0xa70799a9 0xd6575ef6 0x9c67be5f 0xe565e7f2
+ 0x6c602d11 0x47a2332b 0x58e3a7c0 0x4bb04592
+ 0xb899331e 0x28691b63 0x35a5b304 0x590e8684
+ 0x398bce23 0xa6e5d1a7 0xbe941045 0x8248a1c7
+ 0xe2f0f0b3 0x8fedacf9 0xe9412fa0 0xfcdd0389
+ 0x0aadca9a 0x592efaa5 0x5b32f7ca 0x59331bb2
+ 0x8c3edeb1 0x327d14ad 0xaf6ee0de 0xba015362
+ 0x331e2a77 0xd0759b70 0xd80e1d52 0x8f24b791
+ 0xa77b5abf 0x0dc0bb13 0x22d28613 0xf579ac0e
+ 0xfb8f0252 0x7073e4df 0x28a4aa05 0x7e665e37
+ 0x8459682e 0x17ce0744 0x55c15497 0xf0d506ed
+ 0xe4402e0f 0xeb964b36 0xadf8cdfa 0x51e408b2
+ 0xac8f1f75 0x21da7eab 0xd8be84a6 0xb889de7f
+ 0xa3b7ccba 0x2e92096f 0x51dea741 0x4bc8b6b7
+ 0x509d1e16 0xa51680d2 0x94570667 0xac5f5203
+ 0x916845a5 0x1e2b4162 0x39f55bf1 0x903c4c15
+ 0x0953148e 0xe0ebd00e 0xcb659fdf 0xd3574623
+ 0x4d97e3cf 0x49f4b61e 0x44007063 0x20a32437
+ 0x7c5dde33 0x8c7145df 0x9db86b04 0x19b6dc0c
+ 0x18ae6d06 0xa7e11c47 0xbf60d44b 0xf8670b5b
+ 0xe9e8e361 0x6bea92d7 0xddb5fbf3 0xfe493a6a
+ 0xe0010eca 0x472558e9 0xd3438288 0x67dff800
+ 0xdcf99ebc 0x8550e460 0xd4f74bf2 0x9cd801bf
+ 0x69a5fcc4 0x70ca0a39 0x8ca2156b 0x7c3d451f
+ 0x688ccdc8 0xcf6fe525 0xc39776e6 0x2d71269f
+ 0x9bac002d 0xdb4bd577 0xaaff71ad 0x99a880ee
+ 0xc4e77913 0x4f58dea4 0xb0d35b3c 0xb7dd5cd6
+ 0x368f88e0 0x1a153497 0xa61a686a 0xb4b29fc0
+ 0xa2605188 0xf1bc0648 0xb2ad7cbd 0xac582f14
+ 0xdfb3bac0 0x079fd5f3 0xfb336ee5 0xdbd17aac
+ 0x5c5da53d 0x89d5d69e 0x07451fc0 0x53f3ee4c
+ 0xfd1e08cc 0xcf46a702 0xe9b4e436 0x25e13d98
+ 0x809a73ab 0x07b25e94 0xd5845739 0x7eb131f1
+ 0xd3e5d83c 0x5fa46a68 0x178d2b05 0x94ee2f16
+ 0x75c6be0b 0x01716271 0x359790a8 0x754a16c4
+ 0xa26be7f5 0xd998b02e 0x25497107 0xb842f73a
+ 0x34f680a0 0xae8c305d 0x5b9b239c 0x0f2b009d
+ 0xfe440280 0x145d1126 0x6d102c8b 0x402b89b6
+ 0x9a580c40 0x91aa00a9 0xa03d8974 0x4d2a26a1
+ 0xb75b8202 0x16600764 0x211ebb2e 0x28bd93d9
+ 0x6518d2cf 0x6d5bd308 0x382c5ed7 0xa29e0aa3
+ 0xf89cf93a 0x74a0b016 0x3ca612f5 0x24064cf1
+ 0x47747a5d 0xd22975dc 0x3c696e1b 0x0e4d0a5a
+ 0x3718d1a4 0x1fcc5ea4 0xab35093b 0xb50603ea
+ 0x3650c65f 0x32858ec5 0xa87dd504 0x687c5833
+ 0x2a36de42 0x9cb6868a 0xe78d1072 0x675eb362
+ 0x64e67cfc 0xcdab05b7 0x72e23276 0xc7dd5753
+ 0x409f3b09 0xfa93587d 0x99eb8cff 0xb6c5fc09
+ 0xca99a2a2 0x7f5583e9 0x2fd55cd2 0x38a65dd0
+ 0xa16d92a2 0x286f021f 0xd71619c3 0x7d1c61f3
+ 0xf7507ce9 0x6c2a3eee 0x1053a2ae 0xb63e258e
+ 0x86f335a4 0xb5b07b32 0x0d156a38 0x53755412
+ 0x76a542d2 0x26f25a85 0xfc038aab 0xa9d96a0c
+ 0x8575d08a 0x24805c0c 0x39ea0650 0xb2edc539
+ 0x1df34734 0xf7728395 0xe17c0196 0x54079a46
+ 0x5c52fc37 0x09d2d435 0x19f28d5d 0x92dc3611
+ 0x4f7fa756 0x19a128f0 0x3e273d1d 0xff6309c9
+ 0x2c34216c 0xba4cc184 0x8873b38c 0xcd84fcdb
+ 0x3ede1e50 0x286cfb74 0xef17d548 0x01e12784
+ 0x5365dfce 0xe808116d 0x619f6117 0xaaa322f5
+ 0xc81e268a 0x8303df05 0xe251ffa3 0x86b43181
+ 0x1f6ab10b 0x60c48f73 0xf0a299df 0x311f1a35
+ 0xcf1b31d1 0x67bbee54 0x4be22f23 0xe1cbb341
+ 0xce778173 0x495c5dd4 0x2597b567 0xda1bda27
+ 0x45409289 0x5f8290bf 0x9b3d5714 0x5a732f3e
+ 0x9ec75a75 0xa062a5ae 0x1d9b6d09 0xa983c663
+ 0x0fc1863b 0xef46c113 0xaf6517a2 0x3a90caa4
+ 0xc1c36909 0x16a68595 0xd83751da 0xf965e105
+ 0xf0a2c08f 0xaf5a83cb 0xb1ef85a2 0xb994a331
+ 0xd0dc78d2 0xeb278a2a 0xe22a165d 0x3f1f999c
+ 0x5b7c2d89 0xa0a9afbd 0xc42db24e 0x061c9ef4
+ 0xbf09c71b 0x2e14198c 0x8765e181 0x6eb6884d
+ 0xa91be755 0x8d203fe3 0x80e25674 0x0b39ba38
+ 0x12cb68bc 0xf0dbdc5d 0xb95f1bab 0x7ce7663c
+ 0x227dc658 0xcd46afb7 0xaf9127c3 0x0ba73835
+ 0x613b23f0 0x599e6f37 0xb5e6463b 0x49557c88
+ 0xb104b402 0xd5276a66 0xa68ce0da 0x5d229e9f
+ 0x59292206 0xe71d18a5 0x3627be43 0xa1931f4d
+ 0x9b282f64 0xa429e37d 0x2954801c 0x78f8ff7d
+ 0x72d0997e 0xb6333f10 0x9db0ae49 0x849d6972
+ 0xf3105f52 0x42413f96 0xddb2c652 0x99802d95
+ 0xeeedf598 0xfd785866 0xd13a7b1a 0x225a59fd
+ 0x19722276 0x9a016c80 0xf4d22f4e 0x5a739fb9
+ 0xbaa3488e 0xcf913c7a 0x7ff05f65 0x0b5ecfe3
+ 0x86a7dbde 0x2de1255b 0xbadc1a92 0xe8be38c4
+ 0xf13fa2fb 0xd46894cd 0xc48b9503 0x8e715854
+ 0x3a03fe9a 0x013e5b08 0x4f46f488 0x7e27181d
+ 0xec159b58 0xc4977b80 0xcd454784 0xbbaa3742
+ 0x124eaaa3 0x66414ef9 0x1e514b4e 0xe978d0e6
+ 0x46d8c643 0xd316c855 0xb84dd9b7 0x5122465d
+ 0x34c59dac 0xa6f10643 0xd80b3949 0x07536f2d
+ 0x4fbcc30a 0x8aa8a4b6 0xdc2be5ef 0xbc3e1c78
+ 0xc25d1ebd 0x96919bed 0xdb37931b 0x6e077871
+ 0xfb2bf61b 0x9a659648 0xeccda7dc 0x79e86b23
+ 0xf1c18329 0x59830510 0xf1dcfedb 0xdc7d2b84
+ 0x41e7afd1 0xeca8021d 0x7312d4fb 0x7a45eeb5
+ 0xbffc8a1e 0x494d7c24 0xc2a84a95 0x460a0ddd
+ 0x7e44dbd5 0x2109fdbf 0x556374c2 0x616bf76c
+ 0x8b3ae7b6 0x0e2cfcd1 0x65370b6c 0xf1fbb913
+ 0x81c57609 0x4c2cadad 0xfc74a3cc 0xc9556305
+ 0x16464838 0x5ef7fb12 0xc90eb9f4 0x72353a20
+ 0x46bc1ec8 0xd3b12916 0x51c45e0e 0x061b53b2
+ 0x1a203faa 0x4e5e3054 0xbaff1858 0xb65398a0
+ 0xd5b4eca8 0x5649844c 0x2e1c6f6c 0xf828c53c
+ 0x689565ba 0x76f11b18 0x5dfd40ae 0x1d98abf6
+ 0xc9322c46 0xa22604ad 0x2740ba5b 0x99eb85be
+ 0xb52a3340 0x3fde5fb7 0x5e0e3a01 0x60f69345
+ 0x37f6fd3d 0xd084006d 0x26c3a62b 0x161b206a
+ 0x2a224c7e 0x93a45c60 0xfacdce07 0x2e7b4058
+ 0x3c79d10a 0xd7939bc8 0xbca2e30f 0xf22b6c21
+ 0xbb03c5e1 0xf30b3651 0x2fbb40f4 0x8050c8d8
+ 0x8683e045 0xe6024d08 0x81dc0b0c 0x8cd923e3
+ 0xdf8df717 0xb1f8d6f6 0xb0469246 0x79ea7958
+ 0xe3743d7d 0x83e1cad3 0xeaa7fd02 0x4d3aebc0
+ 0xba63ef51 0xd5cde1ca 0x1bdf1383 0xbb462d70
+ 0xb777376c 0x5a382db2 0xaed44fff 0x130fdd93
+ 0x1ed8bc23 0x1f3c7297 0xf3e79215 0xaabc0139
+ 0x50005a1e 0x55ca82c7 0x58778cb8 0x2e58a478
+ 0x4c4cff0b 0x3c44a21f 0x8f108d67 0x58211b23
+ 0xd233181a 0x9e46b169 0x37533a95 0x33bddfef
+ 0x777df938 0xda8a8239 0x45af2beb 0x3613b03e
+ 0xe6ae05f4 0xe33730a2 0x1e65dff3 0x7a64a0d2
+ 0x79273ca5 0x580a16b5 0xc51b39b5 0xccea7be3
+ 0x29d9caff 0xf7377acf 0x0bc27444 0xb68b6ba4
+ 0xa75ccbbb 0xdbf69f05 0xe8be0152 0x569bdc28
+ 0xb8ebe746 0x43398e79 0xa7def566 0xc99e1f1c
+ 0x3be29c87 0x6e4c4b68 0xb8a37b2e 0x84970f9c
+ 0x178d4e72 0xac72ec6f 0x0862e04d 0x85cdb66d
+ 0xd6f2feb9 0x10d299c2 0xd91a74a1 0x831697bc
+ 0xd0038240 0xbe9aed06 0xe808bb08 0x49462fac
+ 0x7efb2fbe 0x1e276eb9 0xf83b97b5 0x3754f4bb
+ 0x4449cb0c 0xcf2a2866 0x04840e6d 0x9d9b6551
+ 0x3b50f722 0xd8f7f14c 0x9ba685f6 0xcf6bed00
+ 0x41012924 0x82b27e98 0x7541d6e5 0xfa5b81cc
+ 0x91d44937 0x46d27cdd 0x91570abf 0x959e1e97
+ 0x7ee9da66 0xf82883a5 0x87afb380 0x761c818a
+ 0x180811ad 0x095d4970 0x751dee19 0x9f438246
+ 0x32a3c642 0xb3b34b98 0xab450f56 0x539a6ffd
+ 0xb339563e 0xe8808c93 0xc7ad9eef 0x0dc36b70
+ 0x1278e749 0xe83d046b 0x987de721 0x2115e00d
+ 0x7a09efd3 0x8e56c4f1 0xd5de351b 0x98eb73c2
+ 0x9becebb9 0xb18998d9 0x3ee01945 0x20eea116
+ 0x846bb55c 0xb7f624c5 0x6f7b7463 0xcbb986ad
+ 0x545c3c41 0xd754bfbd 0xfc4148ec 0x312f89dc
+ 0xe2894337 0x7867e25b 0xeb11c6df 0x9fb721ac
+ 0xa843962b 0xef242fd4 0x6fcf4b6c 0xea208951
+ 0xd521c86f 0x08f67a28 0x07209b9c 0x6ee42989
+ 0x9fdc0e42 0x3794b7db 0x038a398a 0xb339b4b8
+ 0x6d621319 0x6b9d713f 0x3537ff34 0x3fff0baf
+ 0xa5c0e302 0x8fdfa8da 0x50dede4b 0x448ed0b2
+ 0x2178bf5d 0xf7dc834b 0x9762f1aa 0x087a9b65
+ 0x7f3cc965 0xcd1c011a 0x4c630727 0x755908c4
+ 0xe33580fd 0xca010764 0x677b59b5 0xb3d182d3
+ 0x55c2d739 0x8c6f67df 0x10f6b558 0xf034ee76
+ 0x540009e2 0xe6343edf 0x95f2508e 0x2a9c22c9
+ 0x5d42e77e 0x82216d23 0x10ad67da 0x8ec77e6e
+ 0xa88a3bb0 0x4e10dc6d 0xf3fa2dcf 0x59be53e7
+ 0x25f758c1 0x2c42fef5 0xba575ddc 0x0435bf50
+ 0xd390d087 0x6e230259 0xf7e3c764 0x52c16ff4
+ 0xf2a6105a 0x31f0188f 0x83f2582c 0x2b73521d
+ 0x6b320332 0xcb7f3899 0x17f23cd3 0xab7d47d2
+ 0x535f1340 0x700ea217 0xbcf4f83b 0x16ea4470
+ 0x76a618f7 0x30216e93 0x6e80cfd7 0xcf706ae5
+ 0xd766457d 0x0ebc1377 0xdcb10949 0x2f679120
+ 0x5cc6abdf 0x65754d61 0x1a3dab69 0x8f349b8e
+ 0x95bb833b 0x5588b280 0x0f0fa923 0x21250ef5
+ 0x73bc2547 0xcd7dabe5 0x4795737a 0x82b92e90
+ 0x896f9de5 0xa18ae6d7 0xfeeffde3 0x346b0557
+ 0xdc7c068a 0x4e6eed51 0x4ff07c63 0xdd15b445
+ 0x97808676 0x304a0912 0x7fe07453 0xb9e64599
+ 0xd7a57b8d 0x7f4fd506 0x226719e4 0xe6c251e1
+ 0x7ea1ee5d 0x6051b787 0xb00b6e40 0x6babdb06
+ 0x725fc094 0xf35fc6d2 0x4e7d6c3e 0xa5a718f4
+ 0x17f63fb4 0xc39bf11c 0x808332f9 0xd2c07986
+ 0x57bf130e 0xe1f5656d 0xb52a43b6 0x9a105745
+ 0xafc22c4c 0xeb5b8a45 0x39153d0c 0x55f1b477
+ 0x4a947d5d 0x83dee3b3 0xc3d1e1c1 0xc6dc4d47
+ 0xfb93a531 0xea002909 0x95e58a9e 0xf14453ee
+ 0xe7fe7f8a 0x6eb7bf4e 0xfd74da03 0xe2a994cf
+ 0x4ec6321a 0x27c4a2d8 0xfaecde76 0xd4ba53bc
+ 0x22b291c3 0x32dad786 0xedc8172b 0x98f6cbe5
+ 0x0407f9c5 0x0e3e7894 0x68c4562a 0x2264dbe4
+ 0x938a45c1 0xb02c5428 0x31df8b31 0xefb49223
+ 0xad0abeb3 0x9ce02ca2 0x7906e6d5 0x2fbe9f55
+ 0x3dfed450 0x9a9f5854 0xa99171aa 0xdedd910f
+ 0x3e7727bd 0xbf49e35f 0xfb435c59 0x872ca461
+ 0x9693c2e5 0x4d9f7917 0xbf9b494b 0x4cb695ce
+ 0xc21c2629 0xaceab2b2 0x30a8686c 0xc09e85e3
+ 0xe3cf9904 0x39d0db4d 0x73e0c451 0x64b5d63f
+ 0xc27777a3 0x91272d8e 0x511db1dc 0x9d1a6175
+ 0x9c7e83c0 0x60037169 0xe9d248c6 0x54d04f10
+ 0x99787291 0xc3ee42f5 0xbbd26f8d 0x7fa0ab4c
+ 0x1e1e7f10 0x170b04bd 0xdf46d792 0xb17864a5
+ 0x832c1074 0x17783980 0x174f75ea 0x92980341
+ 0x7aca43ef 0x851a6e2d 0xa25dfbd7 0xf84cff03
+ 0x8a3d6563 0x8fff04c8 0x9ac359da 0x58a7b145
+ 0x57c1e741 0xbc735a98 0x171bc199 0x9f704237
+ 0x1efbde72 0x79b48991 0xa7d67d95 0xe9869769
+ 0xf6324dbe 0x17360a53 0x2131f704 0x5cf7b840
+ 0x53101e35 0xe71c8bb6 0x1c10fa64 0x28aa5883
+ 0xc41d3377 0xe6c3556a 0xa5140cf0 0x1e0224b6
+ 0xaabe86f5 0x00b520f4 0x346aa560 0x7de8aef9
+ 0x2a19e4a0 0xbe2a2772 0x93653c17 0x2ec53d8c
+ 0xd0a5ea33 0x985e6fd7 0xd300651c 0x72ce1567
+ 0x16559001 0x6e459145 0x2dafc413 0x28f514cc
+ 0x2d1b9e94 0x798b5770 0x3bd27af8 0xd5437be9
+ 0x0bc1de32 0x83f58c43 0x4a968323 0x873cf533
+ 0x44b8f501 0x8caa31dc 0x90961244 0x257e5811
+ 0xfb1c4c4d 0x7203f540 0x9d2294eb 0x533e9896
+ 0x670bf234 0xefde4d0a 0xace846e0 0x16a1421f
+ 0xe6a40e79 0x8b0f861c 0x63b8416a 0x80bc7963
+ 0x035bcc06 0x2f3a8636 0x4adeb4a8 0x527a1f98
+ 0x6d0ae365 0xd430ee93 0xa54d6e88 0x9e492859
+ 0x6d435e2a 0xf3f336df 0x8789fe48 0x04683847
+ 0xeb35012c 0x793f787f 0x1649fc98 0x4daae27a
+ 0xa899ef37 0x0aa874e3 0xe877985f 0x3877168e
+ 0xbcd9af49 0x925bd4a0 0xd7653ea4 0x1a7356c1
+ 0x53cf5cbb 0x5b3e660a 0xce923831 0x42ea11b2
+ 0xcb85c607 0xcb4fef4b 0x33ac8e92 0xc68e0ee8
+ 0xda28f304 0x34466a58 0x4e3ed659 0x433c37d5
+ 0x6e5d8f11 0x2306c1d7 0xb8562926 0x857280be
+ 0x7f6978c9 0xb6127ef8 0x848ff180 0x3f175d08
+ 0xc9ea3682 0xa7f8401b 0x073a04ee 0x75d43c6e
+ 0x193e70e8 0x9e6ee78f 0x5eda1df9 0x53e54ed1
+ 0x94a57a5c 0xd66dc923 0x121c0f87 0x637f93d0
+ 0x52b5658f 0x34ca3432 0xed262d4d 0xe7c3c8bf
+ 0x05519bb1 0xa27335b6 0x8aeba357 0xa9edeef9
+ 0x06dad515 0xcc0258ca 0x0db85a3d 0x4edbeee7
+ 0x8efdc1fa 0x53f1f91c 0x367b73bd 0xc9785288
+ 0x8046ec91 0x1270cb82 0x6a5cc22b 0x7c56f6c4
+ 0x09140a7f 0xa362df46 0x794ba791 0xc280f317
+ 0x0a8c218e 0x8fd18bc7 0x9d112770 0x4a94c675
+ 0xd08f6e86 0x200978a2 0x08bb8824 0xeda38a74
+ 0x396364ed 0x4cf3fae5 0xd1bbcc8a 0x38e68b54
+ 0x49fe9e89 0x0f372a6f 0xcb8206ec 0x686c51df
+ 0x3d21fba2 0xeed5addc 0x8cb09804 0x7b144b6c
+ 0xc31b72c5 0xb2e1fc8a 0x699440df 0xa1484706
+ 0xbfd64898 0x87c7d89f 0xdd1f06e2 0x9048531b
+ 0x3fb97a6f 0xec79fb12 0x1a81577f 0xf6fe7c86
+ 0xfa572435 0x0ed1607e 0x85823de4 0x2688f491
+ 0xcd6f5341 0x55c944e2 0xd94a5421 0x43b0eb08
+ 0xabc52c65 0x3f624e64 0xaaec22a7 0x0b6fc108
+ 0x0b5e8a54 0xb9f36d25 0xf531e230 0x18405343
+ 0xadf99cb1 0x779851bb 0x93aec541 0x8364b884
+ 0x9e14f66a 0x389f6625 0x94d43b9a 0xd9f3b002
+ 0x34b23621 0x80599e02 0x7ab4a0f0 0xb0428b5c
+ 0x8510def7 0x2871743f 0x350d0bc3 0xdbe61d9a
+ 0x787b3c6c 0x80272431 0x2ed6efd3 0xcf77c8b4
+ 0xa21f406c 0xcb82aafc 0x451b3a49 0x4bfd9ae6
+ 0x4bb86748 0x03fbd542 0x329ad4fd 0x0761e756
+ 0x07f31e88 0xe6aa2f44 0xc209345b 0x250eab3a
+ 0x2710b3b1 0x710bb403 0x921c083c 0x94e25ccb
+ 0x6b344255 0xda1501d3 0x3e0dc98c 0x2c09adda
+ 0xefbf0286 0xdec41f1c 0x3865e02d 0x211215e6
+ 0xbd3e4351 0xa3b9abc0 0x9ab908b2 0x5c345108
+ 0x0175a871 0x3611d15b 0x54733b2a 0xe57bfda6
+ 0x3b507ed3 0xcdcd1007 0x5314fc0d 0x3ef57680
+ 0x181ffd9e 0x27a7e64f 0x7a780684 0xc8fadf11
+ 0x13415b31 0xce53dcd9 0x55488687 0x858b70cc
+ 0x14067837 0x0f3f012f 0x41f0636b 0x1c8d2f52
+ 0x9dacc300 0x63b27876 0xe1c23617 0x02c57956
+ 0x85a91d2c 0x0740e7a4 0x619eab0c 0x10f254ca
+ 0x9ec8ca01 0xdfd090f4 0xbac084ac 0xa1f8168e
+ 0x7fa0e114 0x282b1cac 0x8e1283be 0x9e108b3b
+ 0xc6eb7a09 0xf8d643a3 0x3b4afa67 0x3e7f307c
+ 0xa5fb1937 0x0b00178b 0x017369f8 0xafe1fcff
+ 0x29987f54 0x965cfcd5 0x0e362047 0xd03dfc30
+ 0x9540bd32 0x2c688ee6 0x6c32d9c1 0x5935278a
+ 0x11b6c4c9 0x69202bd5 0xce48e114 0x9c5bc22e
+ 0x3e92fc71 0xb77657e2 0x9232fd3f 0x76dbd637
+ 0x1d672fbf 0x4dcb0727 0xe719838c 0x3db49bc3
+ 0x77d94683 0x6d82214f 0xdd3d51cb 0x3c23f486
+ 0x46253c8d 0x347089d1 0x7fef2912 0xee1d3cb4
+ 0x10da8cbd 0x7172b3ac 0x95c24117 0x60d1bd52
+ 0x1b2b9552 0x20ac6729 0x3614535b 0x830844db
+ 0xd9310617 0x3480f0ae 0x8e2e14df 0x4a02c210
+ 0xf5944144 0x680b5216 0x5b5ff941 0x921f8c17
+ 0x798012fa 0x43dd9855 0x725e40e7 0xb3bbac37
+ 0x44ef21ec 0x7fcbcfe0 0x0630ce23 0x3f39b5dd
+ 0xf0b3f7dc 0x51bdefd5 0xf5e0b7ec 0x3a2c2398
+ 0x00e4ad5c 0x4017fa32 0x205c567e 0x70c646e9
+ 0x81c0291b 0x33c5050c 0xeda458a6 0xa6c868fd
+ 0x1b70f270 0xb661cd4e 0x322b97a9 0x1572f522
+ 0x004792fd 0x01d23270 0x667b335f 0x5da3142d
+ 0xb7de831d 0x9736e866 0x0a70d898 0x16d1b373
+ 0x70bd1a6b 0x75170aff 0xe98d71af 0xb9829684
+ 0xedaa0924 0xbc67c151 0x155b4797 0x63c8d08c
+ 0x7811c5b5 0x84a348e8 0x6d841a8a 0xdc0e3707
+ 0x3defd447 0xac78f3ba 0x44ac7616 0x68147936
+ 0xc3f6fe4f 0xe3550b13 0x1dbb593e 0xeede24e0
+ 0x3935ec43 0xe0a30569 0x66a0223f 0x32b741c6
+ 0xd9e35135 0x77793169 0x8479a087 0xcf7433a2
+ 0x91d6967a 0x34aee2fd 0xfd68c051 0x6375cafa
+ 0xe5d7a0bf 0x1a3cdf26 0x4f0765b6 0x89dd8de2
+ 0x0ebfa813 0x8a5b91c0 0xd698549a 0x4ee2cfb4
+ 0xc2dbd4a5 0xd0e2ab9b 0x9765a4e8 0x880f32ac
+ 0xf0f30fcd 0x74021c54 0xa1d6944f 0x25270ba8
+ 0x75dd0748 0x770e7b69 0xd6dafdd2 0x0254ea84
+ 0x427eb60e 0xf5a422b1 0x53fbc0e3 0xb470027c
+ 0x3ff09ede 0xbecc9100 0xba2d3ea8 0x86295a6c
+ 0xf3a8690e 0x503f198e 0x7498daba 0x4c04fd03
+ 0xcebcfdcb 0xec671b62 0xeb98f36e 0xcf3d095d
+ 0xfc627be1 0x7a6aa482 0x4961f814 0x82a9df39
+ 0xeab68128 0xe618105e 0x603e4e80 0xd42305a1
+ 0x2ab596b0 0x66ef4bf8 0xbe2d8a31 0x7571fd10
+ 0x6ad34e73 0x77c92e69 0xf70829d0 0x243bca33
+ 0xa41899b2 0xad3847d1 0x326085c9 0x1e32f76a
+ 0xe5939032 0x2ef87117 0xedd0598b 0x0f5b0ab6
+ 0x843d972e 0xbdedfd02 0xf6f281d2 0x806f8619
+ 0xc0d4e6f7 0xc7c752e2 0x4cb18e8c 0xa3109bc7
+ 0xb3c9d39f 0x5fed1b89 0xf56bf4a6 0x1ef9ad37
+ 0xb6d27d00 0xd62e0e2f 0x427c1f76 0x64b708e3
+ 0xe61b8094 0x58c140cf 0xc9ed8bfd 0x549d8321
+ 0x887f495a 0x9b92965e 0x19dd4f23 0x48faa916
+ 0x536988d2 0x5c41f555 0x78dd7a98 0x52c98af1
+ 0xaf1aa0a7 0x472d9c18 0x5072ec30 0xcb8d8c2a
+ 0x20ca2831 0x54741df0 0xde485e64 0xde719ed4
+ 0xd0e4fa14 0xdbe68e08 0xc4b52f6b 0x7c478181
+ 0x5ce15685 0x20bf9757 0x01ccdc90 0x3f59a540
+ 0x09dfd538 0x96d5313a 0x11b8a5b5 0xb185b4a6
+ 0x80b8ebac 0xdcbf7885 0x1f78d8ed 0x3f845528
+ 0x8f10047b 0x31048ec4 0x08b16c82 0xef8212ce
+ 0xba7e12b6 0xbb27b4dd 0x880c366b 0xbb9013e9
+ 0x680e9afc 0x639c8dd4 0x67a899a9 0x95d99658
+ 0xcdcd0ef6 0xd35bf9ae 0x73dc39ff 0x1159cdd6
+ 0x820e821a 0x233b30ac 0xa5355178 0x508a060b
+ 0x70f8eb69 0x7dd6cd6a 0xc9babdac 0x952886c9
+ 0x20a4d780 0xcafe7a7d 0x4a564d22 0x23c88386
+ 0x95dcd3ba 0x57e703c6 0xbafaa61d 0xd515f701
+ 0x1634dc08 0xaf721b5c 0xdb4b52e4 0xcb54c7f2
+ 0x1bdf64d1 0x7e798a76 0x20066741 0x1ecacec1
+ 0x2d5be224 0x8eec039c 0xa2adcff2 0x6abe342a
+ 0x15929ccb 0xde4a5a29 0xb0ef2733 0x51e6e38e
+ 0x88f7ded5 0x9a7c3d12 0x0102cd55 0x1e5fa60d
+ 0x43e10b70 0x17c67005 0x6d60158b 0x03ebc351
+ 0xc1877454 0x99486475 0x68e31d63 0x4ef41164
+ 0x1250792d 0xe2dbb2b7 0x3f041adf 0xc00f1ca1
+ 0x0bf6b065 0x581d1496 0x6babf291 0x0cab401a
+ 0x37305a02 0xd8b025f0 0xd9aad863 0x33378c27
+ 0xfce64bab 0xb944fc9a 0x421cb71a 0xeaaf1a0e
+ 0x08c62ae4 0x4be73168 0x95907070 0x7b40f3dd
+ 0xa0273b1e 0xe4995d27 0xb6aa456f 0xbbefad85
+ 0xdf650ed9 0xcdfde8ec 0x8f3ba9b3 0x6c8aaa45
+ 0xbb938c57 0x2d26fcf3 0x1fc85e00 0x30338e08
+ 0xe3502aad 0xfe0528ba 0x25c888e4 0x136224fd
+ 0xe3fb8d06 0x8b521420 0x8d4849b0 0x128a5579
+ 0x485bd52d 0x46ced7d5 0xe922bb2d 0x76d52253
+ 0x976436c0 0xc3fa64e6 0xf900fa97 0x1ef8db2d
+ 0x79a8b6e9 0x1ff2b058 0x61dd59cb 0x76eaffd9
+ 0xdaad829b 0xaf929bc6 0x7f1461f0 0x28541e57
+ 0xdb2223ca 0xb5a41af3 0x963dfe3c 0xf332afee
+ 0xf01270c1 0x37fff0d5 0xa8db736d 0xbf6b8ace
+ 0x060b9827 0xe04fa359 0x8483405b 0x526756af
+ 0xf93bd116 0xaaf82ddc 0x3d800e46 0xa462a35c
+ 0xb62236e3 0xab42ba34 0xb662603a 0xe8a24ea0
+ 0x4b13879b 0x0271f215 0xb7227ebc 0x1c85b75a
+ 0x06a7f989 0x5a58a071 0xf027ba62 0x3940d149
+ 0x174c162e 0x1710f899 0xe50684e0 0xe58982ee
+ 0xcb3b9fa5 0x545dd73d 0x42a33d21 0x14ce3ed8
+ 0x151fc3e7 0x6fa96a65 0x60131642 0x20115648
+ 0xe2fe3663 0x618bb9ab 0x9b2fe08c 0xce906711
+ 0xb9fbe11b 0xce79c0a2 0x76320db5 0xd2b8956d
+ 0x3c8fba1b 0xda7d5cfd 0x79930fde 0x7b1eaab3
+ 0xe4190098 0xe46cc648 0x796557fa 0xe61f5c5d
+ 0x85341adf 0xa01cc486 0x1460f8f8 0x0de8488c
+ 0xc3575498 0xdaba60b1 0x6e00e9de 0x8de1e277
+ 0xd7ef67e0 0x6f209a77 0x582ec810 0x4636f6cc
+ 0x6bd9e60d 0x64ea05fc 0x580f9f7a 0x0f18218c
+ 0x240f624a 0x0afc252f 0xb025c839 0xe6a5afc3
+ 0xd5e32234 0xf30ced0c 0x90f032cf 0xb6fd59b8
+ 0x2ef1aeb8 0xdd5d3fe6 0xa18a909d 0x65c3e9e1
+ 0xe821d2f9 0x957146ce 0x86ea8c2e 0xea79a59c
+ 0x91bbff8c 0x50efab7f 0x4a8c0919 0x11faafd8
+ 0x3f3463b9 0x80e0e50a 0xdbcc8485 0x3f7c058b
+ 0x4cfa4e1f 0xff8867ed 0x6bf2f6e9 0xa61daaaf
+ 0xb718eeec 0xefe4f834 0xd0c4727d 0xec787df0
+ 0x85bfe1f5 0x7329affc 0xf4c0ed95 0xa6a8b495
+ 0xb3bd1c06 0xd38e0a09 0x26e3f747 0x6bd5ceb3
+ 0x5eef12c8 0xd1011d66 0xb1dd692a 0xba1294c7
+ 0xf7ddcb0f 0x4dbd2861 0xb29db408 0x051fb421
+ 0xa4fd5f8c 0x1ad5a3d0 0xd95aee42 0xd52203b8
+ 0xc4e76978 0x5780ee25 0xc38f6280 0x0e4bdb05
+ 0xdeaf0dc3 0xcada9dc0 0xf7dd201b 0xffe07b67
+ 0xe486f4d5 0x72a0b32a 0x518c1122 0xc240db35
+ 0x1d7b5a09 0xa26636f5 0xe1b716fb 0x9158d0d9
+ 0xfbe3b60e 0xd37c00dc 0x551615da 0xc7fde3ed
+ 0xac94b6ae 0xcc87d6a7 0x0d010d6c 0xe1bc4072
+ 0x8d8a4caf 0xf4381342 0xe3efc8dd 0x64be88ba
+ 0x0eac9658 0xd10e87c6 0x8dc223f5 0xbbadd543
+ 0x3ad28376 0xba68d553 0xbce5620d 0x1adc3d5e
+ 0xa64d27fe 0x65086819 0x80b82c62 0xff91b5cd
+ 0x97cadf1a 0x2cb0d45c 0xa73587ca 0xdaffecee
+ 0x299e3888 0xb4c116f2 0xd7aee299 0x9c33d177
+ 0x8af686c9 0xba6b45b6 0x47fe7688 0x1e49d908
+ 0x721370a8 0x1220ffc9 0xeb62dcbd 0x4255a463
+ 0x13ef302e 0x619bc137 0xce369fdf 0x3a1ded2d
+ 0x88dc709e 0x4b10b186 0x582eba1a 0xb508101b
+ 0x6e827983 0xb25e5755 0x9f29bac5 0xdd946461
+ 0xa6b87255 0x92471f76 0xac61af93 0x670e9ae7
+ 0xb3cc278f 0xb674f114 0x5616b751 0x527869b2
+ 0xb6847ec3 0x7c94f508 0xdedd2e51 0xe322e023
+ 0x3ef45d78 0xc95848ce 0xd53c243c 0x645d8456
+ 0x1c510cde 0x243ad2e5 0xfafac2e4 0xc23ad8fc
+ 0x481fe577 0x1f73fdc8 0x4cf5388c 0x8afb0c47
+ 0xe39a7e0e 0x439e32a0 0x1a3af126 0xdd0ddbcf
+ 0x56efe7bb 0xa4526c50 0x1f1e8d7c 0x6fff2758
+ 0xa9cfc7c8 0x9aed3088 0x1419791f 0xc41006c6
+ 0xe665ffb4 0xe0cfc001 0x5ac279f7 0x8dda44e8
+ 0x6ba63b5d 0x11cd5e85 0x87b35603 0xfcb57486
+ 0x64df1bbe 0x1df9ceb9 0xc2565187 0xbb6b4730
+ 0xa60ba743 0xb50ca534 0x224eecf0 0x8acbd1e3
+ 0xff2a22f6 0x00b94b20 0xb2bb1824 0xe3af6f67
+ 0x78db1d5c 0xa3dfaa5e 0xb23a1a59 0x234628d1
+ 0x46a0b6b1 0x6d7b354d 0xd7f14b18 0x492cdb7a
+ 0x4b0e5fb1 0x3b210deb 0x82ba85b1 0xe5af7727
+ 0xde5e2892 0xf4ba96b6 0x1011fde0 0xb96e65b0
+ 0xb3f72d55 0x4388cb56 0x09f8801d 0x534eecde
+ 0xa30f33cf 0x2454f5c5 0x5f32f1a1 0xd1d008eb
+ 0xadb25f06 0xea32375f 0x71734ccd 0xc989e49c
+ 0xb45f560d 0x49ed0d08 0x5ccf1394 0x5115dd15
+ 0x46876215 0x20e6e84f 0xd5deaeea 0xe559d4f2
+ 0x1e1c44d0 0x9f582603 0xad90b17d 0xf16c26c9
+ 0x7f0708f0 0xfeb0b9e1 0xb853f20e 0x16f3ff5c
+ 0x1789f6ba 0x236bb3aa 0x906f2ccb 0x255c8814
+ 0x9d762cb2 0x2846e2b6 0xa34f8522 0x2502c2fe
+ 0x698ad3e5 0x09c88175 0xdbee86b6 0x264167d1
+ 0xcce5d399 0x78a3f959 0xa0a515c8 0x36c2db5c
+ 0x5dec037f 0x56a558ad 0xa17a21b5 0xca0296a3
+ 0x963a70b4 0x2733e44e 0x4f979549 0xf3738ba0
+ 0x60aff2d1 0xf66ed176 0x8f658d9b 0x1e83fc2b
+ 0x28a3d57c 0x1d50c6d7 0x434f286e 0xbbd6f950
+ 0x5bfebf75 0xe366392a 0xbd328d7b 0xf10a2ad9
+ 0x59504439 0xac3f2cb8 0x28cd3fd9 0x3776a6d9
+ 0x5ac2b26e 0x25171f43 0xfb20e0e7 0xda4565f0
+ 0xcf0cd438 0xf54f1ff9 0x33322457 0xaa368462
+ 0x540acfd9 0x331fff32 0x8b66b3b4 0x19a74ca7
+ 0xe3037b68 0xa4ddcf1a 0x48dfd4e6 0xe0302745
+ 0x21522f0a 0x3b9f1cf8 0x2f7da1d2 0xd1e02b1a
+ 0x89d834ef 0xc03b327c 0xa32b106f 0x2bfb3409
+ 0x7f001db1 0x9ad9a334 0x0f2e5ed3 0x1063a583
+ 0x6cb009d2 0xe9670521 0xdfcab184 0xd02add2b
+ 0xfa7721f2 0x6e772878 0x11c5f0cd 0x1d228ded
+ 0x54d84a8b 0xffbb136f 0x489a4619 0xf51cd9d7
+ 0x6618cdff 0x76685892 0xfebcf111 0x02ee0a86
+ 0x77ffdd9e 0xd36303bf 0xed4a8619 0x0160eb27
+ 0x0b7ae017 0x7e3919a8 0x1b0c65ca 0xc8c7ef9a
+ 0xdd593e48 0x48091b98 0x5ad15379 0xf9f54186
+ 0x8c064d3f 0x09f23b45 0xb1bf1f50 0xdefe3c11
+ 0x3d9c3506 0x328acb8a 0xc0efd1cc 0x7f3e472c
+ 0xbd0855c8 0xc32d33ea 0xb2aedfad 0x5f9c5e3f
+ 0x39fab7b6 0x3d58511c 0x74dce606 0xca5975f2
+ 0x7adc328c 0xa7f2cf36 0x9084c11d 0xa25fccfd
+ 0x0f5591e9 0x7c912a6d 0x6bcd5638 0x74174d51
+ 0xe4f38864 0x545a4f72 0xad79bce7 0x68f23ea3
+ 0x2c29455e 0xb2dce3e7 0xf75922bd 0x62d9d813
+ 0x2ea9daf9 0x9544ba17 0x1036f50d 0x003d0734
+ 0x6de2f91d 0x12de6d4e 0xbe6f77c9 0xcdc6f7e0
+ 0xb7bc6908 0x8102989a 0x81b1ecc4 0xbec4c06b
+ 0x57ae207e 0x0d9bf8ed 0xf82fd233 0x626e99b4
+ 0x775ba43d 0xfdbe57b3 0x9e13e0ae 0x8f9e71cb
+ 0x22e5b181 0x879a9646 0xa59f02b6 0x315bea64
+ 0xfc2d998e 0xf3ee358a 0x465f0469 0xae5e30d1
+ 0x8667c5ea 0x4d3797f1 0xdd9119c1 0x8a5c7526
+ 0xefdbe49b 0xcba8bf75 0x31c56598 0xb089371a
+ 0x50b88730 0x8b04e9ea 0xbe766234 0xb589b311
+ 0xac86a2dd 0xf3cab9d4 0x8392e86e 0x459f4c2d
+ 0xdc6e9e42 0x38fc7db6 0xbe1c3f55 0x87827bb1
+ 0xd3fb2dae 0x29f65cb9 0x288ee868 0x44ef835c
+ 0x5412f96d 0x8db90a63 0x619eb896 0x819145d0
+ 0x4c334fcc 0xb28d29d1 0x71198c8e 0xcb7a1ec7
+ 0x67d911c8 0x83e5b451 0x18dc1483 0x74d2d7fc
+ 0xfebe405b 0x1b1865d7 0x552adee0 0x62e24345
+ 0x4c772a36 0x047bfaa5 0x848961c3 0x86f2f24c
+ 0x3f5db1e9 0x48c4d9c7 0xd7902c02 0xa0dfb8c6
+ 0xb16ca129 0x7df0a350 0x58e2570b 0x6c0aefa5
+ 0x2c8a35be 0xd155ab73 0x0801d1ad 0x913ac469
+ 0xc6398211 0xa44aabec 0x74f991fd 0x122423d0
+ 0xd1d7f77d 0xeccf8eff 0x59ecfdbb 0xb85cd73f
+ 0xbd10ba8d 0x0c9880b2 0xcabcba47 0xc11e71ef
+ 0xcb57870b 0x3a29030f 0x0bff4c01 0xf2629315
+ 0x6686b1e9 0xd2b50835 0xec24eb6c 0xb23c7e88
+ 0x045a35c1 0x5fb62127 0x2dcc31f7 0x5c47cd7b
+ 0x1059b75c 0xe2d6d12d 0x6bc8f0da 0x30ade89c
+ 0x35b06222 0xd13a1347 0xacbb2f8a 0xb7fc8acb
+ 0x2edd849b 0x8d74157a 0x562d8d4d 0xa393948b
+ 0xb89b904c 0x418eee39 0xd42898ae 0x630e1cda
+ 0x96c56104 0xdd16c830 0x89ae9ec2 0x1e1cadb2
+ 0xb8ea73b8 0xabaa7ad5 0x654ab956 0x17b2bb13
+ 0xb064652a 0xbf9897cf 0xaabb9b9e 0x38a0654f
+ 0x8bc378bf 0x11559864 0xd193ee51 0x3883fef8
+ 0x461d458b 0xc35b1b22 0x570015df 0x2b18a043
+ 0xab4aee83 0x4e0bff9e 0x323dafd6 0x8bec69ed
+ 0x1846d886 0x0ed944bd 0x9a2b4a60 0x132616d5
+ 0x86f3c871 0x76ee6765 0xe971f2cc 0xabaac761
+ 0x59bf478b 0x0d83ee79 0x0883a1e1 0xbb4660cd
+ 0x24c77bd5 0xed55f531 0xfaea8dbc 0xdfecc13d
+ 0x285e5bef 0x7b14cc12 0x68cb6d5c 0x07b7a0a8
+ 0xaf3d6e45 0xbceb6223 0x1eeaa87b 0xbf0f9998
+ 0xf7582f97 0xce1d2f25 0xd8509595 0x1f6729ba
+ 0xe3fccc36 0x7ca2d51b 0xa92c327c 0xe1b49064
+ 0xe3cc87e9 0x82c05001 0x9d855812 0x0a7cda02
+ 0x65017632 0x1b226e96 0xd4ffaa0a 0xc5a5e42e
+ 0x04ba35e1 0x39f6606d 0x23668a62 0x9f670515
+ 0x4fa60d9a 0xc8bd3911 0xd95d20c8 0xfe483aa8
+ 0xbad0ea2f 0x3a443ce8 0x3857d9f0 0x4516097c
+ 0x98d96ee3 0x11529725 0x85c93890 0x47461181
+ 0xf6fbe21d 0xda939a92 0x1bf3d3d2 0xf5385362
+ 0x31937784 0xa7b86d9e 0x42bbf80b 0xaa3c390a
+ 0xf4b7d5bf 0xb1c43ae7 0x59efcce8 0xb69885db
+ 0x2a6ff378 0x20f6ecb3 0x5cd55e2b 0xcb345f54
+ 0x6ff1d8c8 0xa6766f2a 0x80b3f21e 0xb69aa081
+ 0x7b685d4b 0x2b84356d 0xc8f7c968 0xdd9582cb
+ 0x2ae3329d 0x2884e0a1 0xcfba6d58 0xe80ffa06
+ 0x1d9e8104 0xb1cb5fdd 0xdff34ce8 0xa3d46b2d
+ 0x229a693e 0x02c1ffad 0xb52810d7 0x94a5f91f
+ 0xb2410f87 0xb827abdf 0xd608ca6f 0xb1091e4d
+ 0x75b7eb78 0xc40d51ea 0xe8c64259 0xa2b38060
+ 0xd3284d20 0xc7bcf1f7 0x380b300b 0x469fd0aa
+ 0x39f0e4a8 0x58b56c61 0xe42a3c3e 0x95afbad6
+ 0xd989f15c 0x12f9d899 0xaa41188b 0x5ef0a7dd
+ 0xe50d22a6 0xceda0b9e 0x53e0fd62 0x4f974e41
+ 0x78684102 0x743bc6aa 0x973a47ff 0x48a09dfd
+ 0x815546e1 0x346ef0a9 0xd8b9f0d9 0x1f990a29
+ 0x1cb7cda3 0x93b243b5 0x081298b4 0x8b1c0520
+ 0x6740563f 0xad1275bb 0x82aeb54c 0xcedb023e
+ 0xfa9275e3 0xac1918df 0x395ffc44 0xe52017e0
+ 0x9b88236b 0x47229fe7 0xafe00678 0x1b506855
+ 0x6cd90e68 0xee6332a0 0x806910a8 0xf42b4856
+ 0x99ba5340 0x8a0f68d6 0x7a7442e0 0x01f543b9
+ 0xd3ae2a29 0x82006e7f 0x84f3c581 0x945c25c6
+ 0x08ebe7a0 0xa544b292 0xa828419b 0x17363dec
+ 0xf772131d 0x59edff26 0xd05d94c9 0x86f00bb9
+ 0x45ce081c 0x25916c63 0xbc881029 0xa52c11da
+ 0x846b2a91 0x5802a2cf 0x4a8de481 0x2b418464
+ 0xfc6c04ee 0xf23c0f6c 0xc470aa16 0x5f168faa
+ 0x544e44ed 0x66e02d1d 0xe4316d32 0x5faa049a
+ 0xa3b599c1 0x1712d5c0 0x22c049f6 0x0dcf6498
+ 0x59d976ff 0x5729d27b 0x20667d36 0x5e94eb1b
+ 0xfe9f912a 0x5b31c8d7 0x96754466 0xb5b7387f
+ 0xe6557f48 0xc095086b 0x1876dd38 0xbe3bd213
+ 0x2a956ef8 0x59cde6dc 0x79ef6f14 0xd479ac9c
+ 0x4fb12aa6 0x1773ac27 0xc99a79b7 0x88319c2e
+ 0x017171b0 0xe9322144 0x89ad5ffa 0x66bce095
+ 0xe7feea4a 0x67457e06 0x4c85a956 0x91eeaf30
+ 0x8e9a3fb3 0x04029d73 0x831daebb 0x15105d48
+ 0x855d539b 0xe041b09a 0x64d2d1bb 0x3c3249f1
+ 0x9e601a46 0xf6c06195 0x9304a550 0x07ba1e54
+ 0xe0e41cbc 0x686ba561 0x92a1174e 0x8dae719e
+ 0x7363732a 0xe31c5716 0x75ea27ac 0x20dce24b
+ 0xcdd0cb3a 0x7510e7dc 0x6b438775 0x7dc88707
+ 0x097883a8 0x9a0653ba 0xa5b58b39 0xb4dffe70
+ 0x3dbf5354 0x1296bec8 0x6afea6f7 0x5a396962
+ 0x44c59723 0x00197649 0x88476700 0xcebb0206
+ 0xc6cb5364 0x01ab08a9 0xefc19a10 0x98b3dbb7
+ 0x79290d1f 0xeeb1cee1 0x155d3eb0 0x0d1ad333
+ 0xbecbaf44 0xcb494c9e 0xfaba7d92 0x8f0a38d2
+ 0xd71aadd7 0x96898e98 0xfae22e00 0x5cdf8ce9
+ 0xec12989e 0xc0e235d6 0x35ffad3b 0x0607e758
+ 0x146c87c7 0xd441c093 0x94ba23ed 0xf9029146
+ 0xb2a55678 0xd9575a72 0xc8d977ea 0x3e4ee1e9
+ 0x929514f0 0x947b0b81 0x7659a020 0x1e889477
+ 0x47fc8fc3 0xba26006b 0x11ba9b5a 0x296ee7c0
+ 0xb9625907 0xce20ae26 0xab5c4ffd 0xc8fb7bdb
+ 0x09b94a92 0x96955d13 0xcc165a1c 0x59774853
+ 0xd033d21c 0xfcb748fe 0xcca14a49 0xf7c3bddb
+ 0x1699d641 0x5a7df26f 0x800db96f 0x3f06e996
+ 0x32cb5eec 0xcfed09a3 0x590f6e50 0xe0de426a
+ 0x8818035d 0x3e864da1 0x9915f5a5 0x0c9f0e01
+ 0xc039e81e 0xbd41702e 0xedeb91f3 0x58bb813e
+ 0x58d88d4f 0xcc9aebb9 0x1f16b1f6 0x20289a23
+ 0xfc74f52d 0xf76141fe 0xefeea38e 0xb264ab37
+ 0x5761d199 0xa615c301 0x854a2586 0xece5890d
+ 0x25687347 0xdd5b00cf 0xdc380b09 0x3679f957
+ 0x8d28f162 0x8d192079 0xc5018575 0x84e7dc2b
+ 0x6801ba12 0x0ff46ee9 0x05977f7a 0x2804d141
+ 0x2d66aef1 0x12b96d1e 0xbd0fee36 0xeb61eb3e
+ 0x3bfadea6 0xecc451ad 0x6a7c496d 0xa9df4093
+ 0xba53eb3b 0x6fc140f0 0xa10e0b45 0x7177ac62
+ 0xcf5fb075 0xf15384d3 0xe76956d2 0x6bfe3cd0
+ 0xd4c176b1 0x7b83caa4 0x6fcb1c28 0x7013d243
+ 0x8303b45f 0x77217eec 0x5f04b4cf 0xed77af47
+ 0x4ee8c05b 0x84d50949 0x4af30115 0x6536adfa
+ 0xe3460043 0x42d089f5 0x6e7b3b0a 0xa33f554f
+ 0xb2f9a7f4 0x8b1ee0d4 0x75b77494 0x5084f874
+ 0xd12a5561 0xe22cc792 0xc5b37ca4 0xd3325f7f
+ 0x941da42e 0x5f3faf13 0x4d328409 0x2efe01d3
+ 0x54742b4e 0xd07c956a 0x57f65956 0x6c1af66e
+ 0xe0a2f710 0xe90fc5fb 0xaabb9038 0xb1b78f53
+ 0x2235d7ef 0x5421ca3d 0xc2d423e7 0x0d44fe4f
+ 0xcb104bc7 0xc68e796d 0xc9f45636 0xd019c30a
+ 0x14bdaf28 0x8c1a1651 0x90ab3551 0x9f19da7d
+ 0x9b987a22 0x8d49388b 0x89c83ae3 0xafa42208
+ 0xf29b54a3 0x83bc5cbe 0xe250c960 0x2c902a21
+ 0x057042d0 0x6cfce181 0xca9a5abc 0x43739c7b
+ 0xdcaa30b7 0x658f0a5f 0xfc3a3524 0xf1d40104
+ 0x611b0e9b 0xf50e2887 0x0fd173f1 0xa0e9597e
+ 0xd70ca0e4 0x66657238 0x4c6b155d 0x46021c60
+ 0xf6abb98a 0x8b8eca83 0x63a6b1c6 0x000761db
+ 0xb9280399 0x68593f55 0x7515caff 0x2c50e58e
+ 0x512cab6d 0xebe2dd7d 0xe627fe0f 0x1c85dc4b
+ 0x867a14e9 0x5052f8d0 0x8c4bfb3b 0x77047e84
+ 0x650c4f5a 0x8f28e68f 0xe50223bb 0xd38f07d5
+ 0x1924055d 0x0a89a801 0x9ebb9896 0xd4c7c7e0
+ 0x6edea478 0x74ec0a2a 0x4d70ace1 0x1f57c098
+ 0x9acae446 0x2d695902 0x0b7b67bb 0xf2c1cd8d
+ 0x9d999240 0x02916fc1 0x9eb6f334 0xe7b45cc4
+ 0x1155b93b 0x8a101032 0x71a1014b 0xf01bb4e8
+ 0x04a38871 0x57d7d947 0xa7b9d28b 0x3f7969d0
+ 0x3aca24a4 0xf9d4c499 0x2220fe8b 0x94b1f831
+ 0x42f919fa 0x68bed324 0x15a50bdc 0xe29db9d4
+ 0x7fb44468 0x3d82d179 0x4736a849 0xc04dbc09
+ 0x797c4eba 0x7a6e09e6 0x3704f556 0xe0200cd1
+ 0xc52dd55a 0xc80971f0 0xe6c01cfb 0x8057e7bb
+ 0xd36b505e 0x85d81001 0x569f284b 0xf44d32cd
+ 0x8b6860e5 0xa65bcde5 0xe55c743a 0x9a8a1caa
+ 0xd3f91d2b 0xb27506e9 0x82316358 0xbe864575
+ 0x809bb916 0xc978bc53 0x4725378d 0x30e50762
+ 0x67586f24 0x01a9fcb6 0xe9f6c5b9 0x19719844
+ 0x9fb9fad4 0x08c4b450 0x4a45b9ac 0x3048f27b
+ 0x077c4a30 0x4aea9304 0x3b2a2216 0x3cf58019
+ 0x84f1cf20 0xca0eb68e 0x50775bc5 0xd1f7aea7
+ 0x8ae46127 0x54edb313 0xf845afb0 0x61f398d3
+ 0xf536b987 0x0b9e6912 0xdb2f264e 0x78e46fdb
+ 0x41fbda89 0xf03fe81f 0x187c1ef1 0x17bc721b
+ 0x41cf8c8b 0x9b011fb1 0x1aeb5155 0xd0a0fefa
+ 0x6751ef85 0xd5d88dc7 0x10825111 0xfc087529
+ 0xe33dffad 0x6e82678f 0x50cb45b1 0xd5cc582b
+ 0x5df4b1f5 0x6f4f0276 0xcd6aecb6 0x80c6602b
+ 0xaf862a20 0x882518ae 0x69fbcf16 0xf3e38188
+ 0xa7b35576 0xe40eb7b7 0x879a2088 0x55944f95
+ 0xcf7672f2 0xc4541a5c 0x6e09ad3a 0x38075dfd
+ 0x2ed6c693 0xc4fa0139 0x671c3821 0x038d5dc5
+ 0x09793c52 0xb6a931be 0x453d79e9 0xecd6cd11
+ 0x960f0fae 0x7649359f 0x19766e8f 0x4a7fb57d
+ 0xb18746cb 0x8c3f492e 0xb91a220a 0xaa889e36
+ 0x246cb452 0xa7f61e5f 0xf9fb9e07 0xef7c0d56
+ 0x4f8d0024 0x082dd2a2 0xa8c091f1 0xd7466121
+ 0x10c79d8a 0x3300740b 0x6d1f3780 0xf60f731c
+ 0xf2d58803 0x6a80b882 0xd5d9c4fa 0x3dfc9be7
+ 0x9dfe48fb 0xed7e7e88 0xcdd5dbdc 0x485b67d4
+ 0xd19f715f 0xce7d6a99 0xed483597 0x2f0eb52b
+ 0x7546c358 0x54f1cbcc 0x5df93879 0x79693708
+ 0x8eba40f1 0x8f705e5c 0xd1154fc1 0x9f99ac65
+ 0xb92d1d22 0x07c98e9a 0x21a14255 0x78c68738
+ 0x7cd994da 0xbad78e73 0x463d5997 0x83a71109
+ 0x53bb8986 0x15bd8dc5 0x7e1f1998 0xa8c5391b
+ 0xc5abc962 0xd9a0bd54 0x48f64292 0x77410557
+ 0x09db7193 0xf835577c 0xfd0f32fd 0x578d5fe4
+ 0x198232a3 0x5e332aa4 0xce6b2647 0xeabc740e
+ 0xf8e545ba 0xcd7d6c42 0x2776f043 0x3f0486c9
+ 0xeea7d9b9 0x6773671d 0x08043447 0x290896a7
+ 0xe5d05e2d 0x1701dd00 0xe2ac31a2 0xc7a96166
+ 0xaff6d0c2 0xfd73837f 0x0bd95906 0xdbbbd03e
+ 0x93406214 0x8e4827ef 0x67c7af4b 0x2e83eefb
+ 0xac7857ea 0x6a3705ba 0x0e6694ad 0x5b7cf57b
+ 0x12b302ab 0xe302c65a 0xb86a70e4 0x558c3c3b
+ 0x516b9e0e 0x14a404ac 0xc2125bf6 0x7b004a59
+ 0x65781699 0xb455f1c2 0x1f1f7b0c 0x800225a8
+ 0x382ec77a 0x31f3d8ee 0xeedbcabd 0x6b95ea73
+ 0x7a3a3f50 0x49b810d1 0xb682073c 0x36971f10
+ 0x10eec5e1 0x9b9354cf 0x220dc62a 0x0f901007
+ 0x204baa07 0x8b028c1e 0x7e4fff42 0x19123ff4
+ 0x0219d4f0 0xfd355ae0 0x82e8c025 0x04daa19d
+ 0x1d65eb84 0x282aa6ae 0x40dbee56 0x906b6b46
+ 0xe1112280 0x031a9dcb 0x61dd8e8c 0x42504f64
+ 0x1cb256d9 0x569448f3 0x9ed09cc2 0x52cffe5d
+ 0xa0d21264 0xad756a66 0x42743067 0xbc6a7470
+ 0x3950b8e6 0x62a4ec00 0x1743a299 0x659adbca
+ 0x7206b852 0x156b6cf0 0xa54cca90 0xd4f789b8
+ 0x177e7e86 0x6b19f13e 0xd7fadfd1 0x68ef1abc
+ 0xbad802eb 0x3802a623 0x43b08974 0x23bc8939
+ 0x8ee2bb67 0xbdc11c8e 0x2efbf4e3 0xc550bd4f
+ 0xfb7e6923 0x9fd78d20 0x0238fc36 0xa733dd00
+ 0x1ae532d2 0x83f4e497 0xca0f4cdd 0x3b204df2
+ 0x0d5084f2 0x15da2f6a 0x904b1dc3 0x7418ce5e
+ 0x28258fee 0xbc0292b7 0xf2002944 0x73720375
+ 0x2486734c 0x1883172b 0xe1dda0b6 0x8e1ead82
+ 0x18e47d65 0x9b8178a1 0x0251a0af 0x5a8577c3
+ 0x1c5ce32f 0x0220633e 0xc90c9de8 0xe63cc5b7
+ 0x7f334c91 0xfe0e70da 0x0af05ce6 0x8506f70d
+ 0x52ee885c 0x1c723bd5 0xc547fa0b 0xeaf183de
+ 0x5bf6e086 0x436d2b8e 0x3d7ad97e 0x9b766a06
+ 0x021e0e79 0xdd17bae6 0x04607ea8 0xb8d174a6
+ 0xc3b99816 0x9f2bf1fd 0x6521b1c9 0xc6373e8f
+ 0x9c472d66 0xa71f624a 0x14af923d 0x52266735
+ 0xa0a0bb3e 0xba8d52d2 0x54c78a14 0x4dd0708f
+ 0x190c6c33 0xbfcc1963 0x3ed502c8 0x0766a192
+ 0xe1724557 0x32271339 0x6078e163 0x8de0c570
+ 0xd8e8dd17 0xce6b4b31 0xb341a175 0x8b8da109
+ 0x557dbde6 0x4863ddc1 0xd345fd2d 0xbe39b49f
+ 0x0b46caa9 0x572a2334 0x67d7e89e 0x658e947b
+ 0x6afe994a 0x17bd769e 0x054b5949 0x850db30c
+ 0x20ac6bb6 0x50480eb7 0xe06ebba0 0xacb7497f
+ 0x1dadb5c5 0x4d33366e 0x8559d54a 0x7cce6ef5
+ 0xfffed33f 0x7695b9c7 0xbec2d062 0x92a1c084
+ 0xe0220148 0xfef08bee 0xc3ee1787 0xbe7151b6
+ 0x86c8e888 0x4cae3d51 0xbeb8686a 0xa4b252b9
+ 0x54d8cfd3 0x8d38b0a7 0x2f8051f8 0xeb3e0808
+ 0x7bd6ef4a 0x6d3850d0 0x718b796e 0x20aa1cda
+ 0x0a2ae34a 0x1f786b4d 0x1ef65ce3 0x5a710df0
+ 0x618056a7 0x1863794c 0xb98ee235 0x9627fafe
+ 0x48c9dc0d 0x33a09717 0xc985c1e1 0x0dcd0297
+ 0xd8559f14 0x0925fff7 0x1ec6e43b 0xeabd0343
+ 0xdf224c30 0x1560e2d0 0x11072a5e 0x5439abec
+ 0x68539ad2 0x7e220044 0x8a1285a6 0x1728d4a5
+ 0xf9d7cce1 0x6797757d 0x65c9101e 0x6e40134a
+ 0x2a3bf252 0x5859d1c3 0xd42d7037 0xe519f182
+ 0xa52ca09f 0xa4b8a207 0x3e2c5afa 0xa2dd1581
+ 0xfc43c1a6 0xc10737bf 0xc3196027 0xdbae602c
+ 0xa8b8bb9d 0xd092e4ae 0xd08b558f 0x41b0c1e1
+ 0x6523934c 0x2c339d81 0x903f234e 0xb24cdff6
+ 0x98e056ff 0x7f3d915a 0x87d1fa96 0xfbf87d09
+ 0x9543241e 0x5d7df767 0x81082a30 0x206e5ca0
+ 0x3c78dd55 0x3c4ef16f 0x0cdcda86 0x41b65308
+ 0x04001fd9 0x51647a1b 0xd0eba6a6 0xea5b6d04
+ 0xe6040387 0x0d8bb27e 0x68cf3432 0xd05a4c2d
+ 0x23c1f2b6 0x17241b34 0xebb1ca9a 0xf37a448d
+ 0xece67298 0x0487a8e5 0xfcb0bcef 0x31be2771
+ 0x82bce53c 0x85b84892 0xdabc1c6e 0xfa2abcdd
+ 0xd1df67c0 0x16f1ede8 0xff1a16b7 0x0d8c5570
+ 0x51fbe82b 0x8bbb72cc 0x2329bada 0x3085b33c
+ 0xb57804b1 0xb0e794b0 0x15c12782 0x607ef889
+ 0x0f812dee 0xf4cd98ef 0xb952b6f0 0x5a58331d
+ 0x5ec46323 0x125057ea 0x622c0ff6 0x883106d2
+ 0xfb3dffea 0xdc3e0223 0xa97ab5da 0x654600ad
+ 0x933167a6 0x374ed2a9 0x937eb718 0xd9501125
+ 0x1ab096d8 0x7c9e0cbc 0xe4977ce0 0xc5f10f9d
+ 0x34d150bb 0x964e8a96 0x45ca9ad2 0x4682d4cc
+ 0x1a547f3f 0x48fca7f6 0xd7bcc4a6 0xd97d99ae
+ 0xd8f0abc1 0x66cc1dc0 0x97db316e 0x8a382cab
+ 0xbfbd6c74 0xa48d1b1c 0x2699542e 0xfd497691
+ 0xface9d1f 0xb9efda89 0x4bbd1fc2 0x92f8afc1
+ 0x43b37edd 0x6dde4632 0x3919ef3b 0x895378e1
+ 0x87bef27b 0xf411bf33 0x656ba5fe 0x8b265339
+ 0x50901749 0x3bde1f64 0xd6ca273f 0x896cbaf0
+ 0x94122826 0x34ea9bf5 0x15d3043b 0xf332ff70
+ 0x2b95d76e 0x57a79ba3 0x71c1f063 0xe71fc35b
+ 0x8f07ee43 0x048ac612 0x65aac513 0x68ea6eb7
+ 0xf730ded5 0x4402fb34 0x70ac795c 0x69800516
+ 0xb1b869f3 0x6f4bbd00 0xe7447778 0xa36497f4
+ 0x1c59ed09 0xb2992d4a 0x93c6a1d3 0x11d3ce10
+ 0xdef0a673 0xe86e3d99 0xf1468e25 0xb272fd13
+ 0xd407426f 0x95497062 0xcad1dae1 0x5a483a78
+ 0x0bdb41a5 0x2899f32b 0xbb8bac96 0x5003c23b
+ 0xf88ffbad 0xf4155bd2 0x4dea88df 0x5507bfac
+ 0x86bd066f 0x7c993d88 0x89ad6efa 0x2dc99462
+ 0x8d634a1d 0xebd312d7 0xfc8a8549 0x26f6cc24
+ 0xdfc6c501 0x9615c1c4 0xa48293ef 0x52aa4e4d
+ 0x7c1126b1 0xed10ce8f 0x39d15759 0xf6dd7f71
+ 0x2f4d86f5 0x151da4d4 0xd9175dd4 0xb2d20142
+ 0x20fe7518 0xf35752a8 0x37ae7efc 0xc210d83a
+ 0x5d9ff559 0x33e91d21 0xd1c7714d 0xa98c7599
+ 0x8ee50ccd 0xc747a3b1 0x9dbc5317 0xc25ae129
+ 0x51b3647e 0x25aa4406 0x6e123b35 0xcc8fe12f
+ 0xdf9c6d92 0xff1e6b44 0xc294d3cf 0x458dbe77
+ 0x8176b64a 0x4daa895b 0x5ecc9d75 0x1b570965
+ 0xd563bbb7 0x297b9784 0x4129fd5b 0x77beeb2d
+ 0x82bab257 0xca55d798 0x4d413dfa 0x27214528
+ 0x918d94a4 0xe9dc1881 0x17a00e62 0xff38fe70
+ 0xf0578886 0x99fc567e 0x89728e9e 0x267a192e
+ 0x5e16982a 0x5da1f959 0x3c407435 0x9c5cfe85
+ 0xa7626913 0xb1145c57 0x174daaa8 0x0487ef1a
+ 0x11d7b896 0xcd48cce8 0x464ceff1 0xbdc0f36b
+ 0xffdc957b 0xb94233f9 0x61dd9f4b 0xfbc1fe7c
+ 0x45f0195e 0xd7c92251 0x6c4ba5b1 0xc780a5a0
+ 0xe8fc9220 0xa7ca21ed 0xa82eab05 0xd6050a60
+ 0x68bf3f0e 0x50214ae8 0xb83e6b76 0xa435330c
+ 0xefe62d27 0xd3b40484 0xe96a563c 0xc93296b2
+ 0xd1531895 0x5db76e04 0x491b827a 0xf160fcf4
+ 0x4b82737c 0x3c72de73 0x1996e649 0xd2d79c59
+ 0xb1263519 0xb8660e24 0x4b07996d 0x71df252d
+ 0x58f95a70 0x8618a823 0x94239726 0xd6d92a80
+ 0xd8142a6b 0xc98c3175 0xfaa52b59 0xe91fdee1
+ 0xd9a1fbff 0x8d63a59a 0xe0bd9077 0xbb1cddda
+ 0xad57fea1 0x32af0614 0xea652e8d 0xa02ef7b3
+ 0x07440720 0xbac50654 0x5e32309d 0x444a9d5b
+ 0x9c5d9ff4 0x6b0ef745 0x248f1f75 0x7d87e2e8
+ 0x27490681 0xfc2a7b49 0xd81d2e73 0x76b09294
+ 0x4512b27e 0xcd72c2f1 0x41d3ba4f 0xc752688d
+ 0xc22a2077 0x45a01ca2 0x82b5ba56 0x9f12c039
+ 0x44cc1b0f 0xe8b8353d 0x0c26d80b 0xe54b917e
+ 0x62df727e 0xfce091be 0x79ca5f3c 0xec222126
+ 0x4df04d01 0xcd7566d0 0x839eb434 0x9b6d3415
+ 0x61fda637 0x3549727b 0x44117109 0x9d1c3ed2
+ 0x2c3cfce8 0x2e2acd9d 0x4ba9129d 0xbe14efef
+ 0x5d07e000 0x2081f339 0x1daf0bc2 0x74d098c3
+ 0x301e59a7 0xfd696b42 0xfc4d3387 0xa5c09d3c
+ 0xf8b0e4d8 0xadd63e51 0x5815b319 0xec7e8516
+ 0xc8d93178 0xdf1b9e1d 0x22107d46 0xa3a99acb
+ 0xfffc3859 0xd00561d4 0xb383323f 0xf6b7033a
+ 0x90f781a0 0xf5f2ce72 0x6eb3fdf3 0x8cc20a5b
+ 0xc97c9c66 0x95135ade 0x24880471 0x9bb65b03
+ 0x81b19c7f 0x700d0f5d 0xd13737b5 0x6607133b
+ 0xfbe4e7d6 0x3c4f45fe 0xfd6782c1 0x93aa0e29
+ 0x5e80ece2 0x16609c87 0x238ba834 0x1ddda4b4
+ 0x6d07bef6 0x23422da6 0x034a0e64 0x9fbd2d4d
+ 0x29f9bf71 0x009ca5a7 0xf483d433 0xcc5b600b
+ 0x6bc292eb 0xbbec5d01 0x3e45ed47 0x1f19013c
+ 0x9beb22ac 0xab5e821e 0xa1430d82 0xd88d6684
+ 0xf8e70a20 0x4e267714 0x32740299 0xc87b9d0d
+ 0x61e7c75a 0x967f007c 0xe1f93f4c 0x11a1c3a5
+ 0xbbee7b5f 0xd1ef645f 0x141aba51 0x70694200
+ 0x71945636 0xc9dde72f 0xc5955db8 0xdbef5230
+ 0xbd17479b 0x53159bd5 0x0878bdc2 0x9fdd9d07
+ 0xaf67a519 0xadca8377 0x13841851 0x97f464f6
+ 0xea749381 0x47018b36 0x42cfffdb 0x2366f112
+ 0xe280757d 0x7426dc87 0xcd5252bc 0xe5bdda7d
+ 0xc9728a8e 0x8e08cd82 0x66797c08 0xe1600e06
+ 0x149121b9 0xf9ea0e1b 0xc3da0d90 0xde18b684
+ 0x0c568801 0x58e83138 0xfe3fe553 0xc52b4e60
+ 0xb6afb01c 0x9154fba6 0xddabb2f2 0x018eaeac
+ 0x7c9640d4 0x9c7c86dc 0x41b8d514 0x8bd27333
+ 0xf07f842e 0xb75e7858 0x990187d3 0x316ef3a6
+ 0xfaf22ada 0x95356100 0xd0ed3ad6 0x3d9951bd
+ 0xd4aa1b22 0xf3a6ad11 0x797f6e48 0xb2428538
+ 0x91466c20 0xf17569d0 0x62d5d1b3 0x5a3d69e4
+ 0x6d869d97 0x82a84e5d 0xf6a45cdd 0x8781c19a
+ 0x0dac70b8 0xe79a4712 0x4617b8c0 0x3167f846
+ 0x9c6e7b77 0xc60b0e08 0xd85879c1 0x2be3a597
+ 0x06a6daf1 0x80915697 0xa3452bde 0x9cfd11d6
+ 0x69be41f8 0xebcadb24 0x315dcb53 0xc35f3e59
+ 0xd5b2edf3 0x443859d5 0x7d54f6a5 0xdcdac118
+ 0xe767ecbd 0xd017fb76 0xd0e7b4eb 0x8d9bb8f4
+ 0xce7b7d9a 0x92c0b4a2 0xcd5d8e1b 0x6f83d592
+ 0xc17f2b68 0x2cdab9c7 0xb6e70484 0xe5fe74c6
+ 0xe87747d2 0x228d5a4e 0x9dde03e2 0x9a14ba34
+ 0x471229ca 0x69be2353 0x74450c0a 0xd1eb650d
+ 0x78501400 0x1c4f2372 0x1fa1b6fb 0xaae57238
+ 0xd724663b 0x05f5c43f 0x402bc254 0x68877f3a
+ 0x57e6c691 0x0a51ef53 0xb65a2733 0x57431f71
+ 0xceb73088 0x03c761af 0xb4542581 0x23933fee
+ 0x4d726fc8 0xe6474d89 0x4816a760 0x97f68d6e
+ 0xb892a46f 0x1fffcbc0 0x63f9c6a2 0x19ec45f7
+ 0xad0f5d1a 0xe1436104 0x02db0bbf 0xa88a4df2
+ 0xca060341 0x7bef4581 0xbbfae170 0xedf98d3a
+ 0xc3972d10 0xce08a7a5 0xf2554832 0xb22c4280
+ 0xf51295a7 0xaafe76f2 0x0503afd6 0xadc0191f
+ 0xf788a6a8 0x32dde44d 0x2e148322 0xe4f4dd86
+ 0xa8012f5f 0x68950d8e 0x40ba9fb7 0xeff278cb
+ 0xf1f29ebb 0x5f273270 0x54db6ab6 0x032c76d6
+ 0x28b7a8ba 0xe06ee4ec 0x95b4c36f 0xf895a4bd
+ 0x6e886a7b 0x29ca6362 0x5ab44a12 0x122b4b0b
+ 0x77542b75 0x4254355b 0x8ba85616 0x78f02722
+ 0xad2c32f4 0x7a8b56be 0xda66fe2b 0x1018c515
+ 0x8e963b24 0x492cd4fa 0x8e8daa8b 0xbbf9a920
+ 0x5e1c170b 0x5b55acbc 0x96a08ca9 0x87628e01
+ 0x7daf9cde 0x402b7363 0x704db5b5 0x4ed3e581
+ 0x0b76bc99 0xee629701 0x976cfef1 0x222eb820
+ 0x1eae4155 0xce2c39a0 0xfc80e3ff 0x46604921
+ 0xa6411e39 0xc64f34d4 0xc2506d0d 0x9175c98e
+ 0x2b41e939 0x9f612788 0xe84717b2 0xdd5f3d18
+ 0x011ccf8c 0xd47c6dbc 0xc42724e4 0x4ecdb867
+ 0x88c2fc65 0x7146f321 0x426ce2d0 0x21874594
+ 0x94752082 0xac96eef9 0xbfaa8f43 0x4b599929
+ 0xc40c67df 0xc2f88319 0x6c13b780 0x0331ddf3
+ 0x03141f93 0xc8792b1d 0xa5cbe506 0x68424a36
+ 0x35fe7a9b 0xc42db001 0xa2c5e600 0x2e9f8f21
+ 0x7733f912 0x24b163b0 0x71003270 0xe5a5c52a
+ 0xf08c8455 0x9f6b0203 0xfa048b10 0xfb2ef899
+ 0xe9b81eef 0xc5d91db3 0x604bdb10 0x30a2bab3
+ 0xbf75341a 0x1609bb55 0xfe4d07ec 0x0ffabee5
+ 0xbfb339e1 0xb3f43c0e 0x66cd4d8e 0x752b5a86
+ 0x9908cfea 0x237d4b88 0x1e4c78d1 0x41914cb7
+ 0xe2d72121 0x815cc67e 0xfbf32db4 0xd4ab50c3
+ 0x5b8f8ca4 0xd7f0225d 0x75662558 0xe1586c50
+ 0xb9add021 0x1475644f 0x7d4d1e0f 0xb078549d
+ 0x64edd4ae 0xe9aa17b1 0xe03324aa 0xad30bdda
+ 0x2f27b674 0xf65879fa 0x5b5d7360 0x75905386
+ 0xc2ecd3f8 0x373566df 0xb7de23e1 0x91805774
+ 0x86162380 0x449b798d 0xaaaa35b5 0x0c72c757
+ 0xda4f445f 0xa83096b7 0x86002daf 0x7749832b
+ 0xf3a61bab 0x5feb28a1 0x26ee7610 0x5a5c40b6
+ 0x42c9ee14 0xc4dbb8b6 0x1f67936a 0xe1b56bbe
+ 0xe027f6b9 0xe63fb059 0xc88bc732 0x3111de49
+ 0x35c2305a 0xcbf91704 0xbd792b65 0x36de53d2
+ 0xe2de429e 0xb90aad73 0xa9f473a4 0xca054a43
+ 0xa984faa3 0xe8ddfb62 0xc36104c8 0x95e7e647
+ 0x17437e84 0xa20c074f 0xb5609b79 0x468c3b7b
+ 0xc0bc3e20 0x368c94fa 0x04ff3519 0x60b01b2e
+ 0x4a3ad0b2 0x4d8b4633 0xb1dc5e67 0x7e14c0be
+ 0x58a6cde6 0xc88980d9 0xb4ca1c86 0xe17c13bc
+ 0x3efb7728 0xadecba18 0x369ab25f 0xcda74fec
+ 0xe9c4c6aa 0x55590211 0xbe191ec5 0xed8ffbcd
+ 0xea3bd84f 0xe1fde7c5 0x5c788a9f 0x31a7b858
+ 0xd65315a8 0x62be6ed6 0x04b8be91 0x73548a2f
+ 0x93f9cbe6 0xcae8695c 0xea678c66 0x618251bf
+ 0xbe8920fc 0xf4f76833 0x15ad8be7 0x5ccf9cb0
+ 0x8d6a4fb9 0xe1a946c0 0x00fe7631 0x6abf0c2a
+ 0x72fbb39d 0x72bd5bac 0x7d679c95 0xaa5ccef7
+ 0x6df60938 0x9f08de64 0xb13afd73 0x61e2cc19
+ 0x31485e10 0x2e125f53 0x74021ab6 0x43fd53f4
+ 0xe506757a 0x454bd201 0x84947916 0xc89e453b
+ 0xa92324cd 0x3667608a 0x28e2645f 0x17e1f1ad
+ 0xa300d261 0xc9662fd3 0x987795f5 0xad6c0302
+ 0x55d47cc3 0xe96259cd 0x0d67ce7d 0x07bccb37
+ 0xf43d61a5 0xbd7131a5 0x686bdc7f 0xd570d5e4
+ 0x9ff9331a 0xac9d1d6e 0xa1702a68 0x4a5775b9
+ 0xa5624641 0xf65bd241 0x2ac16f90 0xe3413b5a
+ 0x17ffa019 0x9d46dc7a 0x2a3081b6 0x857ce29e
+ 0xe6640ac4 0x6445b538 0xad3d7e1c 0x9b79c366
+ 0xf462361f 0xd1097ef6 0xca1c68f6 0xb5f30167
+ 0xc14a23d8 0xc10dcd22 0x2a2fc332 0xfb253533
+ 0x65fdf0b5 0x404b7ad8 0xa9ba6f4d 0xaba569c0
+ 0xbaa52473 0x0e4627a8 0xc5f59463 0x362e6c4e
+ 0x4b2a486d 0x0259c34b 0x28c473f1 0x503bb776
+ 0xc5c0c537 0xa8b225c1 0xeea3c262 0x576dd495
+ 0x571ada41 0x9f7cd0c7 0xd7496acd 0x05feea00
+ 0x41201b9e 0xc77a94fc 0xe9bbcdcb 0x57b23f11
+ 0x0804834e 0xd03b6bc7 0x01010b7e 0x1398ab11
+ 0x16c14655 0x3c6e5e32 0x420bcbd9 0x8047a032
+ 0xf70c4e5e 0x2a3e76ac 0xedd3223c 0xbbba8d71
+ 0xba2a9916 0x1b83f930 0x4c93f25b 0x79731cc9
+ 0x77925eaa 0xb2fee6dd 0x01f12a1b 0xd797d09f
+ 0x1d63619b 0x2b04daaf 0xcaa55fcd 0xc4628c52
+ 0x930f5701 0x0293b2d8 0x00e82920 0x3c4f3f60
+ 0x6c0990ea 0xec07864f 0xfd650432 0x5bdb68df
+ 0x9d138863 0x2a06928c 0xe0f69d3e 0x5310dae5
+ 0x5bd2c0a7 0x775d764f 0xd8aadd14 0x20ba7850
+ 0x358aabd2 0x192ce2f0 0xfe029fcb 0x9a787089
+ 0x032bd81a 0x2033745b 0x11b36de7 0x38e63443
+ 0x26a6a138 0xfe1b4cf0 0x8e8c2e54 0xd8d68982
+ 0x1f8bfd73 0x11132e4d 0x217497b3 0xa882ae2a
+ 0x895350e6 0x58042447 0x027e3513 0x9b23ecfd
+ 0x0368bfc8 0x1f2bb5be 0xe81d1738 0x69176a5d
+ 0xb4e0531d 0xc899b145 0x9fd09aef 0xabf6b854
+ 0x2f1856dc 0x4186e028 0x02aab53b 0x0231c01f
+ 0x543d0d94 0xbc207922 0xef61da69 0xe1056724
+ 0x67fd8072 0xc98426e2 0xc7635142 0xff184885
+ 0x653f91f3 0x1ab5cd1d 0x133df7d9 0x67b35000
+ 0xb5880c56 0x21e4c4b3 0x6773270c 0x1c30a75d
+ 0x360b8cbd 0x0efa143e 0x025c298e 0x8bea4b71
+ 0x903465e9 0x99521cf4 0x2e1857e7 0x13266774
+ 0x72f6d2f6 0x36a1a4fc 0xf0e38e70 0xc9d613d7
+ 0x765b045c 0x28ea90e7 0x99766fb3 0xcdb93ca8
+ 0x4ef82ae9 0xfa083dbb 0x280d6bc6 0x5fa6f9f4
+ 0x8232c95e 0xe899ae64 0x9757bcb7 0x7b9a3fbf
+ 0x7ee59763 0x707c1e8f 0xb09b26cf 0x39b130f4
+ 0x57b13cca 0x9431c3bc 0x03074f78 0x77108240
+ 0x2243cf2e 0x79f1c09b 0x2d7051d7 0x1e896e0e
+ 0xfca3c98a 0x033f9d17 0x8a84fa5f 0x54ef6d59
+ 0xea4f038d 0x37de0f3a 0x290fdf6d 0x87a99d3f
+ 0x03539027 0x423a6a72 0x1751d4ef 0x3307e618
+ 0xff81f836 0xeff8f63b 0x5fd7f014 0x5d2a7e84
+ 0x9bb1c22a 0xd90f6902 0x53594d40 0x2a06777c
+ 0xbfb045d9 0x3a994642 0x5d3bb1c9 0x92ebe0c2
+ 0x1351d163 0x1d164e51 0x646facf6 0x5a09577c
+ 0x1d67f8e2 0x5857aedf 0x4325f877 0x40b104d9
+ 0x417b2244 0x944a7154 0x46887db2 0x8e5c72f6
+ 0xb1e4105d 0xe23955a6 0x32c458f7 0xc5b0adfc
+ 0x45b48308 0xccde9154 0xa84cfc72 0xc4f67710
+ 0x19a5d6c9 0x18feea83 0xf731b3f5 0xd26e63c9
+ 0x3869ef48 0x70b962d6 0x5f2b4ba3 0x5dd5a9c3
+ 0x1efc97a6 0x09be830d 0x791d72d3 0x53f2948a
+ 0xf5bdc706 0xa5b6aeb0 0x6c35db0e 0xc312c33b
+ 0x6dca7a95 0x9f890aae 0x75308dfd 0x7de2239b
+ 0xf530420c 0xe085f9b7 0x2d48c359 0xa8d1fcef
+ 0xcb3f9669 0xdf491f38 0xc59ffdd0 0x995cda92
+ 0xdef37f3b 0xe056b574 0x676eafd4 0xd4bd9336
+ 0xda3ada02 0x290cf756 0x991efdaf 0x2f70baa2
+ 0x515ced1a 0xaa0fa199 0x77f09ee0 0xafc3d840
+ 0x79e5ada0 0x7900a254 0x4ca65cb7 0xb3eaba8f
+ 0x98cd17e0 0xe179d477 0xe80d2f39 0xd89f3b4c
+ 0x8d3ca0dd 0xd1d87ab1 0xf9368d54 0xe885ded8
+ 0xd500c7f7 0x04910374 0x7c6467be 0x5ad058ce
+ 0x5f8885b8 0x08a4a3c9 0x90583a94 0x369f4c36
+ 0xafbd90a9 0x6eec8300 0x1fd17777 0xaa8ba562
+ 0x24531969 0x64eae352 0x6f7e72c5 0xca5e2247
+ 0xee11333d 0x4e96b233 0xcc9c45db 0x377d9b3b
+ 0xac17897f 0x8d4f2cf7 0x03786608 0x2ed70cb9
+ 0xabb521fc 0x27ae8324 0x99fedf05 0xfa60f2f4
+ 0x60fe2470 0xd9994193 0xce4a1f0c 0xdf803250
+ 0x7773e538 0xe3461726 0x8f1fb31a 0xe20b4ba0
+ 0x247a6bd0 0x33f33c29 0x0534675d 0x9df47ebd
+ 0xcb86d416 0xfca6bde0 0xc2113e28 0xac64d376
+ 0xd34923e0 0x128f937c 0xc74b76b6 0xb653872c
+ 0x05c78e23 0x482ece1a 0x17cd4da8 0x460f5a20
+ 0xa9a3676e 0x0776830a 0x9c5764a5 0x7c0bf0f2
+ 0xe193d4be 0x31b71120 0x4beed8fe 0x8426bc77
+ 0x9f665f9d 0x4e2b00be 0x2dd365af 0x015f5889
+ 0x92bd288b 0x4bda3b7a 0xeb2b0605 0xaadc6a84
+ 0xf715172f 0x1b0fdedf 0x17ccd242 0xd511eab2
+ 0x75829b1c 0x0f5861b7 0x229338cb 0xcad5ac0d
+ 0x95ed8bb9 0xe719c62b 0x2e50c781 0x40492cc9
+ 0x7ac3e8c2 0x4881bef1 0x8359b0a8 0xd0a8713e
+ 0x3808db04 0x847e12f9 0xd28ee5b2 0xc77f7a81
+ 0x2e89e5ae 0x95296641 0x55f44a6a 0x22c16d11
+ 0x1fa9d5ec 0x3b131a56 0x6b113976 0x057616a9
+ 0xf4813132 0x003fbe23 0x082a9ff4 0xd0db4d18
+ 0x84be1702 0xc9c51278 0x9f5bc62e 0x5691be5d
+ 0xc12f7c79 0xa84f8dc9 0xa9b2b8db 0x0ab996e3
+ 0xd25a2195 0x91584ae2 0x11e0a407 0x9faf14ef
+ 0x7ecf8b2d 0x64d1b392 0x8292b54e 0xaec7c7d8
+ 0xedf1eec6 0x9164a0a8 0x16132244 0x07077758
+ 0x32f53095 0x8036d28b 0x5534fa23 0x66869c3f
+ 0x3a503595 0x87706388 0x315540f8 0x5348f0c9
+ 0xfbe7451a 0x491d7c96 0xa70ad473 0x5d7975c1
+ 0xa51c99b0 0xdc0320d8 0x259a0935 0xf15dee76
+ 0xb080d4bc 0x1d8611f7 0x64b6c12d 0x115bb158
+ 0x1ae6f885 0x9b7bddbb 0x74107ba0 0x5ec2433f
+ 0xc05198b8 0x4e3921cc 0xf866e4ee 0xdf4e5b52
+ 0x93dc0bfc 0x9f5957eb 0xffebb962 0xb2845803
+ 0xf16acbdf 0xda0923e7 0x2b7d8663 0xeef7ea5e
+ 0x5c468035 0x1bf5eeb4 0xcf04aad0 0xa898340b
+ 0x58f32310 0x6502901b 0x151e45a6 0x4e0a8176
+ 0x312d5e40 0xb0a82dd9 0x7461f194 0x5d955cc7
+ 0xbc26c368 0x26cc45a5 0xfff346fb 0xcdbdad82
+ 0x1f0da6e7 0x6800be4d 0x931a3413 0xd471a14a
+ 0x773ade46 0x525f8a29 0x416f7b22 0x75c2b0cd
+ 0x5abe1934 0xbb87502d 0xb1568281 0x95c1abf6
+ 0x491971cc 0xbac11423 0x0daf5cfb 0xb5e37509
+ 0x2eb36341 0x1784cff3 0xdcebc5df 0xdb10122f
+ 0xbbed7029 0xb7b66506 0x2b732807 0xb5524662
+ 0x37c211d4 0x0730df05 0xe09e9822 0xd6910951
+ 0xc6ed46f2 0xfc7d7cd6 0x8d6af74d 0x4697b13d
+ 0x7959b678 0x9c67c19e 0x96686e89 0x7f973e98
+ 0xe5759786 0x42ba4801 0x05416f70 0x87a85c5e
+ 0x8f21af39 0xc64ce827 0xf658f857 0x3b75a282
+ 0xf6813344 0x0e9adb2c 0x46ca59b3 0x2f2c4fd5
+ 0x1a7ee3ef 0x1e3202ce 0xc4135b57 0x22792d11
+ 0xe399a044 0x9453c580 0x639da579 0x80239655
+ 0xb1b68953 0xbd677cce 0x9163a0fd 0x766c5b7e
+ 0x46ed281d 0x99ec91f2 0x7db3499c 0xbf2b9793
+ 0xb111887d 0x3906e075 0x9e211f1c 0x16f15768
+ 0xd27474c3 0x8813b27a 0x3393ce5a 0xe73aeee6
+ 0xfe056806 0xfe4bf0fa 0xe106529b 0x317d9099
+ 0xd2ad43c4 0xbd618f1f 0x77d8e13f 0xd4c10bc0
+ 0x30a335fe 0xd7a4b251 0x84c67582 0x1bc0723e
+ 0x7a1cded2 0xf6664fce 0x2bd8c844 0x967cc741
+ 0x8cb6bf8e 0xb8c49dd9 0xc167221d 0x5c65b9b7
+ 0x1f32b243 0x5729b02f 0x76f22a55 0x22ef22f7
+ 0xabcde168 0x273b0513 0xb8cc1b47 0xf0e378e7
+ 0xc3e189b3 0x344090c4 0x3cac2fc3 0x2a06749a
+ 0xb026617d 0x26bbe774 0xb15d08d3 0x6b29e7ed
+ 0x34b5145f 0x740f6f69 0x7edb95a3 0xf55df95f
+ 0x25061c1e 0x45192d2e 0xdef6bb9a 0x5538188a
+ 0x2f7ff744 0x6592e57e 0xdfc302eb 0x8564f70a
+ 0x81f22fc6 0x1ed3f7b7 0x3eb74e98 0x84ff649b
+ 0x40535223 0xa81996a5 0xb30b0b97 0x9ca701de
+ 0x45bd91f2 0x07e94e32 0xb2f60f7f 0xc3d68aec
+ 0x2296450f 0x31567179 0x5fa15060 0x6ade7193
+ 0x7ca6e320 0xb231f34c 0x1e392751 0x3fb50014
+ 0xff632467 0xff33f75b 0x65f2dcdf 0xfa464ff7
+ 0x1ffd17ab 0x34c38154 0x72906efc 0x2f649bd5
+ 0x5349c835 0x6c83e7da 0x9e0ff921 0xf2ad6dd4
+ 0x5afa8581 0x2d6deedc 0xf582ce84 0xda7ddfa8
+ 0x6485db26 0x874585e9 0x13bbb0a1 0x4283bb8d
+ 0x1648cc58 0x69fae5da 0xa5d7bc2c 0xd7fce256
+ 0xc2e25ab7 0x7ec604af 0x1efde306 0x36422ec5
+ 0x78e9bd5d 0xbfa63459 0x052efdbd 0xfbc9d2eb
+ 0xd8b729ee 0x888dfd1b 0xb64a687f 0x9ebd05b2
+ 0x622c28ed 0x3801fff8 0x476285e1 0x262e5f3d
+ 0xd6ba77c4 0x8d5663fe 0x4b9bb3c5 0x1909dfb2
+ 0x40db7079 0x2799a10d 0x1e2e55a7 0xe597551f
+ 0x4d38f913 0x972b1b35 0x92f77eb6 0xb2dcdb5e
+ 0xe275428e 0x0f136b53 0x321b55ba 0x70f7edf1
+ 0xc41fe047 0x332e9ff5 0x3c372115 0x2ea1c88d
+ 0x3ea09444 0xe93066a0 0x666670f5 0xee9553d0
+ 0xa817ee82 0xde3fd981 0xf6c5b2b7 0xe88e3857
+ 0xec60b610 0x4b0e1af7 0xceaa144f 0x0a8f8703
+ 0xd7969cd7 0x0a946a3a 0xc6f77ae4 0x3805f71d
+ 0xd5d56360 0xbee37cf5 0xfa524a3b 0x68ba0662
+ 0xdf153cee 0x5954f21a 0x05aedb31 0x340e4963
+ 0x129115db 0x271db9a2 0x70984fa6 0x7daf0407
+ 0x5fcd11d1 0x750f56c1 0xf1a93401 0x3a3aca1a
+ 0x8a6d152e 0x9c65e58d 0xf0afd845 0x3abef6ea
+ 0xe6e1ff7e 0xf8407d49 0x45dea271 0x545631ca
+ 0x73fad7df 0x21e60e47 0x3bd83fd5 0x12b4394e
+ 0xba4731b1 0x786279a0 0x97c6d6ab 0x2591deb2
+ 0x4b33bf75 0x772fb5bf 0xe9060fd5 0x6a752986
+ 0xdf3090d4 0x9de70555 0x471c2e4d 0x5305f077
+ 0xf2bdabad 0x2a4ed093 0x36e029a8 0x17b7a5b1
+ 0xce75a688 0x8377b839 0x731fa872 0x63f45ed1
+ 0x010bdd8c 0x4366cba1 0xd899b1b2 0x839a8a34
+ 0x4914176e 0x58fec42f 0xb3ecd171 0xa88b5247
+ 0xbfecbafb 0x65962301 0x7b5a7822 0x08b1056f
+ 0x6f0cf6b5 0x5dbe0084 0x3280b172 0xc77913e4
+ 0xa298f67e 0x2131f5c2 0xb9b9b501 0x7f30b7ef
+ 0x55d8cdb6 0x3b0c0dde 0xbf9a5cb6 0x50ba39ab
+ 0x0741872a 0x69217ea4 0xad4b12ca 0x14dd5da0
+ 0x5d220b6b 0x9d0356b5 0x9608d36a 0xdef765ca
+ 0x7d55819c 0xb57ca102 0x9f2a2c76 0x5efc9c7d
+ 0x42952b33 0xc8e2749b 0x2eff7d6b 0x211caa64
+ 0xec846e0c 0xf3119325 0x31bf7f1d 0x984fadb5
+ 0x36670140 0x6419ae9a 0x1c206656 0x86cb7d35
+ 0xbd323508 0x5f970165 0x21777792 0xc8808541
+ 0xecba85e0 0x0b4b3240 0xa70d8609 0xc68913f2
+ 0x67415bba 0x26af0069 0x81974b27 0x92066952
+ 0x5f6aa2e7 0x0dfa50b9 0xc1e65cad 0xb93b9d66
+ 0xad6c8ff8 0x8e885310 0x5f77e1eb 0x2dccb750
+ 0x8f18f33a 0x6ad45207 0x921285f5 0xf3d2d3ab
+ 0x1be2996f 0x9bc30897 0xc7c85614 0xce88b0ca
+ 0x55a5fec7 0x0570e871 0x50cd5f3b 0xb723a9a4
+ 0x8c2f6fd8 0x3a0bfcc5 0x0b75181c 0xe595e483
+ 0x063a7f01 0x16984414 0x9c74253c 0xd9627dee
+ 0x0b8aa93f 0xef9f3c7e 0x186719dd 0xb0311955
+ 0x4ffcf417 0x519b631c 0x295cb456 0x58494234
+ 0x81ebafc8 0x02002fdc 0xb28044e7 0x2682e878
+ 0xb86f281b 0x108f9c77 0x99368ca5 0x24887533
+ 0x37676f0e 0x71230faf 0x8e689144 0x81bbe972
+ 0xc8dbab68 0xca5a3ed9 0x878d622c 0x05217a5b
+ 0x7ce7e849 0x0416578f 0xc43b026a 0x86abc8bd
+ 0xf0fdc5dd 0x1684665c 0xf167d783 0x00d58f21
+ 0xb4929559 0x70572ce4 0xbfe6985c 0x051bdcce
+ 0xa9307ffe 0x2fa9902c 0xd8f76dbc 0x6dcd4744
+ 0xecb46877 0x18ac0a40 0x6f8a8064 0x66dff5e2
+ 0xa55d991a 0xfcd7e70b 0xad9c7fd7 0xb77415a6
+ 0x761134a9 0xa76e4079 0xe9ca8a5f 0xdb627ec1
+ 0x328cd5a8 0xc3f378c6 0x7f5ae9a2 0x5a144e26
+ 0xc4b778f8 0x1910215f 0x1d29a078 0x728c7575
+ 0xc2017bc9 0x201a0601 0xea1e939b 0x7ed85f43
+ 0x92893ace 0xb97613d5 0xa3e47eb1 0xaea2a6b7
+ 0x45b4de8e 0x864e3d12 0x300eb84b 0x57246fa1
+ 0xf9e50600 0xc5fb68af 0xff700271 0x4ecfe6df
+ 0x195f3f4e 0x9bdcfa8b 0x1bcca506 0x0ee96e1e
+ 0x4d722003 0xe6ffe15a 0xc3a392d5 0xedc4ea2f
+ 0x1cc2bc4e 0xf133ded3 0x584bcee5 0x63e54048
+ 0x34f57fa2 0xe606b846 0x82dece0c 0x7bc24217
+ 0xf45b9ac3 0xd9949991 0xbc262aef 0x7949bbec
+ 0xf37e0563 0x716bdca0 0xef533f5b 0xfa53b4e0
+ 0x97365a61 0xbf4cd291 0xc69c9c3f 0xb5ddd420
+ 0x92a65067 0x4a63f3ce 0xf53104a3 0x0053fca8
+ 0xb8f972b1 0x7eb74704 0x2bc2ef35 0x491b520f
+ 0x80f67bbe 0xd36fc91a 0x8babbc98 0xdd3aa4a7
+ 0x1005ace4 0xafe0a165 0x921ee005 0x9d05e888
+ 0x4e7913ee 0x43690cb8 0x634c75a1 0xf2ca1d08
+ 0x6f453485 0x1a62b5f4 0x692608a8 0x76837c9a
+ 0x222f6cb2 0xbc883372 0xc785ebf7 0x21b16a27
+ 0x5ad7860b 0xd5fec2ec 0xa573aead 0x9c0bd90b
+ 0xec3b5d8d 0x393a1263 0xd0cddd05 0x08477829
+ 0xd4bb3080 0xd1580e80 0x614e8dae 0x7e789a32
+ 0x273b2589 0xe5368d97 0x8db1b602 0xbd06492d
+ 0x6760aca0 0xee176a78 0xce44021c 0x4d35c720
+ 0xcc3d8185 0x752005a2 0xffdb4703 0xf01771b1
+ 0xfccc8abf 0xadca3bbc 0x2c2a4739 0x970d0fb8
+ 0xa829ca54 0xc4301da7 0xa56d3181 0x24a95701
+ 0xb760d1ee 0xea87f071 0xfabc32df 0x465f142e
+ 0xe0998f0c 0x6923edf6 0x3a1debda 0x3e88908d
+ 0x7069f55a 0x0cd61367 0x1218e044 0x99713258
+ 0xbb60c477 0xe3997857 0xc4e9ca48 0x4be6b283
+ 0x1bde70e0 0xb0f3e15d 0x40cfb11c 0xbb9e0879
+ 0xc4c732e7 0x2aa169d3 0xa2bff233 0xaa50e35c
+ 0x2d0989e3 0x6f39a59d 0x7a7b69c5 0xe66152bb
+ 0x69c74ec0 0x46ea7bc3 0x59c93af6 0x0a036f99
+ 0x95698244 0xe0ca1af8 0x3565483c 0x8abcce28
+ 0x6b322770 0x188e97b6 0x77874604 0x93298d36
+ 0xbc4a0f5e 0xbf367940 0xf69906ef 0xf2b5975b
+ 0x5968ec40 0xd0e75276 0xdf02b089 0x60b72248
+ 0x32de1e9a 0xe52bb0f9 0xf4b33702 0x87b4cd47
+ 0x31c86ac5 0x77106507 0x20ec46fd 0x5086dc0a
+ 0xadce33fc 0x898ee47a 0x3c6f8af9 0xb4a26000
+ 0x8f11d65b 0xf83d2284 0xe512bf22 0x24a7d8af
+ 0x12b194cd 0xa530f50a 0x1f64f621 0x6160f047
+ 0x8f223c99 0xc7e0809f 0x99312a95 0x5c729b2b
+ 0x4af6e5b7 0x8c6e5da4 0x93a07403 0x89fb2a5d
+ 0xeb347cfb 0x0d127850 0xc3278db5 0x456e3472
+ 0x731c2b96 0x841ed8d1 0x5ed8671a 0x16814226
+ 0x4cc3932a 0x556b1403 0xc8547260 0x52340a36
+ 0x78b8243c 0x9ce3ac1e 0x997c64d4 0x25812f0d
+ 0x5cd3b82f 0xaefcd02b 0xda85628a 0x3b9e3e2d
+ 0x4780e91b 0xbb265ae9 0x4667a62e 0x7fde4743
+ 0xae2d2c8a 0xbdf272d6 0x490e5bf1 0x8f764531
+ 0x59a8ca61 0xc39751a0 0x9777eddb 0xc89da92e
+ 0xfd46b968 0xd5383421 0x916ced6c 0x9fc14c5e
+ 0x91ff992e 0xd59cd577 0xf5cdda19 0x99ed4f29
+ 0xea30d84d 0x868bb72d 0xcd3e19d8 0xefba277e
+ 0x9b895f2b 0xb67570ae 0x7b963bfb 0xb7f59d33
+ 0xc82c0da2 0x713c0ebc 0xd2e19b6d 0xfdd7cb4f
+ 0x0442a88d 0x58e2e7e8 0x7b179f2b 0x12013442
+ 0xbbd1c2d1 0xc4e7d279 0xddb4cd95 0x18a254ad
+ 0xb2876346 0x4bdca7ab 0x94dc9778 0xb648e703
+ 0xeed00eb6 0xab02dd6b 0x3e25115d 0x45cedb33
+ 0x906c2403 0x457849ca 0xfea6f2d9 0x252fb56e
+ 0x2bbe39b4 0xa35c94e8 0x04952551 0xad733a12
+ 0x40bf3982 0x30cb3742 0xd6c149da 0xb6d29f20
+ 0x9df8b8eb 0x706065f5 0xfa915b7f 0xd2bdc0ca
+ 0x0a4c462a 0x288ef8ee 0x2fa27cdb 0xea11b73f
+ 0x5e909f42 0x06d764f5 0x1e2deaaa 0xfae5dbe8
+ 0x0ec720a8 0x8fd675b6 0x58ee95de 0x19fd1ca4
+ 0x4308d173 0x1884c251 0x56ffe45e 0x961c6bdc
+ 0x44582512 0xb76a958a 0x12cdc33f 0xdee5c784
+ 0x8dbbe9fb 0xe327f532 0xefb271ca 0xedecdca5
+ 0x798e60f3 0xcf2d194a 0xee275fd0 0xd8fe6f12
+ 0x30ce7bd8 0x3e17e29e 0x351ec4bf 0xe23692ac
+ 0x0bb60ab1 0x60818dc2 0xdfaea801 0x1afe161f
+ 0x72fbcb53 0x9382e661 0x56054fdf 0xe6261b4b
+ 0x97e746c7 0x6257411b 0xf0bbac9d 0x8fd6478e
+ 0x203e690f 0x9758da43 0xef6ede77 0xe85fc9e5
+ 0x8e5315ed 0x479c6f9a 0xeceaa8b8 0x4f626f85
+ 0xe79c2ead 0x14e97f8c 0x2bb51ff0 0x6b733645
+ 0x9e578a09 0xcf424ddc 0xb315bb19 0xc4833717
+ 0x3890ca82 0xf00aa52d 0x9e652f98 0x87ea3177
+ 0x7acc6baa 0x531c5eb4 0x6a85b1f5 0x7b1c0192
+ 0x0b32c8d7 0x735c5791 0x86c1ebc4 0xa4361511
+ 0x0c7bce26 0x1357809c 0xa382b877 0xa4f9a0ed
+ 0xca30e907 0x277d3c65 0xec0bba64 0xf5169aa9
+ 0xb8a1305b 0xbb4059a3 0xa44d32ca 0x76b0141b
+ 0x7bacc1c2 0x51273c1c 0xf8f4d7af 0x0278678d
+ 0x04d36367 0x38ed7b1e 0x8a45327a 0xdd19324f
+ 0x36a5952f 0x97661f43 0xe2671856 0x1eb34493
+ 0x8708de21 0x080f9e7d 0x070d13a0 0x2c54a64f
+ 0x86ef2751 0xf83a87e8 0xf61841fa 0x0ade1426
+ 0xe1cca086 0x96a9a439 0x648f53e0 0x378a6cf4
+ 0x894a3c7d 0x9bf1031a 0x2f0affd0 0x4688048d
+ 0xec159b64 0x28b103ac 0x462767a5 0x278ac30f
+ 0x3e5bf100 0xdd860ac2 0x384e9dea 0x55abe65b
+ 0xbc95d098 0x905277bd 0x8b47e264 0xf4cc82c5
+ 0x8f06e7ef 0xf2fb2364 0x13f70c45 0xc5eb083c
+ 0x6c4ee92e 0xb2f7719c 0x19883212 0x611f22c8
+ 0x8c742ec0 0x1550089f 0xc6c5933d 0x1a6aab8a
+ 0x27ac73c0 0x4b8be65d 0x25c17a0f 0xd1ee7238
+ 0x54a47bdf 0x9bf2d8e7 0x223873f1 0xb0825f98
+ 0x6263a6a5 0x6e732bde 0xcb2460bc 0x195b6758
+ 0x74eab2c0 0x10509c33 0xad5153c2 0xa9c77d09
+ 0x5581bc9e 0xe85a2906 0x19ecd606 0x22d04481
+ 0x2acc285c 0x4b01bec7 0x7946efc4 0x3fcc4f9b
+ 0x7711e2ba 0x769501b9 0x565ed3a5 0xa6a2e0c2
+ 0x2fc9f212 0x1da1dc7f 0x1e354a51 0x42f070bf
+ 0x96f603fe 0xa11ea899 0xefa65c44 0x309f3b3d
+ 0xa4e7de23 0x0fc0ecf0 0xed135d01 0x11526284
+ 0xe1535798 0x46236948 0xbbf375f3 0x33d03953
+ 0x057340ac 0x1f8d08bd 0xd3e19b4a 0xd1a074e8
+ 0xe8f7b3c1 0x81f4e7cc 0x7efb3ce4 0x2d7b8dfe
+ 0xc35c1b7d 0xa981b243 0x56dc3df2 0x7b0cdd73
+ 0xba20923b 0xe4469620 0x9999a05a 0xd558e6c9
+ 0x1b2a6e34 0x1a03ad40 0xead427a9 0xdfbdf1ea
+ 0xe9b9c758 0xe1ce3e74 0x2ee3013c 0x37fde647
+ 0x7528f451 0xdb169663 0xc1595963 0x487703e0
+ 0x649824fc 0xf4e557c4 0x26ff0cfb 0xa6c61495
+ 0xbf6ff8a8 0x1e936c2f 0x28170318 0x16623623
+ 0x7cf43aa9 0xcf44b9bd 0xee05bbe9 0xbc364396
+ 0xfac9c35a 0x70664227 0x4200bc74 0xc847c1f3
+ 0x393b52cf 0x67df2a37 0x24828663 0x85c64437
+ 0x0ca91fc4 0xbbab8588 0x170d40ec 0x6a5270d7
+ 0xd873cb99 0xc461e41e 0x68fb5dcb 0x175808d3
+ 0xb3c75d6c 0x5f8659a3 0x164af2cd 0x491ed225
+ 0x21b774d4 0xfc5f44e0 0x5a761165 0x8394b784
+ 0xa3625993 0x23db8229 0x18adfc19 0x7a86dcaa
+ 0x3759a419 0x8236b6a0 0x866eb76b 0x40e3936d
+ 0xa327f573 0x0793a949 0x5511fbac 0x7aa8017a
+ 0x869d2433 0x9fb80368 0xd9b8d14a 0x725f0a17
+ 0x50ec0c4d 0xeb8bd3bb 0x6785d7c0 0x9882836f
+ 0x0c164e65 0xa7ff708a 0x3f4b7ded 0x160237e4
+ 0xfa551105 0x7dfeb41d 0xf60157d5 0xf863bb00
+ 0x23d96b49 0xc8b80eea 0xd395a7bb 0xa6cb0b99
+ 0xdae2d53e 0x374d5699 0xede8a731 0x64e2eb82
+ 0x3aaffc9a 0x03da3d18 0x775890e8 0x3842a94c
+ 0x863c3914 0x4cf8cc03 0xc40d3d2c 0xb5514333
+ 0x1254c457 0xae791759 0x7eebf7c4 0xcaac9331
+ 0xb3f9a144 0xf9430aa4 0xc241038c 0x7b481099
+ 0x6ffaf560 0x504946d2 0x5ad1fb41 0x4c4ed169
+ 0x1331c934 0xfc02efaa 0x519b65e5 0xa2eb152b
+ 0xe3b78626 0xf6cc1ce2 0xaba6d9c6 0x6c117767
+ 0x3ba1a970 0xab320fb2 0xa17ae6c9 0x07f8b830
+ 0x1752f87c 0xcadd1616 0x81229b18 0xb8f1c91b
+ 0xf62e10f9 0x40fb1a82 0x6feed0ca 0x375b3f31
+ 0xcc951ee2 0xdbbc0a84 0xc3caf9d9 0x51e4f7e2
+ 0x6c2cc2da 0x86994a97 0x58516036 0xa680e1ff
+ 0x83255438 0xe304daf0 0xabf95c4b 0xeeecb868
+ 0xf258ca56 0xc63b1f45 0xe4637c07 0x4bd8052a
+ 0x01515dbd 0xa3d3dca6 0x79565fed 0x0427abda
+ 0xeb640f00 0x4f34d441 0x135af3a0 0xad86ce4d
+ 0x83daca30 0xd9ae59ab 0xad9edd9a 0xbb18a84d
+ 0x9163b7ae 0x68c45613 0x4eeb7297 0x12c0aa50
+ 0x0003968c 0xb872a623 0xa39b33c0 0x4c934155
+ 0x658bcce4 0xfa7c8c07 0x062681c6 0xd091dce3
+ 0x6b421cf0 0x726aae92 0x623e4f88 0xd74b50b4
+ 0x0a6410e7 0xe6158980 0x2956f74c 0x5e18c87c
+ 0x6fd6e24d 0x8afdf654 0x928a859a 0x55edce30
+ 0x63a859ef 0x4b82ee8c 0x6eda25a4 0xf8b32d44
+ 0xdc47b7f0 0x5ff1c6d3 0x8ec85752 0xfbcddc99
+ 0x86b90e33 0xe9fe679e 0xf6933cee 0x7054cf99
+ 0x7fca8ff3 0x06bbad7c 0x1a5a6f2f 0x1effefd9
+ 0x1aae25a8 0xc594864f 0x8df29cf4 0x373b22ee
+ 0xfd7cc798 0x2d3018a5 0x31806f07 0xaeadce1e
+ 0x9eb56db2 0x997e6a02 0x3f6ad090 0x8d13dedf
+ 0x6fb3b150 0xbd15fe3c 0x35b6e654 0xfd9cda44
+ 0x77864119 0x7ab48f53 0xf0cf2f91 0x16c955fe
+ 0x06ae6500 0x11969961 0xcf4c27cc 0xe0500cae
+ 0x361b4f0a 0x95eafe71 0x9ec8e2a0 0xafd6afe8
+ 0x424b6b80 0x4b2e1810 0x3b474219 0x142aea44
+ 0xf3654186 0x3ba86c0b 0x833f65c2 0x6d47eb79
+ 0x62dd2140 0xd94a70fb 0x8ca1614f 0xaf4b2f5a
+ 0x49a94d86 0xd1bcf8ff 0x75758118 0x4d249643
+ 0x1998d0e3 0x9138a5d2 0x25c3285d 0x94aff0c3
+ 0xa3b5228a 0xd19437b7 0xef21e585 0x1b7e4f3c
+ 0xd641981d 0xb402e718 0x864429c0 0xdea501be
+ 0x106824bd 0xfa029c7e 0x24d7c5b1 0x392faf14
+ 0xc6d34b80 0xcdae7248 0x8fcda2d8 0x4ea47d55
+ 0x6159a07e 0x7321230e 0x898acb28 0x1ee768ef
+ 0x18d5b5ce 0xad651352 0xcdb1b265 0x51344650
+ 0xac50b615 0xe63a8384 0x80662716 0x82a18a79
+ 0xa5a7efaa 0x7a145b9c 0x849e7f01 0x6798d58b
+ 0x040590b7 0xc5ea38e3 0xc801c79c 0xbb195537
+ 0x928bbb0c 0x38dbcc6c 0x78392d00 0x7a1ab99a
+ 0x7ab11689 0x5da16626 0x01fc4fc1 0x73aaf369
+ 0x4ae39f8f 0x5615a7a3 0x973313fa 0xc7ad9ba8
+ 0xd58a9805 0xf600d196 0x2acf7e8a 0xa9781219
+ 0x2f60bfd1 0x73dd49ed 0x08e92462 0x7c088af6
+ 0xc0ec767b 0x813d1a47 0xc854915f 0x38c19883
+ 0x3d68948b 0x37013904 0x7d673d86 0x9a347e46
+ 0x89b64816 0xe2eea157 0x9c9e7b43 0x88894832
+ 0x4e420ce2 0xff8ca9a2 0xc152fd87 0xfb407682
+ 0xe2808404 0x4c386f6e 0x053cd949 0x08f55f48
+ 0xf89b7624 0x37e43a08 0xf9bc62ae 0xa6d76f51
+ 0x4e400425 0xda181f10 0xad190c86 0x6952cd23
+ 0x1c1fc245 0x44d3449b 0x2383b865 0xfe9bb854
+ 0x745990c5 0x34be0541 0x3ec0104d 0xda80eb99
+ 0xf0b3f266 0x29caf9a7 0xf4ff713b 0xebd3c95c
+ 0x1b2223d9 0x14809a4b 0xde8ecf29 0x2140f249
+ 0x9da938f4 0x5376618d 0x45e1c6b9 0xcde4cb9b
+ 0x1dad65a2 0x47567cc3 0x285f8145 0x080df22d
+ 0x61f570bd 0x54c91058 0x597a3472 0x4e2199a7
+ 0x54bc0b43 0xbbe1df4b 0xdf0843a0 0x007ffa70
+ 0x44a969ce 0x2b10aaad 0x337ffb08 0xd176496c
+ 0xe89a0d63 0x953fb0c5 0xc3cfcb1c 0x92a96ea5
+ 0xbde759f4 0x497e8adf 0xad8b516c 0xfb6967f2
+ 0xdc9031a4 0x6a200ab4 0xd93f8951 0x28e22ade
+ 0xf54c1c4d 0x8b6325f0 0xa7946fbb 0x76ed4a4d
+ 0x6b808dd2 0x86634406 0xa5044ca5 0xe0d0591a
+ 0xd817455d 0xc00d1daa 0xc7c40850 0xe2e025fd
+ 0x74ba9bad 0x550c236d 0x29b44966 0xdcbd8276
+ 0xc4b6586d 0xb1702e0f 0xaebf15a6 0x7d2f1cd7
+ 0x9ccc8b24 0xd2fe8842 0x1fe70488 0xffe89b22
+ 0x7600ef41 0x75569ee5 0x89f065c0 0xda8d0c8b
+ 0x27296329 0x99241565 0x611cc8c9 0xc67415f1
+ 0xf0cf41fb 0x38f066ea 0xc13dff67 0xbc04723e
+ 0x8f6f8db7 0x94821abe 0x45a5c57a 0x0c3c2474
+ 0xd80aa358 0xf95e1874 0xaf4258aa 0x325f2c1d
+ 0xcb15342c 0x40d77acf 0xefad72fd 0xb154345e
+ 0x9584df00 0xd0712387 0x6d7d329b 0x8c8ff2eb
+ 0xebd94378 0x8b0bae9d 0xeecd6bc3 0x529a6a69
+ 0x797edc8f 0x4845ef9f 0xa0d083f8 0x14cd8c0b
+ 0x775ef704 0x1f83b4f0 0x0047afdf 0xebf6dd6f
+ 0xad0a5557 0x9a9beed1 0x9784c839 0xc5fb7640
+ 0xe0b3993c 0xaaf9fee0 0x59976746 0x79e0674a
+ 0x82b5ffca 0x608e4a56 0xdb81df21 0x3a558382
+ 0x17a7c643 0xd9112bd2 0x2e2a3121 0x852a0836
+ 0x5625abd8 0x57f8621c 0x7d64dd40 0x2a8d920f
+ 0x5fe3e399 0x4486edd8 0xd36655a2 0x23851557
+ 0xa096b610 0x06d36c37 0x05d1fb87 0x953aea36
+ 0x168daec1 0xbb219585 0x5f17aa7c 0x35d378ae
+ 0x76e183ff 0xd6ec5f10 0x4bda67c1 0x96859188
+ 0xb328559f 0x834f3e93 0xab87eb5b 0xa8bdb45c
+ 0x6e81579f 0x07fee7e4 0x426aa06f 0x7380dc40
+ 0x27cb618e 0x05d41994 0x98876595 0x4e6ecda7
+ 0xd0549783 0x21b62d1c 0x85058d66 0xbeb36620
+ 0x3457564f 0xc29012ee 0x40f30d02 0xa19964e0
+ 0xe6f4e733 0x629df93f 0x958abe90 0xab4c3d2a
+ 0x55c626d3 0x63cd0ce5 0x832f8ae1 0x8dc5bc20
+ 0xcd0b0550 0xfeee65eb 0x0b8309a7 0xdaa9623c
+ 0xb5e51b5a 0xf00c9323 0x6b897c27 0x0bd12d37
+ 0xf42f8ae6 0x48b81705 0x155e9392 0xb40ca230
+ 0x798cd836 0x58e7eb07 0xca2eb2d6 0x238429bc
+ 0xdb60b26c 0xca555fd8 0xac907a1c 0x2307f54a
+ 0x74b44142 0x44d620aa 0xabf0208d 0x8904f028
+ 0x264f31eb 0x5096576e 0x470ccc88 0xed1d68c2
+ 0x03ddf124 0x507bec18 0x262b5988 0xb9b530e2
+ 0xd1ac6728 0x3a407a87 0x92308c30 0x7394af8f
+ 0x4273dd50 0x1abd7a7d 0x28374e74 0x87404b18
+ 0xcf9b2454 0x2da15860 0xfb151dad 0xd7c5e552
+ 0x58a49994 0x7daa7fb6 0xf5c7032d 0x199c156c
+ 0xe42c6748 0x7ab9b557 0x547802b8 0xc606a059
+ 0x3d89ff21 0x4fcdec22 0xb1087ad2 0x5521be5a
+ 0x5bd9618f 0x93aabce7 0x28be0c32 0xcae8c149
+ 0xe98236c3 0xe4be458c 0x805a0a38 0xb300ceb7
+ 0x1dcb3642 0x33d87e03 0x81c17b3a 0xf8b59cd4
+ 0x9ed300eb 0x5e99acb6 0xab24565e 0xa7e9d72a
+ 0x92f97cf2 0xb61fa917 0xbc4167ea 0x5c37d1f6
+ 0xcd5200f3 0xc48dcdf1 0x3ba93fe4 0xf5045cec
+ 0xc09adede 0xdeef5953 0x1d7c6b08 0x77f2cd7c
+ 0x025d30ab 0x206b53a8 0x8140335f 0xed1751b1
+ 0x9fc265b6 0xdc56b2ba 0x6f60ddda 0xf92d7837
+ 0x3560dc91 0xed0140fd 0x12071a5e 0x397e7dba
+ 0x8d9c89b8 0x5f79e3f3 0x41add538 0xafce559e
+ 0x8956bcaa 0x76854169 0xac9d211d 0x1d9d2f47
+ 0xa4c8cf2f 0x0bdfa060 0x35ca5f3b 0x1ec524c5
+ 0x859b6ead 0xb3bd5250 0x1616fbf5 0xd18e5d38
+ 0x8b1b06a7 0x9b6e1a2b 0x128e9c72 0xbb672bb7
+ 0xd50b0234 0xfe1f75c3 0x40062da3 0x7b875ae3
+ 0xca401a1c 0x1668185e 0x25002654 0x314eb038
+ 0xd03a8be3 0x86717b8c 0x1bd58524 0xe17ba392
+ 0xaf90d12d 0x7b3afe6e 0xcad2b963 0xb91245fe
+ 0xe0c7c9f6 0xf98b3bd5 0x305bd207 0x713515d1
+ 0x4677d009 0x20e34228 0x6128d849 0x5fb620df
+ 0xe3274241 0xd3814ecd 0x223303a7 0xcba4f054
+ 0x73a34ab0 0x874fb4ce 0x390efd43 0x490a7a12
+ 0xa45a9d66 0xde80cd80 0x9a36beaa 0x2cfca0fc
+ 0x231f4d1d 0x04c1fad2 0x5ad83a8d 0xc2931f83
+ 0x97f63f61 0x38a6029c 0xe34de276 0x699fa28b
+ 0x458d2e15 0x67b57701 0x49385ab4 0x09417b0c
+ 0x18897b93 0x516f5749 0x4578a8ff 0x52fbda3e
+ 0x2da1dd8a 0xf22e616a 0x7806ab6e 0x92886668
+ 0xaf7e056f 0xd9a35959 0xf6ae0b16 0xa42d213d
+ 0x928ba1be 0xb61f8e2a 0x6635e3c8 0xbaf76f05
+ 0x693d4eb0 0x69546031 0x00427e2b 0x97e563bd
+ 0x2857d47f 0x28aaa688 0xf91ec5a8 0xd119289f
+ 0x721dc1df 0xdc40c94e 0x67e3d987 0xd2141380
+ 0x1bdb7023 0xa84158f3 0x5637a2a8 0x34f80708
+ 0x7d452316 0x7cdd1f84 0xe1d1633a 0x82d9f886
+ 0xad779cc7 0xd2ae85f9 0x0c467ac9 0x27c1d5f5
+ 0x1b28be66 0x34d759d5 0xbcb56ec9 0x171c3020
+ 0xac4319ce 0x68c1e8c2 0x3cb463cd 0x78a065bb
+ 0x5188b314 0xc8566dfa 0xc93094fc 0x28a21400
+ 0x9151a62d 0x678940c6 0x5023ed27 0x089290aa
+ 0x327f3b1d 0x7e3d9bc8 0x2c664ff5 0x32e58da7
+ 0xe998fd47 0x480411d0 0x9297db4c 0x182058ef
+ 0xe21c0a93 0xa32d2771 0x91199466 0xdb8694df
+ 0x6261f08c 0x3aff7da0 0x1e24865e 0xde2f7ebf
+ 0x1f570473 0x3ec320a3 0x3a8461b6 0x3e1c1e73
+ 0x862aa78e 0x74c9a73f 0x090973ab 0x248fb1fd
+ 0xebb1b73c 0xab8cc3d0 0xa80d3a86 0xb81c4992
+ 0x9f14bb10 0xef283b13 0x060ac416 0x03768c78
+ 0xab1a3b35 0xa8f7cf27 0x947beee4 0xdb6d4731
+ 0xbc6cebd4 0x39e3cd02 0x9ced359a 0x3358a905
+ 0xa4f31baf 0x56bb572c 0x0a8ccbde 0xe701126f
+ 0xad241a42 0xd66bafdf 0x5be07a77 0x4fa8a2ee
+ 0xff2a829e 0xbe7aa422 0x8ba9b94c 0x20fce978
+ 0x8086487b 0x66bf1d28 0x0e9a4b37 0xdf5836b6
+ 0xa6eb018c 0xf6a5ef16 0xcfb3b85f 0xa8bc1ecc
+ 0x3c5925ab 0x1c926d4a 0x60e2747c 0x629eb075
+ 0xbdcfea23 0x10443caa 0x5d005a9a 0x4a6235b1
+ 0x56b70ab3 0xff8cb97f 0x42828a8b 0x33692058
+ 0x4ce783ad 0x08d1c099 0xb14379df 0xd65d24dd
+ 0x14450585 0xbb0450d7 0xc8776287 0xea2eb9b6
+ 0xc44d73e2 0xcb386daf 0x9d3686a1 0xb58c318b
+ 0x287fbe53 0xe8d84535 0xbf17ef8f 0x98332fff
+ 0x5e098cbb 0x9ecc14a7 0x08366dbc 0x55028860
+ 0xc09e869f 0xa29a43e7 0x9be9daac 0xa1750a10
+ 0xb2fd8da5 0xf380c1cf 0x6087ff3c 0xd69bd21c
+ 0x7e14ede5 0xc0ed409f 0x12f25810 0x3f44d63e
+ 0x9e7b0cab 0xcb9cc71b 0x18b66ea5 0x80843c35
+ 0xf140a7ed 0x89fb323d 0x0a326c40 0xe3f9af29
+ 0xf6c59365 0xad3a2017 0x906d1ce2 0xd3360e1f
+ 0x046307dd 0x290ff1e8 0x910a9632 0x5cf471a7
+ 0x54321c10 0x12924fa3 0xff3d87e6 0xb1687618
+ 0xa2a68555 0x1a21d3bd 0x1095d6f9 0x349b25d0
+ 0x8166c94a 0x006c839e 0x0094b4e4 0xdd11f901
+ 0x1c40e7f0 0x50946c87 0x52bcea55 0x20b86a9c
+ 0x7b386df2 0xddd48f3d 0x421d417a 0x7052e089
+ 0x8ec43a4e 0x6174ca83 0x6b712d8e 0x566ae151
+ 0xc38d68a1 0xf7d64e87 0x9f53d487 0x5e985461
+ 0x21d27e2b 0xdbb9bf40 0x2826a5cc 0x6ca4d786
+ 0x381508b8 0xd8ffd839 0xa85f5b86 0xb37fa53d
+ 0xe4906f8f 0xc7329e0a 0xe56272aa 0xe7b97be8
+ 0xbd6a48dc 0x935e9f91 0x02313e13 0x026b8e36
+ 0x939a5293 0xe125a1a5 0x6b27d136 0x3d520ae7
+ 0x7abc1309 0x183f50f6 0x08575ed5 0x1d2c4c72
+ 0x0e682129 0x655ceb36 0x1a508349 0x3be034d9
+ 0x4bf83c5f 0x592520d0 0x5f65a0c2 0xcad74a35
+ 0x5c4e605a 0x973b60a3 0x309fc15b 0x3ea3781f
+ 0xb56c3172 0x269f8d75 0xebfa9293 0x9ff8bf36
+ 0x27bc0472 0x4a1888d1 0x598b47c1 0xba2d3073
+ 0xf71b310a 0xb9db5309 0x065ffaf8 0xeb21604b
+ 0x60875644 0x6f76cd48 0x47746357 0xbf2e90b5
+ 0x7d40e67d 0xe87f11ec 0xc5409f18 0x9904fefe
+ 0x9745644f 0xe1089f12 0xdc49f755 0xf0cd3596
+ 0xe9e69302 0x419b9a3b 0x3f0a6315 0x8b715e28
+ 0x363ede54 0xcd41a72f 0x0bafa9fe 0xd00225c7
+ 0x6e8d0407 0xd1f100b9 0x0cd02e9c 0x760a2ffd
+ 0x6ac6f01e 0xd2226e57 0xe7a7bd75 0x0bec05af
+ 0x72b4d6c9 0x54df0f5b 0xbcb2bb34 0x20364bf2
+ 0x9fc24cdf 0x83452f28 0x734248b7 0xc698bf34
+ 0xee328cdc 0x8e4bff33 0xa1addacd 0x07af68c8
+ 0xc34b5d25 0x8e611a0d 0xcbb8ff85 0x077c6d43
+ 0x95feb2a3 0xb435fffc 0xef5eca7a 0x0ff6045a
+ 0x449647ba 0x75795c99 0x9c514436 0xabbe74d9
+ 0xd180f18d 0xdcdeee76 0xa9550f7b 0xb4c8e109
+ 0x80b21662 0x8a407a0c 0xa6245b13 0xa16f44ac
+ 0xb3db67d3 0x0b335cfe 0xd878e875 0x81d6df28
+ 0x44871141 0x6a6dada5 0x7f97fcd0 0x7ee87f79
+ 0xddc5bcfa 0xfc2763db 0xb11a9212 0x94ba7acc
+ 0x49428749 0xd219071f 0xd91bc4c2 0x4ad5c326
+ 0x54ea2297 0xdb16bca5 0x33327f3f 0xc487b8c7
+ 0x54ca8d94 0x4c6f5655 0xf51c3911 0x37931433
+ 0xf6506856 0x6b5a93f8 0x388950b9 0xdf5263b5
+ 0xd4cf56ea 0x8da347e2 0xf20a9a39 0x1a6b8e4c
+ 0x2ce3df55 0x38269e78 0xdc7a9762 0x9e73a3dc
+ 0x57de6fa7 0x9c2573f5 0x3491629e 0x009452fe
+ 0x8a34ddd1 0x701df9ab 0x4035380c 0x6f25e16d
+ 0x0ca914de 0xf9277a06 0xca1f1fe3 0x95aec5b6
+ 0x7a613e97 0x52e77607 0xd7229ff0 0x5f301016
+ 0xd4e142c1 0x29a939cb 0xe96dd1ca 0xc953aec0
+ 0xbf02c31e 0x02135076 0x4f931dcb 0x4b280cd3
+ 0xe0cda493 0x70831c04 0x8192143c 0xc9f94a3b
+ 0x13eda1d1 0xc62c39ad 0x754a5411 0xe43ce416
+ 0x95ac1b10 0x871261dd 0x79f33a8a 0x77383224
+ 0x98b2480f 0x2df139d4 0xd753e53b 0xbad87b53
+ 0x977cc17f 0xacc4bb71 0xbde6b5f2 0x206562ae
+ 0xe0319086 0xcf903501 0x56ed1506 0x64f4556c
+ 0xb90bbe0f 0x2def02e5 0x9b625a9b 0x96086cce
+ 0x39d1d0ab 0x8c85c5d6 0xa8199040 0x23c770e2
+ 0xf5303bd0 0x51a83607 0x5afa1989 0x8a81b4ff
+ 0x1b24e6a4 0x4cb58014 0xbbee7d31 0x758271fd
+ 0x259bc3f5 0xb3f9c6eb 0xbd8c4f86 0x66c27a35
+ 0xa41c2904 0xc9848ce3 0x9ba21676 0x18f65508
+ 0xe5637556 0x031e21c0 0xc09e3c77 0x5f10856f
+ 0x9b3ea697 0xd8afe20b 0x447f5be1 0x5c4b1668
+ 0x71f44cc1 0x8637d0c6 0xbd182081 0x1e4221b4
+ 0xd312a403 0xf49d2c96 0x686ff9e1 0xa3f9b746
+ 0x3caeae90 0xf2bfb131 0x5823eb37 0xcd4edc6d
+ 0x3a7f65d8 0xbb4be9d3 0xd7939b2e 0x71d03a37
+ 0xa30ff63a 0xde7ccb57 0x8ea031ba 0xbcb3994d
+ 0x8018d6fb 0x1c7a3610 0xac900573 0x9ad05089
+ 0xe2d17d5e 0x7816b9a7 0xffcca5c1 0x9faa9a0c
+ 0xadbe99e6 0x06de7ee1 0xe4ac8981 0x29ef423c
+ 0x32219ad2 0x806642b8 0x412ab076 0xfe4c5196
+ 0x82c2507c 0xd58c7b7c 0xfe9edc9a 0x89e4c6e9
+ 0x4f122269 0xf0aeb2f1 0x77f4fbc0 0xe6692464
+ 0x6e64c198 0xaf79a455 0x01e2ed98 0x897ec1b0
+ 0xf7a0dd35 0x92baec5e 0x93f17b7e 0xfbf82b90
+ 0x168d32c5 0x741b61c0 0xb0f5b9b5 0x0557fb71
+ 0xca937e89 0xad652a2b 0x9a2121c8 0x34d189ca
+ 0x037dd1a3 0x3e650192 0x4defbaa7 0x06763750
+ 0x48d4d1b4 0xda2af400 0x7df71d63 0x3e0b4c46
+ 0x28c645bc 0x29b15428 0x34e10558 0x1166cdd6
+ 0xc259a364 0xdc7e0f21 0xb02cee35 0x3055f39b
+ 0xb77a50d2 0x2c143c84 0x7903e30c 0x018e20a8
+ 0xf95b4a26 0x38c84311 0x1f0c3098 0x535a95e7
+ 0x730214dd 0xb0f90f53 0x625fc5d1 0x2c1f2d76
+ 0x7c9b5351 0x5cc285f4 0x0f63b5f4 0x90d59d57
+ 0x140213fc 0xd21a74b7 0xf85fd83b 0xd9f21e94
+ 0xbbefcd30 0x5091f90f 0x8d5c47fc 0x9455364a
+ 0xef89f274 0x901af041 0x782cd03a 0x086f1f81
+ 0xe09eb4db 0xf7a8146c 0x41898271 0xe8be480c
+ 0xdfbac329 0x5fb899cd 0xfdca25e8 0xe994b3d8
+ 0x2299ede3 0xc0341512 0x0128eb87 0xd5cff619
+ 0x779bba38 0x1e986657 0xc22ac15c 0x919af309
+ 0xd3cd1df4 0xb4b22d9a 0x210c0617 0x5723f9e0
+ 0xb7b79328 0x613e738d 0x39057942 0x48d48958
+ 0xf9d80cc0 0x16f69a5c 0x6d517734 0x012f07fa
+ 0x7a8329e1 0x586b22c3 0xdd0d96b9 0x0c56d5f9
+ 0x60410aa3 0xd1975446 0xd2c142fa 0xb13ba75b
+ 0x0b046c21 0x03afb4e0 0x346f5dce 0xd108fa96
+ 0xd1ca963c 0x73f5838a 0x4b4f734f 0xa1d430a7
+ 0xd0cda381 0x64fecfee 0xc5048480 0xd3bfb251
+ 0x088982f9 0x2383aaee 0x9b9c8f48 0x623f2132
+ 0x0f5ae663 0x3c32959a 0xa1fd9ecc 0xf62d0e4c
+ 0xe690d930 0x6be7a286 0x825d0066 0xe51094ca
+ 0xc99affb8 0x832222ea 0xe7296513 0x2c040c86
+ 0x35f62e4f 0x6f46ba84 0x25cdb0a3 0xe8b6ec22
+ 0x5b6cf8d0 0xcfd85f8a 0xf0181633 0x5362c0b7
+ 0x58955c60 0xc5a36973 0x874d04eb 0xa42a42df
+ 0x4bd5d994 0xee6114f3 0x671ccecb 0xf0ae2422
+ 0x70c98042 0xf9ed2a1a 0x6b60f0c9 0x04b13374
+ 0x96fba002 0x8b481645 0x315198a2 0x65c80b9a
+ 0x31475dd9 0xe95c5c3a 0xe3c22d43 0x12659565
+ 0xabec6f96 0x9446e315 0xa6552f83 0x295e2596
+ 0x8b6a2d9f 0x71efb10e 0x2d309912 0xe3dd2879
+ 0xabd39f50 0xcfa94a90 0x61d282b7 0x062b246f
+ 0x617b7162 0x3628fffd 0x93c8c8a5 0xaa44c72a
+ 0x11b78bff 0x8259874a 0x186bbcfd 0x37bf7395
+ 0x6f8582a7 0x65fdd21b 0x53106cb5 0xbfbe1e4a
+ 0x1ed99eac 0x670b3763 0x245db7b2 0x7584d9be
+ 0xc3472009 0x572bddab 0x17e7406c 0x79e0ea4e
+ 0x74779fd3 0x92d0c51a 0x1808d006 0x46c1e76b
+ 0x40e48bf4 0x61e17325 0x1d437ab2 0xacf51c38
+ 0xc19eab2c 0x02957308 0x0bcc40bb 0xf603815f
+ 0x9c666571 0x6a7d539f 0x57f3941b 0x7af81d5c
+ 0xad1427b0 0xc188d623 0xac010003 0x1ff4cdf6
+ 0xfa504446 0x6425ba6c 0x27ff69fa 0x26da5613
+ 0xb6fc0a69 0x1155853e 0xbab81c6e 0x3dc17909
+ 0x07b209d9 0x8b269554 0x73fc8781 0xfc1c2c82
+ 0x572df087 0xb71bb5e5 0x55f9d202 0x6f525daf
+ 0x117755f9 0x52cce1bb 0xa789ed0e 0x1313ca47
+ 0xe8bdd878 0xc37e8dcb 0x53b971fc 0x43540a80
+ 0x3d2384a7 0x25ac992d 0x7aef31c8 0xb1294afd
+ 0xb0a34878 0x96e9ca1d 0x82a19bcd 0x08cd2bdf
+ 0xd2681e35 0x2d32fa5f 0xc7c0c8b2 0xeecd089d
+ 0x97404355 0x0b34539d 0x37ce4df3 0x599352dc
+ 0x06734f29 0xf47ab5d8 0xb15ea9a4 0xfd92ed2f
+ 0x9510bdbd 0xb740d34b 0xbac3e94a 0x52efbc03
+ 0x40bd7acb 0x1bf83a4f 0x3d76c698 0x7e691383
+ 0xec85e4ae 0x55e9a446 0x1fc3ab3b 0x6aea12fe
+ 0x8fab4a84 0x69cd7328 0x935a7236 0xc3f59437
+ 0xb73a7d8b 0xba0f54e0 0xe8e7aafc 0x6f82ade6
+ 0xed6ccaf0 0xdfddc46c 0x0763fc3e 0x778e488f
+ 0x0bcc4dce 0x8f919858 0xa7bc7d1a 0xd4954eea
+ 0x517b5458 0x6c3f5835 0xd960f76d 0xf5be65a7
+ 0x133666d9 0x4431f94f 0xccedf47d 0x6eb21ff8
+ 0xb858dfef 0x15beefef 0x9a1b6b6a 0x64890eda
+ 0x2a381329 0x660302bb 0xc65c001c 0x049a4be4
+ 0xfca1b112 0xb081a099 0x3a2217f8 0xeea9a2ef
+ 0x7719129c 0x7c915047 0xb3fe3e16 0xf1c31548
+ 0xfa84a76b 0xd7af5b51 0x0de24c14 0x89a7263d
+ 0x5a9dbffe 0x7ea90ae3 0xc21a2a1d 0x65ef3a3e
+ 0x90fd1fa0 0x69aa0d9b 0xb44a5778 0x5ded34b3
+ 0xa0d78617 0x91817661 0xf9541869 0xa0960273
+ 0x024d891a 0xbc9f6d7a 0x630bac04 0xd186ffe5
+ 0x0d60d640 0xc05e4701 0xba72d775 0xacec7c0c
+ 0x1680e76d 0x6b153d69 0xbcbd60c1 0x3e1ed6c6
+ 0x9705975b 0xaa3cc082 0xbdd723d0 0x7c0bbdd9
+ 0x2bcf8414 0x787b2dea 0xaf923561 0xe4ad94a2
+ 0xa85f83a1 0x1de0ddcf 0xd96f918b 0x617b1461
+ 0xb1d3e386 0xe8d80b5d 0x40dad53e 0xcd8fb285
+ 0x46fb4bae 0x2845c456 0x8b261251 0xf4923055
+ 0x99d0db1e 0x0d7cc781 0x9bb20af6 0x7116d81c
+ 0xd7f54821 0xba4eb2d0 0xaef6b275 0x3ca796cf
+ 0x8807360c 0xd887484b 0x7066ec38 0xf7262152
+ 0x5ede9cc5 0x6b8eb00c 0x5564b7af 0x4726dfd1
+ 0x9421fe95 0xcc0ff9e5 0x10ca7e89 0xb76760e6
+ 0x3da3a50a 0xf9cd3f82 0x1eb01d3c 0x13ae6371
+ 0x129747e6 0xab223504 0x9978c7e9 0x1f7ce259
+ 0xb17fb162 0xd1ac0e80 0xe04bfd17 0x197d9eac
+ 0x59586a32 0x7436e8ef 0xc28b1ec5 0x83af0dc7
+ 0x8382692e 0x17f04148 0x31ee5ad3 0xfe89b973
+ 0x0148467a 0x1a6a16ef 0xb6400bcd 0x53ae7036
+ 0x6b258693 0xb6edbeca 0x2ff0b686 0xe6f0c346
+ 0x0e0ff99c 0x8d369a6e 0x7d10411d 0x2ebccabc
+ 0xa67435d3 0xf9901563 0x363f164f 0xf01a1b15
+ 0x93b6a10f 0x81f0c068 0x89b8423d 0x60eb711a
+ 0x4e45bf98 0x24845e1e 0xda91d7f7 0x561e7ab1
+ 0x51a183de 0x73bf29a6 0xcdb20f84 0x46d5ab3d
+ 0xce01efbc 0x8d09be04 0xbf4aee2e 0xadf03a7b
+ 0xbc454c61 0x83647148 0xec9e834a 0x11527826
+ 0x2c7eb009 0xc6d7e3f4 0xbe8befd2 0xd3cc42a8
+ 0x0442b41e 0x89643506 0xfd1dc572 0x74b340bc
+ 0x686f6f6c 0x48b92189 0xe8f88be6 0xfc591dbf
+ 0x8b453678 0xea1fd8cc 0x659d57d9 0xb501f90c
+ 0xa6d6b031 0x182d8378 0xd6a8d690 0x6419c2b6
+ 0x523d3089 0xc23c971c 0x43994015 0xa4b23066
+ 0x831e6ca5 0x03c18610 0xd6d1f4b5 0x28978a3d
+ 0xdc620eba 0xc1f86faa 0xf6c4d906 0xf06f85f3
+ 0x232fa1bf 0xcf80cc2a 0x6599a5b2 0xc2d4cdad
+ 0x0287eb92 0x5cdc4dd6 0x34a9b6d4 0x6d4b1324
+ 0x6d21a837 0x00026037 0x80a225a8 0xad75b226
+ 0x414a3741 0xb74d0962 0x363b24b5 0xb5044295
+ 0x0a01c1a1 0x90a110c8 0x53bdeee5 0xad31aa53
+ 0xfb85cc5f 0xdf80b0f3 0x7ad3cb0f 0xb5c68bd6
+ 0x89185ff8 0x41544629 0xad5adfe7 0x39061752
+ 0x2e9c106c 0xbf52a0df 0x9d2cef79 0x99eba49d
+ 0x4459b32c 0xdc98fd7b 0xd81f2f74 0x8aa59f53
+ 0x1817857f 0x5f79e3bf 0xc4b7c810 0x9e3a9ddc
+ 0x724af115 0x121239e3 0x3c33c849 0xd8abb44d
+ 0x600d67b7 0xeaa06b4c 0x20fe7ba6 0x502c684b
+ 0xf212d37d 0x413d883a 0x5abc83ec 0x3112bb6e
+ 0x27e1b3e0 0xf6dc8508 0xfe602c4f 0xa5b34bce
+ 0x4d03d689 0xdacb23c2 0xa00fb513 0x78606ea8
+ 0x8fd43ecf 0x90072d2a 0xfcc7b1b9 0x7ffec951
+ 0x684bbc25 0xc21a0374 0x8f06a016 0x0e28dfea
+ 0x40da3a00 0x8c73a059 0xc0d565ef 0x13bb6c81
+ 0x6e27c2ec 0x2f4c9a43 0xae1b4513 0x9738b38a
+ 0x5557c3e1 0xa292c6ab 0xd0f78cea 0xb96402f7
+ 0x6c281a04 0x948787f9 0xe59f0714 0x6f130446
+ 0x4b12e263 0xcae5e073 0x00f0e279 0x9b03c647
+ 0x2a141b72 0x19d1e112 0x97b3b6df 0x3c2b6c82
+ 0x5b119136 0x57e2084c 0xe954bc0d 0xcdfbfa78
+ 0xadc6b571 0x010b9122 0x236676d6 0x2458c822
+ 0xcbb8384a 0x662cfd01 0x096c50d2 0x4959676b
+ 0xf8b59f31 0xad912a4d 0x2e87fa6e 0x30182092
+ 0xc0bf2c01 0x02b4bfa7 0xdd208dac 0x4c174da2
+ >;
diff --git a/arch/x86/dts/minnowmax.dts b/arch/x86/dts/minnowmax.dts
index daac24e..e917f0f 100644
--- a/arch/x86/dts/minnowmax.dts
+++ b/arch/x86/dts/minnowmax.dts
@@ -30,6 +30,33 @@
compatible = "intel,x86-pinctrl";
io-base = <0x4c>;
+ /* GPIO E0 */
+ soc_gpio_s5_0@0 {
+ gpio-offset = <0x80 0>;
+ pad-offset = <0x1d0>;
+ mode-gpio;
+ output-value = <0>;
+ direction = <PIN_OUTPUT>;
+ };
+
+ /* GPIO E1 */
+ soc_gpio_s5_1@0 {
+ gpio-offset = <0x80 1>;
+ pad-offset = <0x210>;
+ mode-gpio;
+ output-value = <0>;
+ direction = <PIN_OUTPUT>;
+ };
+
+ /* GPIO E2 */
+ soc_gpio_s5_2@0 {
+ gpio-offset = <0x80 2>;
+ pad-offset = <0x1e0>;
+ mode-gpio;
+ output-value = <0>;
+ direction = <PIN_OUTPUT>;
+ };
+
pin_usb_host_en0@0 {
gpio-offset = <0x80 8>;
pad-offset = <0x260>;
@@ -40,7 +67,7 @@
pin_usb_host_en1@0 {
gpio-offset = <0x80 9>;
- pad-offset = <0x258>;
+ pad-offset = <0x250>;
mode-gpio;
output-value = <1>;
direction = <PIN_OUTPUT>;
@@ -256,6 +283,9 @@
update@0 {
#include "microcode/m0130673322.dtsi"
};
+ update@1 {
+#include "microcode/m0130679901.dtsi"
+ };
};
};
diff --git a/arch/x86/include/asm/acpi_table.h b/arch/x86/include/asm/acpi_table.h
new file mode 100644
index 0000000..0853248
--- /dev/null
+++ b/arch/x86/include/asm/acpi_table.h
@@ -0,0 +1,393 @@
+/*
+ * Based on acpi.c from coreboot
+ *
+ * Copyright (C) 2015, Saket Sinha <saket.sinha89@gmail.com>
+ *
+ * SPDX-License-Identifier: GPL-2.0+
+ */
+
+#include <common.h>
+#include <malloc.h>
+#include <asm/post.h>
+#include <linux/string.h>
+
+#define RSDP_SIG "RSD PTR " /* RSDT pointer signature */
+#define ACPI_TABLE_CREATOR "UBOOT " /* Must be 8 bytes long! */
+#define OEM_ID "UBOOT " /* Must be 6 bytes long! */
+#define ASLC "INTL" /* Must be 4 bytes long! */
+
+#define OEM_REVISION 42
+#define ASL_COMPILER_REVISION 42
+
+/* IO ports to generate SMIs */
+#define APM_CNT 0xb2
+#define APM_CNT_CST_CONTROL 0x85
+#define APM_CNT_PST_CONTROL 0x80
+#define APM_CNT_ACPI_DISABLE 0x1e
+#define APM_CNT_ACPI_ENABLE 0xe1
+#define APM_CNT_MBI_UPDATE 0xeb
+#define APM_CNT_GNVS_UPDATE 0xea
+#define APM_CNT_FINALIZE 0xcb
+#define APM_CNT_LEGACY 0xcc
+#define APM_ST 0xb3
+
+/* Multiple Processor Interrupts */
+#define MP_IRQ_POLARITY_DEFAULT 0x0
+#define MP_IRQ_POLARITY_HIGH 0x1
+#define MP_IRQ_POLARITY_LOW 0x3
+#define MP_IRQ_POLARITY_MASK 0x3
+#define MP_IRQ_TRIGGER_DEFAULT 0x0
+#define MP_IRQ_TRIGGER_EDGE 0x4
+#define MP_IRQ_TRIGGER_LEVEL 0xc
+#define MP_IRQ_TRIGGER_MASK 0xc
+
+/*
+ * Interrupt assigned for SCI in order to
+ * create the ACPI MADT IRQ override entry
+ */
+#define ACTL 0x00
+#define SCIS_MASK 0x07
+#define SCIS_IRQ9 0x00
+#define SCIS_IRQ10 0x01
+#define SCIS_IRQ11 0x02
+#define SCIS_IRQ20 0x04
+#define SCIS_IRQ21 0x05
+#define SCIS_IRQ22 0x06
+#define SCIS_IRQ23 0x07
+
+#define ACPI_REV_ACPI_1_0 1
+#define ACPI_REV_ACPI_2_0 1
+#define ACPI_REV_ACPI_3_0 2
+#define ACPI_REV_ACPI_4_0 3
+#define ACPI_REV_ACPI_5_0 5
+
+#define ACPI_RSDP_REV_ACPI_1_0 0
+#define ACPI_RSDP_REV_ACPI_2_0 2
+
+typedef struct acpi_gen_regaddr {
+ u8 space_id; /* Address space ID */
+ u8 bit_width; /* Register size in bits */
+ u8 bit_offset; /* Register bit offset */
+ union {
+ /* Reserved in ACPI 2.0 - 2.0b */
+ u8 resv;
+ /* Access size in ACPI 2.0c/3.0/4.0/5.0 */
+ u8 access_size;
+ };
+ u32 addrl; /* Register address, low 32 bits */
+ u32 addrh; /* Register address, high 32 bits */
+} acpi_addr_t;
+
+
+/*
+ * RSDP (Root System Description Pointer)
+ * Note: ACPI 1.0 didn't have length, xsdt_address, and ext_checksum
+ */
+struct acpi_rsdp {
+ char signature[8]; /* RSDP signature */
+ u8 checksum; /* Checksum of the first 20 bytes */
+ char oem_id[6]; /* OEM ID */
+ u8 revision; /* 0 for ACPI 1.0, 2 for ACPI 2.0/3.0/4.0 */
+ u32 rsdt_address; /* Physical address of RSDT (32 bits) */
+ u32 length; /* Total RSDP length (incl. extended part) */
+ u64 xsdt_address; /* Physical address of XSDT (64 bits) */
+ u8 ext_checksum; /* Checksum of the whole table */
+ u8 reserved[3];
+};
+
+enum acpi_address_space_type {
+ ACPI_ADDRESS_SPACE_MEMORY = 0, /* System memory */
+ ACPI_ADDRESS_SPACE_IO, /* System I/O */
+ ACPI_ADDRESS_SPACE_PCI, /* PCI config space */
+ ACPI_ADDRESS_SPACE_EC, /* Embedded controller */
+ ACPI_ADDRESS_SPACE_SMBUS, /* SMBus */
+ ACPI_ADDRESS_SPACE_PCC = 0x0a, /* Platform Comm. Channel */
+ ACPI_ADDRESS_SPACE_FIXED = 0x7f /* Functional fixed hardware */
+};
+
+/* functional fixed hardware */
+#define ACPI_FFIXEDHW_VENDOR_INTEL 1 /* Intel */
+#define ACPI_FFIXEDHW_CLASS_HLT 0 /* C1 Halt */
+#define ACPI_FFIXEDHW_CLASS_IO_HLT 1 /* C1 I/O then Halt */
+#define ACPI_FFIXEDHW_CLASS_MWAIT 2 /* MWAIT Native C-state */
+#define ACPI_FFIXEDHW_FLAG_HW_COORD 1 /* Hardware Coordination bit */
+#define ACPI_FFIXEDHW_FLAG_BM_STS 2 /* BM_STS avoidance bit */
+
+/* Access size definitions for Generic address structure */
+enum acpi_address_space_size {
+ ACPI_ACCESS_SIZE_UNDEFINED = 0, /* Undefined (legacy reasons) */
+ ACPI_ACCESS_SIZE_BYTE_ACCESS = 1,
+ ACPI_ACCESS_SIZE_WORD_ACCESS = 2,
+ ACPI_ACCESS_SIZE_DWORD_ACCESS = 3,
+ ACPI_ACCESS_SIZE_QWORD_ACCESS = 4
+};
+
+/* Generic ACPI header, provided by (almost) all tables */
+typedef struct acpi_table_header {
+ char signature[4]; /* ACPI signature (4 ASCII characters) */
+ u32 length; /* Table length in bytes (incl. header) */
+ u8 revision; /* Table version (not ACPI version!) */
+ volatile u8 checksum; /* To make sum of entire table == 0 */
+ char oem_id[6]; /* OEM identification */
+ char oem_table_id[8]; /* OEM table identification */
+ u32 oem_revision; /* OEM revision number */
+ char asl_compiler_id[4]; /* ASL compiler vendor ID */
+ u32 asl_compiler_revision; /* ASL compiler revision number */
+} acpi_header_t;
+
+/* A maximum number of 32 ACPI tables ought to be enough for now */
+#define MAX_ACPI_TABLES 32
+
+/* RSDT (Root System Description Table) */
+struct acpi_rsdt {
+ struct acpi_table_header header;
+ u32 entry[MAX_ACPI_TABLES];
+};
+
+/* XSDT (Extended System Description Table) */
+struct acpi_xsdt {
+ struct acpi_table_header header;
+ u64 entry[MAX_ACPI_TABLES];
+};
+
+/* MCFG (PCI Express MMIO config space BAR description table) */
+struct acpi_mcfg {
+ struct acpi_table_header header;
+ u8 reserved[8];
+};
+
+struct acpi_mcfg_mmconfig {
+ u32 base_address;
+ u32 base_reserved;
+ u16 pci_segment_group_number;
+ u8 start_bus_number;
+ u8 end_bus_number;
+ u8 reserved[4];
+};
+
+/* MADT (Multiple APIC Description Table) */
+struct acpi_madt {
+ struct acpi_table_header header;
+ u32 lapic_addr; /* Local APIC address */
+ u32 flags; /* Multiple APIC flags */
+} acpi_madt_t;
+
+enum dev_scope_type {
+ SCOPE_PCI_ENDPOINT = 1,
+ SCOPE_PCI_SUB = 2,
+ SCOPE_IOAPIC = 3,
+ SCOPE_MSI_HPET = 4
+};
+
+typedef struct dev_scope {
+ u8 type;
+ u8 length;
+ u8 reserved[2];
+ u8 enumeration;
+ u8 start_bus;
+ struct {
+ u8 dev;
+ u8 fn;
+ } path[0];
+} __packed dev_scope_t;
+
+/* MADT: APIC Structure Type*/
+enum acpi_apic_types {
+ LOCALAPIC = 0, /* Processor local APIC */
+ IOAPIC, /* I/O APIC */
+ IRQSOURCEOVERRIDE, /* Interrupt source override */
+ NMITYPE, /* NMI source */
+ LOCALNMITYPE, /* Local APIC NMI */
+ LAPICADDRESSOVERRIDE, /* Local APIC address override */
+ IOSAPIC, /* I/O SAPIC */
+ LOCALSAPIC, /* Local SAPIC */
+ PLATFORMIRQSOURCES, /* Platform interrupt sources */
+ LOCALX2SAPIC, /* Processor local x2APIC */
+ LOCALX2APICNMI, /* Local x2APIC NMI */
+};
+
+/* MADT: Processor Local APIC Structure */
+struct acpi_madt_lapic {
+ u8 type; /* Type (0) */
+ u8 length; /* Length in bytes (8) */
+ u8 processor_id; /* ACPI processor ID */
+ u8 apic_id; /* Local APIC ID */
+ u32 flags; /* Local APIC flags */
+};
+
+#define LOCAL_APIC_FLAG_ENABLED (1 << 0)
+/* bits 1-31: reserved */
+#define PCAT_COMPAT (1 << 0)
+/* bits 1-31: reserved */
+
+/* MADT: Local APIC NMI Structure */
+struct acpi_madt_lapic_nmi {
+ u8 type; /* Type (4) */
+ u8 length; /* Length in bytes (6) */
+ u8 processor_id; /* ACPI processor ID */
+ u16 flags; /* MPS INTI flags */
+ u8 lint; /* Local APIC LINT# */
+};
+
+/* MADT: I/O APIC Structure */
+struct acpi_madt_ioapic {
+ u8 type; /* Type (1) */
+ u8 length; /* Length in bytes (12) */
+ u8 ioapic_id; /* I/O APIC ID */
+ u8 reserved;
+ u32 ioapic_addr; /* I/O APIC address */
+ u32 gsi_base; /* Global system interrupt base */
+};
+
+/* MADT: Interrupt Source Override Structure */
+struct acpi_madt_irqoverride {
+ u8 type; /* Type (2) */
+ u8 length; /* Length in bytes (10) */
+ u8 bus; /* ISA (0) */
+ u8 source; /* Bus-relative int. source (IRQ) */
+ u32 gsirq; /* Global system interrupt */
+ u16 flags; /* MPS INTI flags */
+};
+
+/* FADT (Fixed ACPI Description Table) */
+struct __packed acpi_fadt {
+ struct acpi_table_header header;
+ u32 firmware_ctrl;
+ u32 dsdt;
+ u8 model;
+ u8 preferred_pm_profile;
+ u16 sci_int;
+ u32 smi_cmd;
+ u8 acpi_enable;
+ u8 acpi_disable;
+ u8 s4bios_req;
+ u8 pstate_cnt;
+ u32 pm1a_evt_blk;
+ u32 pm1b_evt_blk;
+ u32 pm1a_cnt_blk;
+ u32 pm1b_cnt_blk;
+ u32 pm2_cnt_blk;
+ u32 pm_tmr_blk;
+ u32 gpe0_blk;
+ u32 gpe1_blk;
+ u8 pm1_evt_len;
+ u8 pm1_cnt_len;
+ u8 pm2_cnt_len;
+ u8 pm_tmr_len;
+ u8 gpe0_blk_len;
+ u8 gpe1_blk_len;
+ u8 gpe1_base;
+ u8 cst_cnt;
+ u16 p_lvl2_lat;
+ u16 p_lvl3_lat;
+ u16 flush_size;
+ u16 flush_stride;
+ u8 duty_offset;
+ u8 duty_width;
+ u8 day_alrm;
+ u8 mon_alrm;
+ u8 century;
+ u16 iapc_boot_arch;
+ u8 res2;
+ u32 flags;
+ struct acpi_gen_regaddr reset_reg;
+ u8 reset_value;
+ u8 res3;
+ u8 res4;
+ u8 res5;
+ u32 x_firmware_ctl_l;
+ u32 x_firmware_ctl_h;
+ u32 x_dsdt_l;
+ u32 x_dsdt_h;
+ struct acpi_gen_regaddr x_pm1a_evt_blk;
+ struct acpi_gen_regaddr x_pm1b_evt_blk;
+ struct acpi_gen_regaddr x_pm1a_cnt_blk;
+ struct acpi_gen_regaddr x_pm1b_cnt_blk;
+ struct acpi_gen_regaddr x_pm2_cnt_blk;
+ struct acpi_gen_regaddr x_pm_tmr_blk;
+ struct acpi_gen_regaddr x_gpe0_blk;
+ struct acpi_gen_regaddr x_gpe1_blk;
+};
+
+/* Flags for p_lvl2_lat and p_lvl3_lat */
+#define ACPI_FADT_C2_NOT_SUPPORTED 101
+#define ACPI_FADT_C3_NOT_SUPPORTED 1001
+
+/* FADT Feature Flags */
+#define ACPI_FADT_WBINVD (1 << 0)
+#define ACPI_FADT_WBINVD_FLUSH (1 << 1)
+#define ACPI_FADT_C1_SUPPORTED (1 << 2)
+#define ACPI_FADT_C2_MP_SUPPORTED (1 << 3)
+#define ACPI_FADT_POWER_BUTTON (1 << 4)
+#define ACPI_FADT_SLEEP_BUTTON (1 << 5)
+#define ACPI_FADT_FIXED_RTC (1 << 6)
+#define ACPI_FADT_S4_RTC_WAKE (1 << 7)
+#define ACPI_FADT_32BIT_TIMER (1 << 8)
+#define ACPI_FADT_DOCKING_SUPPORTED (1 << 9)
+#define ACPI_FADT_RESET_REGISTER (1 << 10)
+#define ACPI_FADT_SEALED_CASE (1 << 11)
+#define ACPI_FADT_HEADLESS (1 << 12)
+#define ACPI_FADT_SLEEP_TYPE (1 << 13)
+#define ACPI_FADT_PCI_EXPRESS_WAKE (1 << 14)
+#define ACPI_FADT_PLATFORM_CLOCK (1 << 15)
+#define ACPI_FADT_S4_RTC_VALID (1 << 16)
+#define ACPI_FADT_REMOTE_POWER_ON (1 << 17)
+#define ACPI_FADT_APIC_CLUSTER (1 << 18)
+#define ACPI_FADT_APIC_PHYSICAL (1 << 19)
+/* Bits 20-31: reserved ACPI 3.0 & 4.0 */
+#define ACPI_FADT_HW_REDUCED_ACPI (1 << 20)
+#define ACPI_FADT_LOW_PWR_IDLE_S0 (1 << 21)
+/* bits 22-31: reserved ACPI 5.0 */
+
+/* FADT Boot Architecture Flags */
+#define ACPI_FADT_LEGACY_DEVICES (1 << 0)
+#define ACPI_FADT_8042 (1 << 1)
+#define ACPI_FADT_VGA_NOT_PRESENT (1 << 2)
+#define ACPI_FADT_MSI_NOT_SUPPORTED (1 << 3)
+#define ACPI_FADT_NO_PCIE_ASPM_CONTROL (1 << 4)
+/* No legacy devices (including 8042) */
+#define ACPI_FADT_LEGACY_FREE 0x00
+
+/* FADT Preferred Power Management Profile */
+#define PM_UNSPECIFIED 0
+#define PM_DESKTOP 1
+#define PM_MOBILE 2
+#define PM_WORKSTATION 3
+#define PM_ENTERPRISE_SERVER 4
+#define PM_SOHO_SERVER 5
+#define PM_APPLIANCE_PC 6
+#define PM_PERFORMANCE_SERVER 7
+#define PM_TABLET 8 /* ACPI 5.0 */
+
+/* FACS (Firmware ACPI Control Structure) */
+struct acpi_facs {
+ char signature[4]; /* "FACS" */
+ u32 length; /* Length in bytes (>= 64) */
+ u32 hardware_signature; /* Hardware signature */
+ u32 firmware_waking_vector; /* Firmware waking vector */
+ u32 global_lock; /* Global lock */
+ u32 flags; /* FACS flags */
+ u32 x_firmware_waking_vector_l; /* X FW waking vector, low */
+ u32 x_firmware_waking_vector_h; /* X FW waking vector, high */
+ u8 version; /* ACPI 4.0: 2 */
+ u8 resv[31]; /* FIXME: 4.0: ospm_flags */
+};
+
+/* FACS flags */
+#define ACPI_FACS_S4BIOS_F (1 << 0)
+#define ACPI_FACS_64BIT_WAKE_F (1 << 1)
+/* Bits 31..2: reserved */
+
+/* These can be used by the target port */
+
+unsigned long acpi_create_madt_lapics(unsigned long current);
+int acpi_create_madt_ioapic(struct acpi_madt_ioapic *ioapic, u8 id, u32 addr,
+ u32 gsi_base);
+int acpi_create_madt_irqoverride(struct acpi_madt_irqoverride *irqoverride,
+ u8 bus, u8 source, u32 gsirq, u16 flags);
+unsigned long acpi_fill_madt(unsigned long current);
+void acpi_create_fadt(struct acpi_fadt *fadt, struct acpi_facs *facs,
+ void *dsdt);
+int acpi_create_madt_lapic_nmi(struct acpi_madt_lapic_nmi *lapic_nmi, u8 cpu,
+ u16 flags, u8 lint);
+unsigned long write_acpi_tables(unsigned long start);
diff --git a/arch/x86/include/asm/arch-coreboot/sysinfo.h b/arch/x86/include/asm/arch-coreboot/sysinfo.h
index 832c50a..2d57245 100644
--- a/arch/x86/include/asm/arch-coreboot/sysinfo.h
+++ b/arch/x86/include/asm/arch-coreboot/sysinfo.h
@@ -9,15 +9,12 @@
#ifndef _COREBOOT_SYSINFO_H
#define _COREBOOT_SYSINFO_H
-#include <common.h>
-#include <linux/compiler.h>
-#include <libfdt.h>
#include <asm/arch/tables.h>
-/* Allow a maximum of 16 memory range definitions. */
-#define SYSINFO_MAX_MEM_RANGES 16
+/* Maximum number of memory range definitions */
+#define SYSINFO_MAX_MEM_RANGES 32
/* Allow a maximum of 8 GPIOs */
-#define SYSINFO_MAX_GPIOS 8
+#define SYSINFO_MAX_GPIOS 8
struct sysinfo_t {
int n_memranges;
diff --git a/arch/x86/include/asm/ibmpc.h b/arch/x86/include/asm/ibmpc.h
index 678cde4..1e9058c 100644
--- a/arch/x86/include/asm/ibmpc.h
+++ b/arch/x86/include/asm/ibmpc.h
@@ -24,4 +24,7 @@
#define UART0_IRQ 4
#define UART1_IRQ 3
+#define KBD_IRQ 1
+#define MSE_IRQ 12
+
#endif
diff --git a/arch/x86/include/asm/init_helpers.h b/arch/x86/include/asm/init_helpers.h
index 8cbe08e..c689a63 100644
--- a/arch/x86/include/asm/init_helpers.h
+++ b/arch/x86/include/asm/init_helpers.h
@@ -8,8 +8,6 @@
#ifndef _INIT_HELPERS_H_
#define _INIT_HELPERS_H_
-int calculate_relocation_address(void);
-
int init_cache_f_r(void);
int init_bd_struct_r(void);
int init_func_spi(void);
diff --git a/arch/x86/lib/Makefile b/arch/x86/lib/Makefile
index dcfe9ee..6ecd6db 100644
--- a/arch/x86/lib/Makefile
+++ b/arch/x86/lib/Makefile
@@ -30,6 +30,7 @@
obj-$(CONFIG_X86_RAMTEST) += ramtest.o
obj-y += sfi.o
obj-y += string.o
+obj-$(CONFIG_GENERATE_ACPI_TABLE) += acpi_table.o
obj-y += tables.o
obj-$(CONFIG_SYS_X86_TSC_TIMER) += tsc_timer.o
obj-$(CONFIG_CMD_ZBOOT) += zimage.o
diff --git a/arch/x86/lib/acpi_table.c b/arch/x86/lib/acpi_table.c
new file mode 100644
index 0000000..ab1db7e
--- /dev/null
+++ b/arch/x86/lib/acpi_table.c
@@ -0,0 +1,436 @@
+/*
+ * Based on acpi.c from coreboot
+ *
+ * Copyright (C) 2015, Saket Sinha <saket.sinha89@gmail.com>
+ *
+ * SPDX-License-Identifier: GPL-2.0+
+ */
+
+#include <common.h>
+#include <cpu.h>
+#include <dm.h>
+#include <dm/uclass-internal.h>
+#include <dm/lists.h>
+#include <asm/acpi_table.h>
+#include <asm/cpu.h>
+#include <asm/ioapic.h>
+#include <asm/lapic.h>
+#include <asm/tables.h>
+#include <asm/pci.h>
+
+/*
+ * IASL compiles the dsdt entries and
+ * writes the hex values to AmlCode array.
+ * CamelCase cannot be handled here.
+ */
+extern const unsigned char AmlCode[];
+
+/**
+* Add an ACPI table to the RSDT (and XSDT) structure, recalculate length
+* and checksum.
+*/
+static void acpi_add_table(struct acpi_rsdp *rsdp, void *table)
+{
+ int i, entries_num;
+ struct acpi_rsdt *rsdt;
+ struct acpi_xsdt *xsdt = NULL;
+
+ /* The RSDT is mandatory while the XSDT is not */
+ rsdt = (struct acpi_rsdt *)rsdp->rsdt_address;
+
+ if (rsdp->xsdt_address)
+ xsdt = (struct acpi_xsdt *)((u32)rsdp->xsdt_address);
+
+ /* This should always be MAX_ACPI_TABLES */
+ entries_num = ARRAY_SIZE(rsdt->entry);
+
+ for (i = 0; i < entries_num; i++) {
+ if (rsdt->entry[i] == 0)
+ break;
+ }
+
+ if (i >= entries_num) {
+ debug("ACPI: Error: too many tables.\n");
+ return;
+ }
+
+ /* Add table to the RSDT */
+ rsdt->entry[i] = (u32)table;
+
+ /* Fix RSDT length or the kernel will assume invalid entries */
+ rsdt->header.length = sizeof(acpi_header_t) + (sizeof(u32) * (i + 1));
+
+ /* Re-calculate checksum */
+ rsdt->header.checksum = 0;
+ rsdt->header.checksum = table_compute_checksum((u8 *)rsdt,
+ rsdt->header.length);
+
+ /*
+ * And now the same thing for the XSDT. We use the same index as for
+ * now we want the XSDT and RSDT to always be in sync in U-Boot
+ */
+ if (xsdt) {
+ /* Add table to the XSDT */
+ xsdt->entry[i] = (u64)(u32)table;
+
+ /* Fix XSDT length */
+ xsdt->header.length = sizeof(acpi_header_t) +
+ (sizeof(u64) * (i + 1));
+
+ /* Re-calculate checksum */
+ xsdt->header.checksum = 0;
+ xsdt->header.checksum = table_compute_checksum((u8 *)xsdt,
+ xsdt->header.length);
+ }
+}
+
+static int acpi_create_madt_lapic(struct acpi_madt_lapic *lapic,
+ u8 cpu, u8 apic)
+{
+ lapic->type = LOCALAPIC; /* Local APIC structure */
+ lapic->length = sizeof(struct acpi_madt_lapic);
+ lapic->flags = LOCAL_APIC_FLAG_ENABLED; /* Processor/LAPIC enabled */
+ lapic->processor_id = cpu;
+ lapic->apic_id = apic;
+
+ return lapic->length;
+}
+
+unsigned long acpi_create_madt_lapics(unsigned long current)
+{
+ struct udevice *dev;
+
+ for (uclass_find_first_device(UCLASS_CPU, &dev);
+ dev;
+ uclass_find_next_device(&dev)) {
+ struct cpu_platdata *plat = dev_get_parent_platdata(dev);
+
+ current += acpi_create_madt_lapic(
+ (struct acpi_madt_lapic *)current,
+ plat->cpu_id, plat->cpu_id);
+ }
+ return current;
+}
+
+int acpi_create_madt_ioapic(struct acpi_madt_ioapic *ioapic, u8 id, u32 addr,
+ u32 gsi_base)
+{
+ ioapic->type = IOAPIC;
+ ioapic->length = sizeof(struct acpi_madt_ioapic);
+ ioapic->reserved = 0x00;
+ ioapic->gsi_base = gsi_base;
+ ioapic->ioapic_id = id;
+ ioapic->ioapic_addr = addr;
+
+ return ioapic->length;
+}
+
+int acpi_create_madt_irqoverride(struct acpi_madt_irqoverride *irqoverride,
+ u8 bus, u8 source, u32 gsirq, u16 flags)
+{
+ irqoverride->type = IRQSOURCEOVERRIDE;
+ irqoverride->length = sizeof(struct acpi_madt_irqoverride);
+ irqoverride->bus = bus;
+ irqoverride->source = source;
+ irqoverride->gsirq = gsirq;
+ irqoverride->flags = flags;
+
+ return irqoverride->length;
+}
+
+int acpi_create_madt_lapic_nmi(struct acpi_madt_lapic_nmi *lapic_nmi,
+ u8 cpu, u16 flags, u8 lint)
+{
+ lapic_nmi->type = LOCALNMITYPE;
+ lapic_nmi->length = sizeof(struct acpi_madt_lapic_nmi);
+ lapic_nmi->flags = flags;
+ lapic_nmi->processor_id = cpu;
+ lapic_nmi->lint = lint;
+
+ return lapic_nmi->length;
+}
+
+static void fill_header(acpi_header_t *header, char *signature, int length)
+{
+ memcpy(header->signature, signature, length);
+ memcpy(header->oem_id, OEM_ID, 6);
+ memcpy(header->oem_table_id, ACPI_TABLE_CREATOR, 8);
+ memcpy(header->asl_compiler_id, ASLC, 4);
+}
+
+static void acpi_create_madt(struct acpi_madt *madt)
+{
+ acpi_header_t *header = &(madt->header);
+ unsigned long current = (unsigned long)madt + sizeof(struct acpi_madt);
+
+ memset((void *)madt, 0, sizeof(struct acpi_madt));
+
+ /* Fill out header fields */
+ fill_header(header, "APIC", 4);
+ header->length = sizeof(struct acpi_madt);
+
+ /* ACPI 1.0/2.0: 1, ACPI 3.0: 2, ACPI 4.0: 3 */
+ header->revision = ACPI_REV_ACPI_2_0;
+
+ madt->lapic_addr = LAPIC_DEFAULT_BASE;
+ madt->flags = PCAT_COMPAT;
+
+ current = acpi_fill_madt(current);
+
+ /* (Re)calculate length and checksum */
+ header->length = current - (unsigned long)madt;
+
+ header->checksum = table_compute_checksum((void *)madt, header->length);
+}
+
+static int acpi_create_mcfg_mmconfig(struct acpi_mcfg_mmconfig *mmconfig,
+ u32 base, u16 seg_nr, u8 start, u8 end)
+{
+ memset(mmconfig, 0, sizeof(*mmconfig));
+ mmconfig->base_address = base;
+ mmconfig->base_reserved = 0;
+ mmconfig->pci_segment_group_number = seg_nr;
+ mmconfig->start_bus_number = start;
+ mmconfig->end_bus_number = end;
+
+ return sizeof(struct acpi_mcfg_mmconfig);
+}
+
+static unsigned long acpi_fill_mcfg(unsigned long current)
+{
+ current += acpi_create_mcfg_mmconfig
+ ((struct acpi_mcfg_mmconfig *)current,
+ CONFIG_PCIE_ECAM_BASE, 0x0, 0x0, 255);
+
+ return current;
+}
+
+/* MCFG is defined in the PCI Firmware Specification 3.0 */
+static void acpi_create_mcfg(struct acpi_mcfg *mcfg)
+{
+ acpi_header_t *header = &(mcfg->header);
+ unsigned long current = (unsigned long)mcfg + sizeof(struct acpi_mcfg);
+
+ memset((void *)mcfg, 0, sizeof(struct acpi_mcfg));
+
+ /* Fill out header fields */
+ fill_header(header, "MCFG", 4);
+ header->length = sizeof(struct acpi_mcfg);
+
+ /* ACPI 1.0/2.0: 1, ACPI 3.0: 2, ACPI 4.0: 3 */
+ header->revision = ACPI_REV_ACPI_2_0;
+
+ current = acpi_fill_mcfg(current);
+
+ /* (Re)calculate length and checksum */
+ header->length = current - (unsigned long)mcfg;
+ header->checksum = table_compute_checksum((void *)mcfg, header->length);
+}
+
+static void acpi_create_facs(struct acpi_facs *facs)
+{
+ memset((void *)facs, 0, sizeof(struct acpi_facs));
+
+ memcpy(facs->signature, "FACS", 4);
+ facs->length = sizeof(struct acpi_facs);
+ facs->hardware_signature = 0;
+ facs->firmware_waking_vector = 0;
+ facs->global_lock = 0;
+ facs->flags = 0;
+ facs->x_firmware_waking_vector_l = 0;
+ facs->x_firmware_waking_vector_h = 0;
+ facs->version = 1; /* ACPI 1.0: 0, ACPI 2.0/3.0: 1, ACPI 4.0: 2 */
+}
+
+static void acpi_write_rsdt(struct acpi_rsdt *rsdt)
+{
+ acpi_header_t *header = &(rsdt->header);
+
+ /* Fill out header fields */
+ fill_header(header, "RSDT", 4);
+ header->length = sizeof(struct acpi_rsdt);
+
+ /* ACPI 1.0/2.0: 1, ACPI 3.0: 2, ACPI 4.0: 3 */
+ header->revision = ACPI_REV_ACPI_2_0;
+
+ /* Entries are filled in later, we come with an empty set */
+
+ /* Fix checksum */
+ header->checksum = table_compute_checksum((void *)rsdt,
+ sizeof(struct acpi_rsdt));
+}
+
+static void acpi_write_xsdt(struct acpi_xsdt *xsdt)
+{
+ acpi_header_t *header = &(xsdt->header);
+
+ /* Fill out header fields */
+ fill_header(header, "XSDT", 4);
+ header->length = sizeof(struct acpi_xsdt);
+
+ /* ACPI 1.0/2.0: 1, ACPI 3.0: 2, ACPI 4.0: 3 */
+ header->revision = ACPI_REV_ACPI_2_0;
+
+ /* Entries are filled in later, we come with an empty set */
+
+ /* Fix checksum */
+ header->checksum = table_compute_checksum((void *)xsdt,
+ sizeof(struct acpi_xsdt));
+}
+
+static void acpi_write_rsdp(struct acpi_rsdp *rsdp, struct acpi_rsdt *rsdt,
+ struct acpi_xsdt *xsdt)
+{
+ memset(rsdp, 0, sizeof(struct acpi_rsdp));
+
+ memcpy(rsdp->signature, RSDP_SIG, 8);
+ memcpy(rsdp->oem_id, OEM_ID, 6);
+
+ rsdp->length = sizeof(struct acpi_rsdp);
+ rsdp->rsdt_address = (u32)rsdt;
+
+ /*
+ * Revision: ACPI 1.0: 0, ACPI 2.0/3.0/4.0: 2
+ *
+ * Some OSes expect an XSDT to be present for RSD PTR revisions >= 2.
+ * If we don't have an ACPI XSDT, force ACPI 1.0 (and thus RSD PTR
+ * revision 0)
+ */
+ if (xsdt == NULL) {
+ rsdp->revision = ACPI_RSDP_REV_ACPI_1_0;
+ } else {
+ rsdp->xsdt_address = (u64)(u32)xsdt;
+ rsdp->revision = ACPI_RSDP_REV_ACPI_2_0;
+ }
+
+ /* Calculate checksums */
+ rsdp->checksum = table_compute_checksum((void *)rsdp, 20);
+ rsdp->ext_checksum = table_compute_checksum((void *)rsdp,
+ sizeof(struct acpi_rsdp));
+}
+
+static void acpi_create_ssdt_generator(acpi_header_t *ssdt,
+ const char *oem_table_id)
+{
+ unsigned long current = (unsigned long)ssdt + sizeof(acpi_header_t);
+
+ memset((void *)ssdt, 0, sizeof(acpi_header_t));
+
+ memcpy(&ssdt->signature, "SSDT", 4);
+ /* Access size in ACPI 2.0c/3.0/4.0/5.0 */
+ ssdt->revision = ACPI_REV_ACPI_3_0;
+ memcpy(&ssdt->oem_id, OEM_ID, 6);
+ memcpy(&ssdt->oem_table_id, oem_table_id, 8);
+ ssdt->oem_revision = OEM_REVISION;
+ memcpy(&ssdt->asl_compiler_id, ASLC, 4);
+ ssdt->asl_compiler_revision = ASL_COMPILER_REVISION;
+ ssdt->length = sizeof(acpi_header_t);
+
+ /* (Re)calculate length and checksum */
+ ssdt->length = current - (unsigned long)ssdt;
+ ssdt->checksum = table_compute_checksum((void *)ssdt, ssdt->length);
+}
+
+unsigned long write_acpi_tables(unsigned long start)
+{
+ unsigned long current;
+ struct acpi_rsdp *rsdp;
+ struct acpi_rsdt *rsdt;
+ struct acpi_xsdt *xsdt;
+ struct acpi_facs *facs;
+ acpi_header_t *dsdt;
+ struct acpi_fadt *fadt;
+ struct acpi_mcfg *mcfg;
+ struct acpi_madt *madt;
+ acpi_header_t *ssdt;
+
+ current = start;
+
+ /* Align ACPI tables to 16byte */
+ current = ALIGN(current, 16);
+
+ debug("ACPI: Writing ACPI tables at %lx.\n", start);
+
+ /* We need at least an RSDP and an RSDT Table */
+ rsdp = (struct acpi_rsdp *)current;
+ current += sizeof(struct acpi_rsdp);
+ current = ALIGN(current, 16);
+ rsdt = (struct acpi_rsdt *)current;
+ current += sizeof(struct acpi_rsdt);
+ current = ALIGN(current, 16);
+ xsdt = (struct acpi_xsdt *)current;
+ current += sizeof(struct acpi_xsdt);
+ current = ALIGN(current, 16);
+
+ /* clear all table memory */
+ memset((void *)start, 0, current - start);
+
+ acpi_write_rsdp(rsdp, rsdt, xsdt);
+ acpi_write_rsdt(rsdt);
+ acpi_write_xsdt(xsdt);
+
+ debug("ACPI: * FACS\n");
+ facs = (struct acpi_facs *)current;
+ current += sizeof(struct acpi_facs);
+ current = ALIGN(current, 16);
+
+ acpi_create_facs(facs);
+
+ debug("ACPI: * DSDT\n");
+ dsdt = (acpi_header_t *)current;
+ memcpy(dsdt, &AmlCode, sizeof(acpi_header_t));
+ if (dsdt->length >= sizeof(acpi_header_t)) {
+ current += sizeof(acpi_header_t);
+ memcpy((char *)current,
+ (char *)&AmlCode + sizeof(acpi_header_t),
+ dsdt->length - sizeof(acpi_header_t));
+ current += dsdt->length - sizeof(acpi_header_t);
+
+ /* (Re)calculate length and checksum */
+ dsdt->length = current - (unsigned long)dsdt;
+ dsdt->checksum = 0;
+ dsdt->checksum = table_compute_checksum((void *)dsdt,
+ dsdt->length);
+ }
+ current = ALIGN(current, 16);
+
+ debug("ACPI: * FADT\n");
+ fadt = (struct acpi_fadt *)current;
+ current += sizeof(struct acpi_fadt);
+ current = ALIGN(current, 16);
+ acpi_create_fadt(fadt, facs, dsdt);
+ acpi_add_table(rsdp, fadt);
+
+ debug("ACPI: * MCFG\n");
+ mcfg = (struct acpi_mcfg *)current;
+ acpi_create_mcfg(mcfg);
+ if (mcfg->header.length > sizeof(struct acpi_mcfg)) {
+ current += mcfg->header.length;
+ current = ALIGN(current, 16);
+ acpi_add_table(rsdp, mcfg);
+ }
+
+ debug("ACPI: * MADT\n");
+ madt = (struct acpi_madt *)current;
+ acpi_create_madt(madt);
+ if (madt->header.length > sizeof(struct acpi_madt)) {
+ current += madt->header.length;
+ acpi_add_table(rsdp, madt);
+ }
+ current = ALIGN(current, 16);
+
+ debug("ACPI: * SSDT\n");
+ ssdt = (acpi_header_t *)current;
+ acpi_create_ssdt_generator(ssdt, ACPI_TABLE_CREATOR);
+ if (ssdt->length > sizeof(acpi_header_t)) {
+ current += ssdt->length;
+ acpi_add_table(rsdp, ssdt);
+ current = ALIGN(current, 16);
+ }
+
+ debug("current = %lx\n", current);
+
+ debug("ACPI: done.\n");
+
+ return current;
+}
diff --git a/arch/x86/lib/fsp/fsp_car.S b/arch/x86/lib/fsp/fsp_car.S
index afbf3f9..15b3751 100644
--- a/arch/x86/lib/fsp/fsp_car.S
+++ b/arch/x86/lib/fsp/fsp_car.S
@@ -64,7 +64,7 @@
.global fsp_init_done
fsp_init_done:
/*
- * We come here from FspInit with eax pointing to the HOB list.
+ * We come here from fsp_continue() with eax pointing to the HOB list.
* Save eax to esi temporarily.
*/
movl %eax, %esi
diff --git a/arch/x86/lib/fsp/fsp_common.c b/arch/x86/lib/fsp/fsp_common.c
index d564cb9..658f32d 100644
--- a/arch/x86/lib/fsp/fsp_common.c
+++ b/arch/x86/lib/fsp/fsp_common.c
@@ -56,8 +56,22 @@
int x86_fsp_init(void)
{
- if (!gd->arch.hob_list)
+ if (!gd->arch.hob_list) {
+ /*
+ * The first time we enter here, call fsp_init().
+ * Note the execution does not return to this function,
+ * instead it jumps to fsp_continue().
+ */
fsp_init(CONFIG_FSP_TEMP_RAM_ADDR, BOOT_FULL_CONFIG, NULL);
+ } else {
+ /*
+ * The second time we enter here, adjust the size of malloc()
+ * pool before relocation. Given gd->malloc_base was adjusted
+ * after the call to board_init_f_mem() in arch/x86/cpu/start.S,
+ * we should fix up gd->malloc_limit here.
+ */
+ gd->malloc_limit += CONFIG_FSP_SYS_MALLOC_F_LEN;
+ }
return 0;
}
diff --git a/arch/x86/lib/init_helpers.c b/arch/x86/lib/init_helpers.c
index 4fd47fc..82fd5c3 100644
--- a/arch/x86/lib/init_helpers.c
+++ b/arch/x86/lib/init_helpers.c
@@ -4,12 +4,10 @@
*
* SPDX-License-Identifier: GPL-2.0+
*/
+
#include <common.h>
-#include <fdtdec.h>
-#include <spi.h>
#include <asm/errno.h>
#include <asm/mtrr.h>
-#include <asm/sections.h>
DECLARE_GLOBAL_DATA_PTR;
@@ -19,53 +17,6 @@
return gd->ram_size;
}
-int calculate_relocation_address(void)
-{
- const ulong uboot_size = (uintptr_t)&__bss_end -
- (uintptr_t)&__text_start;
- ulong total_size;
- ulong dest_addr;
- ulong fdt_size = 0;
-
-#if defined(CONFIG_OF_SEPARATE) && defined(CONFIG_OF_CONTROL)
- if (gd->fdt_blob)
- fdt_size = ALIGN(fdt_totalsize(gd->fdt_blob) + 0x1000, 32);
-#endif
- total_size = ALIGN(uboot_size, 1 << 12) + CONFIG_SYS_MALLOC_LEN +
- CONFIG_SYS_STACK_SIZE + fdt_size;
-
- dest_addr = board_get_usable_ram_top(total_size);
- /*
- * NOTE: All destination address are rounded down to 16-byte
- * boundary to satisfy various worst-case alignment
- * requirements
- */
- dest_addr &= ~15;
-
-#if defined(CONFIG_OF_SEPARATE) && defined(CONFIG_OF_CONTROL)
- /*
- * If the device tree is sitting immediate above our image then we
- * must relocate it. If it is embedded in the data section, then it
- * will be relocated with other data.
- */
- if (gd->fdt_blob) {
- dest_addr -= fdt_size;
- gd->new_fdt = (void *)dest_addr;
- dest_addr &= ~15;
- }
-#endif
- /* U-Boot is below the FDT */
- dest_addr -= uboot_size;
- dest_addr &= ~((1 << 12) - 1);
- gd->relocaddr = dest_addr;
- gd->reloc_off = dest_addr - (uintptr_t)&__text_start;
-
- /* Stack is at the bottom, so it can grow down */
- gd->start_addr_sp = dest_addr - CONFIG_SYS_MALLOC_LEN;
-
- return 0;
-}
-
int init_cache_f_r(void)
{
#if defined(CONFIG_X86_RESET_VECTOR) & !defined(CONFIG_HAVE_FSP)
diff --git a/arch/x86/lib/tables.c b/arch/x86/lib/tables.c
index 75ffbc1..f15b2e2 100644
--- a/arch/x86/lib/tables.c
+++ b/arch/x86/lib/tables.c
@@ -8,6 +8,7 @@
#include <asm/sfi.h>
#include <asm/mpspec.h>
#include <asm/tables.h>
+#include <asm/acpi_table.h>
u8 table_compute_checksum(void *v, int len)
{
@@ -51,4 +52,8 @@
rom_table_end = write_mp_table(rom_table_end);
rom_table_end = ALIGN(rom_table_end, 1024);
#endif
+#ifdef CONFIG_GENERATE_ACPI_TABLE
+ rom_table_end = write_acpi_tables(rom_table_end);
+ rom_table_end = ALIGN(rom_table_end, 1024);
+#endif
}
diff --git a/board/intel/crownbay/crownbay.c b/board/intel/crownbay/crownbay.c
index ad2d5b6..d6de9fa 100644
--- a/board/intel/crownbay/crownbay.c
+++ b/board/intel/crownbay/crownbay.c
@@ -10,11 +10,12 @@
#include <netdev.h>
#include <smsc_lpc47m.h>
-#define SERIAL_DEV PNP_DEV(0x2e, 4)
-
int board_early_init_f(void)
{
- lpc47m_enable_serial(SERIAL_DEV, UART0_BASE, UART0_IRQ);
+ lpc47m_enable_serial(PNP_DEV(LPC47M_IO_PORT, LPC47M_SP1),
+ UART0_BASE, UART0_IRQ);
+ lpc47m_enable_kbc(PNP_DEV(LPC47M_IO_PORT, LPC47M_KBC),
+ KBD_IRQ, MSE_IRQ);
return 0;
}
diff --git a/common/board_f.c b/common/board_f.c
index a2be577..fe75656 100644
--- a/common/board_f.c
+++ b/common/board_f.c
@@ -764,9 +764,6 @@
#ifdef CONFIG_OF_CONTROL
fdtdec_setup,
#endif
-#if defined(CONFIG_X86) && defined(CONFIG_HAVE_FSP)
- x86_fsp_init,
-#endif
#ifdef CONFIG_TRACE
trace_early_init,
#endif
@@ -775,6 +772,9 @@
/* TODO: can this go into arch_cpu_init()? */
probecpu,
#endif
+#if defined(CONFIG_X86) && defined(CONFIG_HAVE_FSP)
+ x86_fsp_init,
+#endif
arch_cpu_init, /* basic arch cpu dependent setup */
mark_bootstage,
initf_dm,
diff --git a/doc/README.efi b/doc/README.efi
index 7c95579..23a3cdd 100644
--- a/doc/README.efi
+++ b/doc/README.efi
@@ -47,23 +47,25 @@
Build Instructions
------------------
First choose a board that has EFI support and obtain an EFI implementation
-for that board. It will be either 32-bit or 64-bit.
+for that board. It will be either 32-bit or 64-bit. Alternatively, you can
+opt for using QEMU [1] and the OVMF [2], as detailed below.
-To build U-Boot as an EFI application (32-bit EFI required), enable
-CONFIG_EFI and CONFIG_EFI_APP. The efi-x86 config is set up for this.
+To build U-Boot as an EFI application (32-bit EFI required), enable CONFIG_EFI
+and CONFIG_EFI_APP. The efi-x86 config (efi-x86_defconfig) is set up for this.
+Just build U-Boot as normal, e.g.
-To build U-Boot as an EFI payload (32-bit or 64-bit EFI can be used), adjust
-an existing config to enable CONFIG_EFI, CONFIG_EFI_STUB and either
-CONFIG_EFI_STUB_32BIT or CONFIG_EFI_STUB_64BIT.
-
-Then build U-Boot as normal, e.g.
-
- make qemu-x86_defconfig
- make menuconfig (or make xconfig if you prefer)
- # change the settings as above
+ make efi-x86_defconfig
make
-You will end up with one of these files:
+To build U-Boot as an EFI payload (32-bit or 64-bit EFI can be used), adjust an
+existing config (like qemu-x86_defconfig) to enable CONFIG_EFI, CONFIG_EFI_STUB
+and either CONFIG_EFI_STUB_32BIT or CONFIG_EFI_STUB_64BIT. All of these are
+boolean Kconfig options. Then build U-Boot as normal, e.g.
+
+ make qemu-x86_defconfig
+ make
+
+You will end up with one of these files depending on what you build for:
u-boot-app.efi - U-Boot EFI application
u-boot-payload.efi - U-Boot EFI payload application
@@ -71,8 +73,9 @@
Trying it out
-------------
-Qemu is an emulator and it can emulate an x86 machine. You can run the
-payload with something like this:
+QEMU is an emulator and it can emulate an x86 machine. Please make sure your
+QEMU version is 2.3.0 or above to test this. You can run the payload with
+something like this:
mkdir /tmp/efi
cp /path/to/u-boot*.efi /tmp/efi
@@ -80,7 +83,8 @@
Add -nographic if you want to use the terminal for output. Once it starts
type 'fs0:u-boot-payload.efi' to run the payload or 'fs0:u-boot-app.efi' to
-run the application. 'bios.bin' is the EFI 'BIOS'.
+run the application. 'bios.bin' is the EFI 'BIOS'. Check [2] to obtain a
+prebuilt EFI BIOS for QEMU or you can build one from source as well.
To try it on real hardware, put u-boot-app.efi on a suitable boot medium,
such as a USB stick. Then you can type something like this to start it:
@@ -235,3 +239,6 @@
Ben Stoltz, Simon Glass
Google, Inc
July 2015
+
+[1] http://www.qemu.org
+[2] http://www.tianocore.org/ovmf/
diff --git a/doc/README.x86 b/doc/README.x86
index e7dc090..3bab5cf 100644
--- a/doc/README.x86
+++ b/doc/README.x86
@@ -245,10 +245,10 @@
# in the coreboot root directory
$ ./build/util/cbfstool/cbfstool build/coreboot.rom add-flat-binary \
- -f u-boot-dtb.bin -n fallback/payload -c lzma -l 0x1110000 -e 0x1110015
+ -f u-boot-dtb.bin -n fallback/payload -c lzma -l 0x1110000 -e 0x1110000
-Make sure 0x1110000 matches CONFIG_SYS_TEXT_BASE and 0x1110015 matches the
-symbol address of _start (in arch/x86/cpu/start.S).
+Make sure 0x1110000 matches CONFIG_SYS_TEXT_BASE, which is the symbol address
+of _x86boot_start (in arch/x86/cpu/start.S).
If you want to use ELF as the coreboot payload, change U-Boot configuration to
use CONFIG_OF_EMBED instead of CONFIG_OF_SEPARATE.
@@ -654,13 +654,13 @@
For the microcode you can create a suitable device tree file using the
microcode tool:
- ./tools/microcode-tool -d microcode.dat create <model>
+ ./tools/microcode-tool -d microcode.dat -m <model> create
or if you only have header files and not the full Intel microcode.dat database:
./tools/microcode-tool -H BAY_TRAIL_FSP_KIT/Microcode/M0130673322.h \
-H BAY_TRAIL_FSP_KIT/Microcode/M0130679901.h \
- create all
+ -m all create
These are written to arch/x86/dts/microcode/ by default.
diff --git a/doc/driver-model/pci-info.txt b/doc/driver-model/pci-info.txt
index cf69167..52b4389 100644
--- a/doc/driver-model/pci-info.txt
+++ b/doc/driver-model/pci-info.txt
@@ -34,9 +34,74 @@
Note that this is all done on a lazy basis, as needed, so until something is
touched on PCI (eg: a call to pci_find_devices()) it will not be probed.
-PCI devices can appear in the device tree. If they do this serves to specify
-the driver to use for the device. In this case they will be bound at
-start-up.
+PCI devices can appear in the flattened device tree. If they do this serves to
+specify the driver to use for the device. In this case they will be bound at
+first. Each PCI device node must have a compatible string list as well as a
+<reg> property, as defined by the IEEE Std 1275-1994 PCI bus binding document
+v2.1. Note we must describe PCI devices with the same bus hierarchy as the
+hardware, otherwise driver model cannot detect the correct parent/children
+relationship during PCI bus enumeration thus PCI devices won't be bound to
+their drivers accordingly. A working example like below:
+
+ pci {
+ #address-cells = <3>;
+ #size-cells = <2>;
+ compatible = "pci-x86";
+ u-boot,dm-pre-reloc;
+ ranges = <0x02000000 0x0 0x40000000 0x40000000 0 0x80000000
+ 0x42000000 0x0 0xc0000000 0xc0000000 0 0x20000000
+ 0x01000000 0x0 0x2000 0x2000 0 0xe000>;
+
+ pcie@17,0 {
+ #address-cells = <3>;
+ #size-cells = <2>;
+ compatible = "pci-bridge";
+ u-boot,dm-pre-reloc;
+ reg = <0x0000b800 0x0 0x0 0x0 0x0>;
+
+ topcliff@0,0 {
+ #address-cells = <3>;
+ #size-cells = <2>;
+ compatible = "pci-bridge";
+ u-boot,dm-pre-reloc;
+ reg = <0x00010000 0x0 0x0 0x0 0x0>;
+
+ pciuart0: uart@a,1 {
+ compatible = "pci8086,8811.00",
+ "pci8086,8811",
+ "pciclass,070002",
+ "pciclass,0700",
+ "x86-uart";
+ u-boot,dm-pre-reloc;
+ reg = <0x00025100 0x0 0x0 0x0 0x0
+ 0x01025110 0x0 0x0 0x0 0x0>;
+ ......
+ };
+
+ ......
+ };
+ };
+
+ ......
+ };
+
+In this example, the root PCI bus node is the "/pci" which matches "pci-x86"
+driver. It has a subnode "pcie@17,0" with driver "pci-bridge". "pcie@17,0"
+also has subnode "topcliff@0,0" which is a "pci-bridge" too. Under that bridge,
+a PCI UART device "uart@a,1" is described. This exactly reflects the hardware
+bus hierarchy: on the root PCI bus, there is a PCIe root port which connects
+to a downstream device Topcliff chipset. Inside Topcliff chipset, it has a
+PCIe-to-PCI bridge and all the chipset integrated devices like the PCI UART
+device are on the PCI bus. Like other devices in the device tree, if we want
+to bind PCI devices before relocation, "u-boot,dm-pre-reloc" must be declared
+in each of these nodes.
+
+If PCI devices are not listed in the device tree, U_BOOT_PCI_DEVICE can be used
+to specify the driver to use for the device. The device tree takes precedence
+over U_BOOT_PCI_DEVICE. Plese note with U_BOOT_PCI_DEVICE, only drivers with
+DM_FLAG_PRE_RELOC will be bound before relocation. If neither device tree nor
+U_BOOT_PCI_DEVICE is provided, the built-in driver (either pci_bridge_drv or
+pci_generic_drv) will be used.
Sandbox
diff --git a/drivers/core/device.c b/drivers/core/device.c
index e23a872..a31e25f 100644
--- a/drivers/core/device.c
+++ b/drivers/core/device.c
@@ -226,17 +226,17 @@
drv = dev->driver;
assert(drv);
- /* Allocate private data if requested */
- if (drv->priv_auto_alloc_size) {
+ /* Allocate private data if requested and not reentered */
+ if (drv->priv_auto_alloc_size && !dev->priv) {
dev->priv = alloc_priv(drv->priv_auto_alloc_size, drv->flags);
if (!dev->priv) {
ret = -ENOMEM;
goto fail;
}
}
- /* Allocate private data if requested */
+ /* Allocate private data if requested and not reentered */
size = dev->uclass->uc_drv->per_device_auto_alloc_size;
- if (size) {
+ if (size && !dev->uclass_priv) {
dev->uclass_priv = calloc(1, size);
if (!dev->uclass_priv) {
ret = -ENOMEM;
@@ -251,7 +251,7 @@
size = dev->parent->uclass->uc_drv->
per_child_auto_alloc_size;
}
- if (size) {
+ if (size && !dev->parent_priv) {
dev->parent_priv = alloc_priv(size, drv->flags);
if (!dev->parent_priv) {
ret = -ENOMEM;
@@ -264,6 +264,15 @@
ret = device_probe(dev->parent);
if (ret)
goto fail;
+
+ /*
+ * The device might have already been probed during
+ * the call to device_probe() on its parent device
+ * (e.g. PCI bridge devices). Test the flags again
+ * so that we don't mess up the device.
+ */
+ if (dev->flags & DM_FLAG_ACTIVATED)
+ return 0;
}
seq = uclass_resolve_seq(dev);
diff --git a/drivers/gpio/intel_ich6_gpio.c b/drivers/gpio/intel_ich6_gpio.c
index cb408a4..67bf0a2 100644
--- a/drivers/gpio/intel_ich6_gpio.c
+++ b/drivers/gpio/intel_ich6_gpio.c
@@ -75,7 +75,7 @@
/* Is the device present? */
tmpword = x86_pci_read_config16(pci_dev, PCI_VENDOR_ID);
if (tmpword != PCI_VENDOR_ID_INTEL) {
- debug("%s: wrong VendorID\n", __func__);
+ debug("%s: wrong VendorID %x\n", __func__, tmpword);
return -ENODEV;
}
@@ -144,7 +144,7 @@
* at the offset that we just read. Bit 0 indicates that it's
* an I/O address, not a memory address, so mask that off.
*/
- return tmplong & 0xfffc;
+ return tmplong & 1 ? tmplong & ~3 : tmplong & ~15;
}
static int _ich6_gpio_set_value(uint16_t base, unsigned offset, int value)
@@ -324,7 +324,7 @@
debug("%s: io-base offset not present\n", __func__);
} else {
iobase = gpio_ich6_get_base(iobase_offset);
- if (iobase < 0) {
+ if (IS_ERR_VALUE(iobase)) {
debug("%s: invalid IOBASE address (%08x)\n", __func__,
iobase);
return -EINVAL;
@@ -410,7 +410,7 @@
{
struct ich6_bank_priv *bank = dev_get_priv(dev);
- return _ich6_gpio_set_direction(inl(bank->io_sel), offset, 0);
+ return _ich6_gpio_set_direction(bank->io_sel, offset, 0);
}
static int ich6_gpio_direction_output(struct udevice *dev, unsigned offset,
@@ -419,7 +419,7 @@
int ret;
struct ich6_bank_priv *bank = dev_get_priv(dev);
- ret = _ich6_gpio_set_direction(inl(bank->io_sel), offset, 1);
+ ret = _ich6_gpio_set_direction(bank->io_sel, offset, 1);
if (ret)
return ret;
diff --git a/drivers/input/i8042.c b/drivers/input/i8042.c
index 1769c5e..9b5fa32 100644
--- a/drivers/input/i8042.c
+++ b/drivers/input/i8042.c
@@ -10,49 +10,30 @@
/* includes */
#include <common.h>
-#include <linux/compiler.h>
-
-#ifdef CONFIG_USE_CPCIDVI
-extern u8 gt_cpcidvi_in8(u32 offset);
-extern void gt_cpcidvi_out8(u32 offset, u8 data);
-
-#define in8(a) gt_cpcidvi_in8(a)
-#define out8(a, b) gt_cpcidvi_out8(a, b)
-#endif
-
+#include <asm/io.h>
#include <i8042.h>
/* defines */
+#define in8(p) inb(p)
+#define out8(p, v) outb(v, p)
#ifdef CONFIG_CONSOLE_CURSOR
extern void console_cursor(int state);
-static int blinkCount = CONFIG_SYS_CONSOLE_BLINK_COUNT;
+static int blink_count = CONFIG_SYS_CONSOLE_BLINK_COUNT;
static int cursor_state;
#endif
/* locals */
-static int kbd_input = -1; /* no input yet */
-static int kbd_mapping = KBD_US; /* default US keyboard */
-static int kbd_flags = NORMAL; /* after reset */
-static int kbd_state; /* unshift code */
-
-static void kbd_conv_char(unsigned char scan_code);
-static void kbd_led_set(void);
-static void kbd_normal(unsigned char scan_code);
-static void kbd_shift(unsigned char scan_code);
-static void kbd_ctrl(unsigned char scan_code);
-static void kbd_num(unsigned char scan_code);
-static void kbd_caps(unsigned char scan_code);
-static void kbd_scroll(unsigned char scan_code);
-static void kbd_alt(unsigned char scan_code);
-static int kbd_input_empty(void);
-static int kbd_reset(void);
+static int kbd_input = -1; /* no input yet */
+static int kbd_mapping = KBD_US; /* default US keyboard */
+static int kbd_flags = NORMAL; /* after reset */
+static int kbd_state; /* unshift code */
static unsigned char kbd_fct_map[144] = {
/* kbd_fct_map table for scan code */
- 0, AS, AS, AS, AS, AS, AS, AS, /* scan 0- 7 */
- AS, AS, AS, AS, AS, AS, AS, AS, /* scan 8- F */
+ 0, AS, AS, AS, AS, AS, AS, AS, /* scan 00-07 */
+ AS, AS, AS, AS, AS, AS, AS, AS, /* scan 08-0F */
AS, AS, AS, AS, AS, AS, AS, AS, /* scan 10-17 */
AS, AS, AS, AS, AS, CN, AS, AS, /* scan 18-1F */
AS, AS, AS, AS, AS, AS, AS, AS, /* scan 20-27 */
@@ -74,8 +55,8 @@
static unsigned char kbd_key_map[2][5][144] = {
{ /* US keyboard */
{ /* unshift code */
- 0, 0x1b, '1', '2', '3', '4', '5', '6', /* scan 0- 7 */
- '7', '8', '9', '0', '-', '=', 0x08, '\t', /* scan 8- F */
+ 0, 0x1b, '1', '2', '3', '4', '5', '6', /* scan 00-07 */
+ '7', '8', '9', '0', '-', '=', 0x08, '\t', /* scan 08-0F */
'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', /* scan 10-17 */
'o', 'p', '[', ']', '\r', CN, 'a', 's', /* scan 18-1F */
'd', 'f', 'g', 'h', 'j', 'k', 'l', ';', /* scan 20-27 */
@@ -94,8 +75,8 @@
0, 'D', 'C', 0, 'B', 0, '@', 'P' /* extended */
},
{ /* shift code */
- 0, 0x1b, '!', '@', '#', '$', '%', '^', /* scan 0- 7 */
- '&', '*', '(', ')', '_', '+', 0x08, '\t', /* scan 8- F */
+ 0, 0x1b, '!', '@', '#', '$', '%', '^', /* scan 00-07 */
+ '&', '*', '(', ')', '_', '+', 0x08, '\t', /* scan 08-0F */
'Q', 'W', 'E', 'R', 'T', 'Y', 'U', 'I', /* scan 10-17 */
'O', 'P', '{', '}', '\r', CN, 'A', 'S', /* scan 18-1F */
'D', 'F', 'G', 'H', 'J', 'K', 'L', ':', /* scan 20-27 */
@@ -114,8 +95,8 @@
0, 'D', 'C', 0, 'B', 0, '@', 'P' /* extended */
},
{ /* control code */
- 0xff, 0x1b, 0xff, 0x00, 0xff, 0xff, 0xff, 0xff, /* scan 0- 7 */
- 0x1e, 0xff, 0xff, 0xff, 0x1f, 0xff, 0xff, '\t', /* scan 8- F */
+ 0xff, 0x1b, 0xff, 0x00, 0xff, 0xff, 0xff, 0xff, /* scan 00-07 */
+ 0x1e, 0xff, 0xff, 0xff, 0x1f, 0xff, 0xff, '\t', /* scan 08-0F */
0x11, 0x17, 0x05, 0x12, 0x14, 0x19, 0x15, 0x09, /* scan 10-17 */
0x0f, 0x10, 0x1b, 0x1d, '\r', CN, 0x01, 0x13, /* scan 18-1F */
0x04, 0x06, 0x07, 0x08, 0x0a, 0x0b, 0x0c, 0xff, /* scan 20-27 */
@@ -134,8 +115,8 @@
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff /* extended */
},
{ /* non numeric code */
- 0, 0x1b, '1', '2', '3', '4', '5', '6', /* scan 0- 7 */
- '7', '8', '9', '0', '-', '=', 0x08, '\t', /* scan 8- F */
+ 0, 0x1b, '1', '2', '3', '4', '5', '6', /* scan 00-07 */
+ '7', '8', '9', '0', '-', '=', 0x08, '\t', /* scan 08-0F */
'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', /* scan 10-17 */
'o', 'p', '[', ']', '\r', CN, 'a', 's', /* scan 18-1F */
'd', 'f', 'g', 'h', 'j', 'k', 'l', ';', /* scan 20-27 */
@@ -154,30 +135,30 @@
0, 'D', 'C', 0, 'B', 0, '@', 'P' /* extended */
},
{ /* right alt mode - not used in US keyboard */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 0 - 7 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 8 - F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 10 -17 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 18 -1F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 20 -27 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 28 -2F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 30 -37 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 38 -3F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 40 -47 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 48 -4F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 50 -57 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 58 -5F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 60 -67 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 68 -6F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 70 -77 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 78 -7F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 00-07 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 08-0F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 10-17 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 18-1F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 20-27 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 28-2F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 30-37 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 38-3F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 40-47 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 48-4F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 50-57 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 58-5F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 60-67 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 68-6F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 70-77 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 78-7F */
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* extended */
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff /* extended */
}
},
- { /* german keyboard */
+ { /* German keyboard */
{ /* unshift code */
- 0, 0x1b, '1', '2', '3', '4', '5', '6', /* scan 0- 7 */
- '7', '8', '9', '0', 0xe1, '\'', 0x08, '\t', /* scan 8- F */
+ 0, 0x1b, '1', '2', '3', '4', '5', '6', /* scan 00-07 */
+ '7', '8', '9', '0', 0xe1, '\'', 0x08, '\t', /* scan 08-0F */
'q', 'w', 'e', 'r', 't', 'z', 'u', 'i', /* scan 10-17 */
'o', 'p', 0x81, '+', '\r', CN, 'a', 's', /* scan 18-1F */
'd', 'f', 'g', 'h', 'j', 'k', 'l', 0x94, /* scan 20-27 */
@@ -196,8 +177,8 @@
0, 'D', 'C', 0, 'B', 0, '@', 'P' /* extended */
},
{ /* shift code */
- 0, 0x1b, '!', '"', 0x15, '$', '%', '&', /* scan 0- 7 */
- '/', '(', ')', '=', '?', '`', 0x08, '\t', /* scan 8- F */
+ 0, 0x1b, '!', '"', 0x15, '$', '%', '&', /* scan 00-07 */
+ '/', '(', ')', '=', '?', '`', 0x08, '\t', /* scan 08-0F */
'Q', 'W', 'E', 'R', 'T', 'Z', 'U', 'I', /* scan 10-17 */
'O', 'P', 0x9a, '*', '\r', CN, 'A', 'S', /* scan 18-1F */
'D', 'F', 'G', 'H', 'J', 'K', 'L', 0x99, /* scan 20-27 */
@@ -216,8 +197,8 @@
0, 'D', 'C', 0, 'B', 0, '@', 'P' /* extended */
},
{ /* control code */
- 0xff, 0x1b, 0xff, 0x00, 0xff, 0xff, 0xff, 0xff, /* scan 0- 7 */
- 0x1e, 0xff, 0xff, 0xff, 0x1f, 0xff, 0xff, '\t', /* scan 8- F */
+ 0xff, 0x1b, 0xff, 0x00, 0xff, 0xff, 0xff, 0xff, /* scan 00-07 */
+ 0x1e, 0xff, 0xff, 0xff, 0x1f, 0xff, 0xff, '\t', /* scan 08-0F */
0x11, 0x17, 0x05, 0x12, 0x14, 0x19, 0x15, 0x09, /* scan 10-17 */
0x0f, 0x10, 0x1b, 0x1d, '\r', CN, 0x01, 0x13, /* scan 18-1F */
0x04, 0x06, 0x07, 0x08, 0x0a, 0x0b, 0x0c, 0xff, /* scan 20-27 */
@@ -236,8 +217,8 @@
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff /* extended */
},
{ /* non numeric code */
- 0, 0x1b, '1', '2', '3', '4', '5', '6', /* scan 0- 7 */
- '7', '8', '9', '0', 0xe1, '\'', 0x08, '\t', /* scan 8- F */
+ 0, 0x1b, '1', '2', '3', '4', '5', '6', /* scan 00-07 */
+ '7', '8', '9', '0', 0xe1, '\'', 0x08, '\t', /* scan 08-0F */
'q', 'w', 'e', 'r', 't', 'z', 'u', 'i', /* scan 10-17 */
'o', 'p', 0x81, '+', '\r', CN, 'a', 's', /* scan 18-1F */
'd', 'f', 'g', 'h', 'j', 'k', 'l', 0x94, /* scan 20-27 */
@@ -255,23 +236,23 @@
'\r', CN, '/', '*', ' ', ST, 'F', 'A', /* extended */
0, 'D', 'C', 0, 'B', 0, '@', 'P' /* extended */
},
- { /* Right alt mode - is used in German keyboard */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 0 - 7 */
- '{', '[', ']', '}', '\\', 0xff, 0xff, 0xff, /* scan 8 - F */
- '@', 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 10 -17 */
- 0xff, 0xff, 0xff, '~', 0xff, 0xff, 0xff, 0xff, /* scan 18 -1F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 20 -27 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 28 -2F */
- 0xff, 0xff, 0xe6, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 30 -37 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 38 -3F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 40 -47 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 48 -4F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, '|', 0xff, /* scan 50 -57 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 58 -5F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 60 -67 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 68 -6F */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 70 -77 */
- 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 78 -7F */
+ { /* right alt mode - is used in German keyboard */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 00-07 */
+ '{', '[', ']', '}', '\\', 0xff, 0xff, 0xff, /* scan 08-0F */
+ '@', 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 10-17 */
+ 0xff, 0xff, 0xff, '~', 0xff, 0xff, 0xff, 0xff, /* scan 18-1F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 20-27 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 28-2F */
+ 0xff, 0xff, 0xe6, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 30-37 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 38-3F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 40-47 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 48-4F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, '|', 0xff, /* scan 50-57 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 58-5F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 60-67 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 68-6F */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 70-77 */
+ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* scan 78-7F */
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, /* extended */
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff /* extended */
}
@@ -298,167 +279,113 @@
0x00 /* map end */
};
-/******************************************************************************/
-
-static int kbd_controller_present(void)
+static int kbd_input_empty(void)
{
- return in8(I8042_STATUS_REG) != 0xff;
+ int kbd_timeout = KBD_TIMEOUT * 1000;
+
+ while ((in8(I8042_STS_REG) & STATUS_IBF) && kbd_timeout--)
+ udelay(1);
+
+ return kbd_timeout != -1;
}
-/*
- * Implement a weak default function for boards that optionally
- * need to skip the i8042 initialization.
- */
-int __weak board_i8042_skip(void)
+static int kbd_output_full(void)
{
- /* As default, don't skip */
- return 0;
+ int kbd_timeout = KBD_TIMEOUT * 1000;
+
+ while (((in8(I8042_STS_REG) & STATUS_OBF) == 0) && kbd_timeout--)
+ udelay(1);
+
+ return kbd_timeout != -1;
}
-void i8042_flush(void)
+static void kbd_led_set(void)
{
- int timeout;
+ kbd_input_empty();
+ out8(I8042_DATA_REG, CMD_SET_KBD_LED);
+ kbd_input_empty();
+ out8(I8042_DATA_REG, (kbd_flags & 0x7));
+}
- /*
- * The delay is to give the keyboard controller some time to fill the
- * next byte.
- */
- while (1) {
- timeout = 100; /* wait for no longer than 100us */
- while (timeout > 0 && !(in8(I8042_STATUS_REG) & 0x01)) {
- udelay(1);
- timeout--;
+static void kbd_normal(unsigned char scan_code)
+{
+ unsigned char chr;
+
+ if ((kbd_flags & BRK) == NORMAL) {
+ chr = kbd_key_map[kbd_mapping][kbd_state][scan_code];
+ if ((chr == 0xff) || (chr == 0x00))
+ return;
+
+ /* if caps lock convert upper to lower */
+ if (((kbd_flags & CAPS) == CAPS) &&
+ (chr >= 'a' && chr <= 'z')) {
+ chr -= 'a' - 'A';
}
-
- /* Try to pull next byte if not timeout. */
- if (in8(I8042_STATUS_REG) & 0x01)
- in8(I8042_DATA_REG);
- else
- break;
+ kbd_input = chr;
}
}
-int i8042_disable(void)
+static void kbd_shift(unsigned char scan_code)
{
- if (kbd_input_empty() == 0)
- return -1;
-
- /* Disable keyboard */
- out8(I8042_COMMAND_REG, 0xad);
-
- if (kbd_input_empty() == 0)
- return -1;
-
- return 0;
-}
-
-
-/*******************************************************************************
- *
- * i8042_kbd_init - reset keyboard and init state flags
- */
-int i8042_kbd_init(void)
-{
- int keymap, try;
- char *penv;
-
- if (!kbd_controller_present() || board_i8042_skip())
- return -1;
-
-#ifdef CONFIG_USE_CPCIDVI
- penv = getenv("console");
- if (penv != NULL) {
- if (strncmp(penv, "serial", 7) == 0)
- return -1;
- }
-#endif
- /* Init keyboard device (default US layout) */
- keymap = KBD_US;
- penv = getenv("keymap");
- if (penv != NULL) {
- if (strncmp(penv, "de", 3) == 0)
- keymap = KBD_GER;
- }
-
- for (try = 0; try < KBD_RESET_TRIES; try++) {
- if (kbd_reset() == 0) {
- kbd_mapping = keymap;
- kbd_flags = NORMAL;
- kbd_state = 0;
- kbd_led_set();
- return 0;
- }
- }
- return -1;
-}
-
-
-/*******************************************************************************
- *
- * i8042_tstc - test if keyboard input is available
- * option: cursor blinking if called in a loop
- */
-int i8042_tstc(struct stdio_dev *dev)
-{
- unsigned char scan_code = 0;
-
-#ifdef CONFIG_CONSOLE_CURSOR
- if (--blinkCount == 0) {
- cursor_state ^= 1;
- console_cursor(cursor_state);
- blinkCount = CONFIG_SYS_CONSOLE_BLINK_COUNT;
- udelay(10);
- }
-#endif
-
- if ((in8(I8042_STATUS_REG) & 0x01) == 0) {
- return 0;
+ if ((kbd_flags & BRK) == BRK) {
+ kbd_state = AS;
+ kbd_flags &= (~SHIFT);
} else {
- scan_code = in8(I8042_DATA_REG);
- if (scan_code == 0xfa)
- return 0;
-
- kbd_conv_char(scan_code);
-
- if (kbd_input != -1)
- return 1;
+ kbd_state = SH;
+ kbd_flags |= SHIFT;
}
- return 0;
}
-
-/*******************************************************************************
- *
- * i8042_getc - wait till keyboard input is available
- * option: turn on/off cursor while waiting
- */
-int i8042_getc(struct stdio_dev *dev)
+static void kbd_ctrl(unsigned char scan_code)
{
- int ret_chr;
- unsigned char scan_code;
-
- while (kbd_input == -1) {
- while ((in8(I8042_STATUS_REG) & 0x01) == 0) {
-#ifdef CONFIG_CONSOLE_CURSOR
- if (--blinkCount == 0) {
- cursor_state ^= 1;
- console_cursor(cursor_state);
- blinkCount = CONFIG_SYS_CONSOLE_BLINK_COUNT;
- }
- udelay(10);
-#endif
- }
- scan_code = in8(I8042_DATA_REG);
- if (scan_code != 0xfa)
- kbd_conv_char (scan_code);
+ if ((kbd_flags & BRK) == BRK) {
+ kbd_state = AS;
+ kbd_flags &= (~CTRL);
+ } else {
+ kbd_state = CN;
+ kbd_flags |= CTRL;
}
- ret_chr = kbd_input;
- kbd_input = -1;
- return ret_chr;
}
+static void kbd_num(unsigned char scan_code)
+{
+ if ((kbd_flags & BRK) == NORMAL) {
+ kbd_flags ^= NUM;
+ kbd_state = (kbd_flags & NUM) ? AS : NM;
+ kbd_led_set();
+ }
+}
-/******************************************************************************/
+static void kbd_alt(unsigned char scan_code)
+{
+ if ((kbd_flags & BRK) == BRK) {
+ kbd_state = AS;
+ kbd_flags &= (~ALT);
+ } else {
+ kbd_state = AK;
+ kbd_flags &= ALT;
+ }
+}
+
+static void kbd_caps(unsigned char scan_code)
+{
+ if ((kbd_flags & BRK) == NORMAL) {
+ kbd_flags ^= CAPS;
+ kbd_led_set();
+ }
+}
+
+static void kbd_scroll(unsigned char scan_code)
+{
+ if ((kbd_flags & BRK) == NORMAL) {
+ kbd_flags ^= STP;
+ kbd_led_set();
+ if (kbd_flags & STP)
+ kbd_input = 0x13;
+ else
+ kbd_input = 0x11;
+ }
+}
static void kbd_conv_char(unsigned char scan_code)
{
@@ -475,8 +402,8 @@
if ((scan_code == 0xe1) || (kbd_flags & E1)) {
if (scan_code == 0xe1) {
- kbd_flags ^= BRK; /* reset the break flag */
- kbd_flags ^= E1; /* bitwise EXOR with E1 flag */
+ kbd_flags ^= BRK; /* reset the break flag */
+ kbd_flags ^= E1; /* bitwise EXOR with E1 flag */
}
return;
}
@@ -511,203 +438,218 @@
case NM:
kbd_num(scan_code);
break;
+ case AK:
+ kbd_alt(scan_code);
+ break;
case CP:
kbd_caps(scan_code);
break;
case ST:
kbd_scroll(scan_code);
break;
- case AK:
- kbd_alt(scan_code);
- break;
}
+
return;
}
-
-/******************************************************************************/
-
-static void kbd_normal(unsigned char scan_code)
-{
- unsigned char chr;
-
- if ((kbd_flags & BRK) == NORMAL) {
- chr = kbd_key_map[kbd_mapping][kbd_state][scan_code];
- if ((chr == 0xff) || (chr == 0x00))
- return;
-
- /* if caps lock convert upper to lower */
- if (((kbd_flags & CAPS) == CAPS) &&
- (chr >= 'a' && chr <= 'z')) {
- chr -= 'a' - 'A';
- }
- kbd_input = chr;
- }
-}
-
-
-/******************************************************************************/
-
-static void kbd_shift(unsigned char scan_code)
-{
- if ((kbd_flags & BRK) == BRK) {
- kbd_state = AS;
- kbd_flags &= (~SHIFT);
- } else {
- kbd_state = SH;
- kbd_flags |= SHIFT;
- }
-}
-
-
-/******************************************************************************/
-
-static void kbd_ctrl(unsigned char scan_code)
-{
- if ((kbd_flags & BRK) == BRK) {
- kbd_state = AS;
- kbd_flags &= (~CTRL);
- } else {
- kbd_state = CN;
- kbd_flags |= CTRL;
- }
-}
-
-
-/******************************************************************************/
-
-static void kbd_caps(unsigned char scan_code)
-{
- if ((kbd_flags & BRK) == NORMAL) {
- kbd_flags ^= CAPS;
- kbd_led_set(); /* update keyboard LED */
- }
-}
-
-
-/******************************************************************************/
-
-static void kbd_num(unsigned char scan_code)
-{
- if ((kbd_flags & BRK) == NORMAL) {
- kbd_flags ^= NUM;
- kbd_state = (kbd_flags & NUM) ? AS : NM;
- kbd_led_set(); /* update keyboard LED */
- }
-}
-
-
-/******************************************************************************/
-
-static void kbd_scroll(unsigned char scan_code)
-{
- if ((kbd_flags & BRK) == NORMAL) {
- kbd_flags ^= STP;
- kbd_led_set(); /* update keyboard LED */
- if (kbd_flags & STP)
- kbd_input = 0x13;
- else
- kbd_input = 0x11;
- }
-}
-
-/******************************************************************************/
-
-static void kbd_alt(unsigned char scan_code)
-{
- if ((kbd_flags & BRK) == BRK) {
- kbd_state = AS;
- kbd_flags &= (~ALT);
- } else {
- kbd_state = AK;
- kbd_flags &= ALT;
- }
-}
-
-
-/******************************************************************************/
-
-static void kbd_led_set(void)
-{
- kbd_input_empty();
- out8(I8042_DATA_REG, 0xed); /* SET LED command */
- kbd_input_empty();
- out8(I8042_DATA_REG, (kbd_flags & 0x7)); /* LED bits only */
-}
-
-
-/******************************************************************************/
-
-static int kbd_input_empty(void)
-{
- int kbdTimeout = KBD_TIMEOUT * 1000;
-
- while ((in8(I8042_STATUS_REG) & I8042_STATUS_IN_DATA) && kbdTimeout--)
- udelay(1);
-
- return kbdTimeout != -1;
-}
-
-/******************************************************************************/
-
-static int wait_until_kbd_output_full(void)
-{
- int kbdTimeout = KBD_TIMEOUT * 1000;
-
- while (((in8(I8042_STATUS_REG) & 0x01) == 0) && kbdTimeout--)
- udelay(1);
-
- return kbdTimeout != -1;
-}
-
-/******************************************************************************/
-
static int kbd_reset(void)
{
- /* KB Reset */
+ u8 config;
+
+ /* controller self test */
if (kbd_input_empty() == 0)
return -1;
-
- out8(I8042_DATA_REG, 0xff);
-
- if (wait_until_kbd_output_full() == 0)
+ out8(I8042_CMD_REG, CMD_SELF_TEST);
+ if (kbd_output_full() == 0)
+ return -1;
+ if (in8(I8042_DATA_REG) != KBC_TEST_OK)
return -1;
- if (in8(I8042_DATA_REG) != 0xfa) /* ACK */
- return -1;
-
- if (wait_until_kbd_output_full() == 0)
- return -1;
-
- if (in8(I8042_DATA_REG) != 0xaa) /* Test Pass*/
- return -1;
-
+ /* keyboard reset */
if (kbd_input_empty() == 0)
return -1;
-
- /* Set KBC mode */
- out8(I8042_COMMAND_REG, 0x60);
-
- if (kbd_input_empty() == 0)
+ out8(I8042_DATA_REG, CMD_RESET_KBD);
+ if (kbd_output_full() == 0)
+ return -1;
+ if (in8(I8042_DATA_REG) != KBD_ACK)
+ return -1;
+ if (kbd_output_full() == 0)
+ return -1;
+ if (in8(I8042_DATA_REG) != KBD_POR)
return -1;
- out8(I8042_DATA_REG, 0x45);
-
+ /* set AT translation and disable irq */
if (kbd_input_empty() == 0)
return -1;
-
- /* Enable Keyboard */
- out8(I8042_COMMAND_REG, 0xae);
+ out8(I8042_CMD_REG, CMD_RD_CONFIG);
+ if (kbd_output_full() == 0)
+ return -1;
+ config = in8(I8042_DATA_REG);
+ config |= CONFIG_AT_TRANS;
+ config &= ~(CONFIG_KIRQ_EN | CONFIG_MIRQ_EN);
if (kbd_input_empty() == 0)
return -1;
-
- out8(I8042_COMMAND_REG, 0x60);
+ out8(I8042_CMD_REG, CMD_WR_CONFIG);
if (kbd_input_empty() == 0)
return -1;
+ out8(I8042_DATA_REG, config);
- out8(I8042_DATA_REG, 0xf4);
+ /* enable keyboard */
+ if (kbd_input_empty() == 0)
+ return -1;
+ out8(I8042_CMD_REG, CMD_KBD_EN);
if (kbd_input_empty() == 0)
return -1;
return 0;
}
+
+static int kbd_controller_present(void)
+{
+ return in8(I8042_STS_REG) != 0xff;
+}
+
+/*
+ * Implement a weak default function for boards that optionally
+ * need to skip the i8042 initialization.
+ */
+int __weak board_i8042_skip(void)
+{
+ /* As default, don't skip */
+ return 0;
+}
+
+void i8042_flush(void)
+{
+ int timeout;
+
+ /*
+ * The delay is to give the keyboard controller some time
+ * to fill the next byte.
+ */
+ while (1) {
+ timeout = 100; /* wait for no longer than 100us */
+ while (timeout > 0 && !(in8(I8042_STS_REG) & STATUS_OBF)) {
+ udelay(1);
+ timeout--;
+ }
+
+ /* Try to pull next byte if not timeout */
+ if (in8(I8042_STS_REG) & STATUS_OBF)
+ in8(I8042_DATA_REG);
+ else
+ break;
+ }
+}
+
+int i8042_disable(void)
+{
+ if (kbd_input_empty() == 0)
+ return -1;
+
+ /* Disable keyboard */
+ out8(I8042_CMD_REG, CMD_KBD_DIS);
+
+ if (kbd_input_empty() == 0)
+ return -1;
+
+ return 0;
+}
+
+/* i8042_kbd_init - reset keyboard and init state flags */
+int i8042_kbd_init(void)
+{
+ int keymap, try;
+ char *penv;
+
+ if (!kbd_controller_present() || board_i8042_skip()) {
+ debug("i8042 keyboard controller is not present\n");
+ return -1;
+ }
+
+ /* Init keyboard device (default US layout) */
+ keymap = KBD_US;
+ penv = getenv("keymap");
+ if (penv != NULL) {
+ if (strncmp(penv, "de", 3) == 0)
+ keymap = KBD_GER;
+ }
+
+ for (try = 0; try < KBD_RESET_TRIES; try++) {
+ if (kbd_reset() == 0) {
+ kbd_mapping = keymap;
+ kbd_flags = NORMAL;
+ kbd_state = 0;
+ kbd_led_set();
+
+ return 0;
+ }
+ }
+
+ return -1;
+}
+
+/*
+ * i8042_tstc - test if keyboard input is available
+ *
+ * option: cursor blinking if called in a loop
+ */
+int i8042_tstc(struct stdio_dev *dev)
+{
+ unsigned char scan_code = 0;
+
+#ifdef CONFIG_CONSOLE_CURSOR
+ if (--blink_count == 0) {
+ cursor_state ^= 1;
+ console_cursor(cursor_state);
+ blink_count = CONFIG_SYS_CONSOLE_BLINK_COUNT;
+ udelay(10);
+ }
+#endif
+
+ if ((in8(I8042_STS_REG) & STATUS_OBF) == 0) {
+ return 0;
+ } else {
+ scan_code = in8(I8042_DATA_REG);
+ if (scan_code == 0xfa)
+ return 0;
+
+ kbd_conv_char(scan_code);
+
+ if (kbd_input != -1)
+ return 1;
+ }
+
+ return 0;
+}
+
+/*
+ * i8042_getc - wait till keyboard input is available
+ *
+ * option: turn on/off cursor while waiting
+ */
+int i8042_getc(struct stdio_dev *dev)
+{
+ int ret_chr;
+ unsigned char scan_code;
+
+ while (kbd_input == -1) {
+ while ((in8(I8042_STS_REG) & STATUS_OBF) == 0) {
+#ifdef CONFIG_CONSOLE_CURSOR
+ if (--blink_count == 0) {
+ cursor_state ^= 1;
+ console_cursor(cursor_state);
+ blink_count = CONFIG_SYS_CONSOLE_BLINK_COUNT;
+ }
+ udelay(10);
+#endif
+ }
+ scan_code = in8(I8042_DATA_REG);
+ if (scan_code != 0xfa)
+ kbd_conv_char(scan_code);
+ }
+ ret_chr = kbd_input;
+ kbd_input = -1;
+
+ return ret_chr;
+}
diff --git a/drivers/misc/smsc_lpc47m.c b/drivers/misc/smsc_lpc47m.c
index 1e50d5b..fcce3a4 100644
--- a/drivers/misc/smsc_lpc47m.c
+++ b/drivers/misc/smsc_lpc47m.c
@@ -22,7 +22,7 @@
outb(0xaa, port);
}
-void lpc47m_enable_serial(u16 dev, u16 iobase, u8 irq)
+void lpc47m_enable_serial(uint dev, uint iobase, uint irq)
{
pnp_enter_conf_state(dev);
pnp_set_logical_device(dev);
@@ -32,3 +32,14 @@
pnp_set_enable(dev, 1);
pnp_exit_conf_state(dev);
}
+
+void lpc47m_enable_kbc(uint dev, uint irq0, uint irq1)
+{
+ pnp_enter_conf_state(dev);
+ pnp_set_logical_device(dev);
+ pnp_set_enable(dev, 0);
+ pnp_set_irq(dev, PNP_IDX_IRQ0, irq0);
+ pnp_set_irq(dev, PNP_IDX_IRQ1, irq1);
+ pnp_set_enable(dev, 1);
+ pnp_exit_conf_state(dev);
+}
diff --git a/drivers/net/e1000.c b/drivers/net/e1000.c
index 6f74d30..7b830ff 100644
--- a/drivers/net/e1000.c
+++ b/drivers/net/e1000.c
@@ -4978,8 +4978,8 @@
unsigned long tipg, tarc;
uint32_t ipgr1, ipgr2;
- E1000_WRITE_REG(hw, TDBAL, (unsigned long)tx_base & 0xffffffff);
- E1000_WRITE_REG(hw, TDBAH, (unsigned long)tx_base >> 32);
+ E1000_WRITE_REG(hw, TDBAL, lower_32_bits((unsigned long)tx_base));
+ E1000_WRITE_REG(hw, TDBAH, upper_32_bits((unsigned long)tx_base));
E1000_WRITE_REG(hw, TDLEN, 128);
@@ -5103,6 +5103,7 @@
{
unsigned long rctl, ctrl_ext;
rx_tail = 0;
+
/* make sure receives are disabled while setting up the descriptors */
rctl = E1000_READ_REG(hw, RCTL);
E1000_WRITE_REG(hw, RCTL, rctl & ~E1000_RCTL_EN);
@@ -5122,8 +5123,8 @@
E1000_WRITE_FLUSH(hw);
}
/* Setup the Base and Length of the Rx Descriptor Ring */
- E1000_WRITE_REG(hw, RDBAL, (unsigned long)rx_base & 0xffffffff);
- E1000_WRITE_REG(hw, RDBAH, (unsigned long)rx_base >> 32);
+ E1000_WRITE_REG(hw, RDBAL, lower_32_bits((unsigned long)rx_base));
+ E1000_WRITE_REG(hw, RDBAH, upper_32_bits((unsigned long)rx_base));
E1000_WRITE_REG(hw, RDLEN, 128);
diff --git a/drivers/pci/pci-uclass.c b/drivers/pci/pci-uclass.c
index 7d41d56..b25298f 100644
--- a/drivers/pci/pci-uclass.c
+++ b/drivers/pci/pci-uclass.c
@@ -14,6 +14,9 @@
#include <dm/lists.h>
#include <dm/root.h>
#include <dm/device-internal.h>
+#if defined(CONFIG_X86) && defined(CONFIG_HAVE_FSP)
+#include <asm/fsp/fsp_support.h>
+#endif
DECLARE_GLOBAL_DATA_PTR;
@@ -461,6 +464,7 @@
int n_ents;
int ret;
char name[30], *str;
+ bool bridge;
*devp = NULL;
@@ -480,6 +484,17 @@
continue;
drv = entry->driver;
+
+ /*
+ * In the pre-relocation phase, we only bind devices
+ * whose driver has the DM_FLAG_PRE_RELOC set, to save
+ * precious memory space as on some platforms as that
+ * space is pretty limited (ie: using Cache As RAM).
+ */
+ if (!(gd->flags & GD_FLG_RELOC) &&
+ !(drv->flags & DM_FLAG_PRE_RELOC))
+ return 0;
+
/*
* We could pass the descriptor to the driver as
* platdata (instead of NULL) and allow its bind()
@@ -499,14 +514,23 @@
}
}
+ bridge = (find_id->class >> 8) == PCI_CLASS_BRIDGE_PCI;
+ /*
+ * In the pre-relocation phase, we only bind bridge devices to save
+ * precious memory space as on some platforms as that space is pretty
+ * limited (ie: using Cache As RAM).
+ */
+ if (!(gd->flags & GD_FLG_RELOC) && !bridge)
+ return 0;
+
/* Bind a generic driver so that the device can be used */
sprintf(name, "pci_%x:%x.%x", parent->seq, PCI_DEV(bdf),
PCI_FUNC(bdf));
str = strdup(name);
if (!str)
return -ENOMEM;
- drv = (find_id->class >> 8) == PCI_CLASS_BRIDGE_PCI ? "pci_bridge_drv" :
- "pci_generic_drv";
+ drv = bridge ? "pci_bridge_drv" : "pci_generic_drv";
+
ret = device_bind_driver(parent, drv, str, devp);
if (ret) {
debug("%s: Failed to bind generic driver: %d", __func__, ret);
@@ -589,11 +613,13 @@
return ret;
/* Update the platform data */
- pplat = dev_get_parent_platdata(dev);
- pplat->devfn = PCI_MASK_BUS(bdf);
- pplat->vendor = vendor;
- pplat->device = device;
- pplat->class = class;
+ if (dev) {
+ pplat = dev_get_parent_platdata(dev);
+ pplat->devfn = PCI_MASK_BUS(bdf);
+ pplat->vendor = vendor;
+ pplat->device = device;
+ pplat->class = class;
+ }
}
return 0;
@@ -606,6 +632,13 @@
static int pci_uclass_post_bind(struct udevice *bus)
{
/*
+ * If there is no pci device listed in the device tree,
+ * don't bother scanning the device tree.
+ */
+ if (bus->of_offset == -1)
+ return 0;
+
+ /*
* Scan the device tree for devices. This does not probe the PCI bus,
* as this is not permitted while binding. It just finds devices
* mentioned in the device tree.
@@ -717,10 +750,6 @@
{
int ret;
- /* Don't scan buses before relocation */
- if (!(gd->flags & GD_FLG_RELOC))
- return 0;
-
debug("%s: probing bus %d\n", __func__, bus->seq);
ret = pci_bind_bus_devices(bus);
if (ret)
@@ -730,6 +759,24 @@
ret = pci_auto_config_devices(bus);
#endif
+#if defined(CONFIG_X86) && defined(CONFIG_HAVE_FSP)
+ /*
+ * Per Intel FSP specification, we should call FSP notify API to
+ * inform FSP that PCI enumeration has been done so that FSP will
+ * do any necessary initialization as required by the chipset's
+ * BIOS Writer's Guide (BWG).
+ *
+ * Unfortunately we have to put this call here as with driver model,
+ * the enumeration is all done on a lazy basis as needed, so until
+ * something is touched on PCI it won't happen.
+ *
+ * Note we only call this 1) after U-Boot is relocated, and 2)
+ * root bus has finished probing.
+ */
+ if ((gd->flags & GD_FLG_RELOC) && (bus->seq == 0))
+ ret = fsp_init_phase_pci();
+#endif
+
return ret < 0 ? ret : 0;
}
@@ -754,8 +801,8 @@
if (ret != -ENOENT)
return -EINVAL;
} else {
- /* extract the bdf from fdt_pci_addr */
- pplat->devfn = addr.phys_hi & 0xffff00;
+ /* extract the devfn from fdt_pci_addr */
+ pplat->devfn = addr.phys_hi & 0xff00;
}
return 0;
diff --git a/drivers/pci/pci_rom.c b/drivers/pci/pci_rom.c
index 26db3ca..d244543 100644
--- a/drivers/pci/pci_rom.c
+++ b/drivers/pci/pci_rom.c
@@ -187,7 +187,7 @@
return 0;
}
-static struct vbe_mode_info mode_info;
+struct vbe_mode_info mode_info;
int vbe_get_video_info(struct graphic_device *gdev)
{
@@ -232,7 +232,6 @@
void setup_video(struct screen_info *screen_info)
{
-#ifdef CONFIG_FRAMEBUFFER_SET_VESA_MODE
struct vesa_mode_info *vesa = &mode_info.vesa;
/* Sanity test on VESA parameters */
@@ -258,7 +257,6 @@
screen_info->blue_pos = vesa->blue_mask_pos;
screen_info->rsvd_size = vesa->reserved_mask_size;
screen_info->rsvd_pos = vesa->reserved_mask_pos;
-#endif
}
int pci_run_vga_bios(pci_dev_t dev, int (*int15_handler)(void), int exec_method)
diff --git a/drivers/video/cfb_console.c b/drivers/video/cfb_console.c
index 30e0317..aa7ca86 100644
--- a/drivers/video/cfb_console.c
+++ b/drivers/video/cfb_console.c
@@ -2247,16 +2247,17 @@
int drv_video_init(void)
{
- int skip_dev_init;
struct stdio_dev console_dev;
bool have_keyboard;
+ bool __maybe_unused keyboard_ok = false;
/* Check if video initialization should be skipped */
if (board_video_skip())
return 0;
/* Init video chip - returns with framebuffer cleared */
- skip_dev_init = (video_init() == -1);
+ if (video_init() == -1)
+ return 0;
if (board_cfb_skip())
return 0;
@@ -2272,11 +2273,9 @@
if (have_keyboard) {
debug("KBD: Keyboard init ...\n");
#if !defined(CONFIG_VGA_AS_SINGLE_DEVICE)
- skip_dev_init |= (VIDEO_KBD_INIT_FCT == -1);
+ keyboard_ok = !(VIDEO_KBD_INIT_FCT == -1);
#endif
}
- if (skip_dev_init)
- return 0;
/* Init vga device */
memset(&console_dev, 0, sizeof(console_dev));
@@ -2287,7 +2286,7 @@
console_dev.puts = video_puts; /* 'puts' function */
#if !defined(CONFIG_VGA_AS_SINGLE_DEVICE)
- if (have_keyboard) {
+ if (have_keyboard && keyboard_ok) {
/* Also init console device */
console_dev.flags |= DEV_FLAGS_INPUT;
console_dev.tstc = VIDEO_TSTC_FCT; /* 'tstc' function */
diff --git a/drivers/video/coreboot_fb.c b/drivers/video/coreboot_fb.c
index 56c35c1..4790ef1 100644
--- a/drivers/video/coreboot_fb.c
+++ b/drivers/video/coreboot_fb.c
@@ -9,6 +9,7 @@
#include <common.h>
#include <asm/arch/tables.h>
#include <asm/arch/sysinfo.h>
+#include <vbe.h>
#include <video_fb.h>
#include "videomodes.h"
@@ -17,6 +18,26 @@
*/
GraphicDevice ctfb;
+static void save_vesa_mode(void)
+{
+ struct vesa_mode_info *vesa = &mode_info.vesa;
+ struct cb_framebuffer *fb = lib_sysinfo.framebuffer;
+
+ vesa->x_resolution = fb->x_resolution;
+ vesa->y_resolution = fb->y_resolution;
+ vesa->bits_per_pixel = fb->bits_per_pixel;
+ vesa->bytes_per_scanline = fb->bytes_per_line;
+ vesa->phys_base_ptr = fb->physical_address;
+ vesa->red_mask_size = fb->red_mask_size;
+ vesa->red_mask_pos = fb->red_mask_pos;
+ vesa->green_mask_size = fb->green_mask_size;
+ vesa->green_mask_pos = fb->green_mask_pos;
+ vesa->blue_mask_size = fb->blue_mask_size;
+ vesa->blue_mask_pos = fb->blue_mask_pos;
+ vesa->reserved_mask_size = fb->reserved_mask_size;
+ vesa->reserved_mask_pos = fb->reserved_mask_pos;
+}
+
static int parse_coreboot_table_fb(GraphicDevice *gdev)
{
struct cb_framebuffer *fb = lib_sysinfo.framebuffer;
@@ -81,5 +102,8 @@
memset((void *)gdev->pciBase, 0,
gdev->winSizeX * gdev->winSizeY * gdev->gdfBytesPP);
+ /* Initialize vesa_mode_info structure */
+ save_vesa_mode();
+
return (void *)gdev;
}
diff --git a/drivers/video/ct69000.c b/drivers/video/ct69000.c
index 168b9ba..22b3441 100644
--- a/drivers/video/ct69000.c
+++ b/drivers/video/ct69000.c
@@ -256,9 +256,6 @@
static const struct ctfb_chips_properties chips[] = {
{PCI_DEVICE_ID_CT_69000, 0x200000, 1, 4, -2, 3, 257, 100, 220},
-#ifdef CONFIG_USE_CPCIDVI
- {PCI_DEVICE_ID_CT_69030, 0x400000, 1, 4, -2, 3, 257, 100, 220},
-#endif
{PCI_DEVICE_ID_CT_65555, 0x100000, 16, 4, 0, 1, 255, 48, 220}, /* NOT TESTED */
{0, 0, 0, 0, 0, 0, 0, 0, 0} /* Terminator */
};
@@ -944,9 +941,6 @@
*/
static struct pci_device_id supported[] = {
{PCI_VENDOR_ID_CT, PCI_DEVICE_ID_CT_69000},
-#ifdef CONFIG_USE_CPCIDVI
- {PCI_VENDOR_ID_CT, PCI_DEVICE_ID_CT_69030},
-#endif
{}
};
@@ -1111,22 +1105,7 @@
pGD->cprBase = pci_mem_base; /* Dummy */
/* set up Hardware */
-#ifdef CONFIG_USE_CPCIDVI
- if (device_id == PCI_DEVICE_ID_CT_69030) {
- ctWrite (CT_MSR_W_O, 0x0b);
- ctWrite (0x3cd, 0x13);
- ctWrite_i (CT_FP_O, 0x02, 0x00);
- ctWrite_i (CT_FP_O, 0x05, 0x00);
- ctWrite_i (CT_FP_O, 0x06, 0x00);
- ctWrite (0x3c2, 0x0b);
- ctWrite_i (CT_FP_O, 0x02, 0x10);
- ctWrite_i (CT_FP_O, 0x01, 0x09);
- } else {
- ctWrite (CT_MSR_W_O, 0x01);
- }
-#else
ctWrite (CT_MSR_W_O, 0x01);
-#endif
/* set the extended Registers */
ctLoadRegs (CT_XR_O, xreg);
diff --git a/include/configs/bayleybay.h b/include/configs/bayleybay.h
index d37a865..1ba2998 100644
--- a/include/configs/bayleybay.h
+++ b/include/configs/bayleybay.h
@@ -16,7 +16,6 @@
#define CONFIG_SYS_MONITOR_LEN (1 << 20)
#define CONFIG_ARCH_MISC_INIT
-#define CONFIG_PCI_CONFIG_HOST_BRIDGE
#define CONFIG_SYS_EARLY_PCI_INIT
#define CONFIG_PCI_PNP
diff --git a/include/configs/crownbay.h b/include/configs/crownbay.h
index 57a9512..998da78 100644
--- a/include/configs/crownbay.h
+++ b/include/configs/crownbay.h
@@ -31,7 +31,6 @@
#define CONFIG_PCI_IO_PHYS CONFIG_PCI_IO_BUS
#define CONFIG_PCI_IO_SIZE 0xe000
-#define CONFIG_PCI_CONFIG_HOST_BRIDGE
#define CONFIG_SYS_EARLY_PCI_INIT
#define CONFIG_PCI_PNP
@@ -54,9 +53,6 @@
#define CONFIG_PCH_GBE
#define CONFIG_PHYLIB
-/* TunnelCreek IGD support */
-#define CONFIG_VGA_AS_SINGLE_DEVICE
-
/* Environment configuration */
#define CONFIG_ENV_SECT_SIZE 0x1000
#define CONFIG_ENV_OFFSET 0
diff --git a/include/configs/minnowmax.h b/include/configs/minnowmax.h
index aeb04b9..53d86a2 100644
--- a/include/configs/minnowmax.h
+++ b/include/configs/minnowmax.h
@@ -19,7 +19,6 @@
#define CONFIG_SMSC_LPC47M
-#define CONFIG_PCI_CONFIG_HOST_BRIDGE
#define CONFIG_SYS_EARLY_PCI_INIT
#define CONFIG_PCI_PNP
#define CONFIG_RTL8169
diff --git a/include/configs/qemu-x86.h b/include/configs/qemu-x86.h
index 72df64e..1b544c1 100644
--- a/include/configs/qemu-x86.h
+++ b/include/configs/qemu-x86.h
@@ -28,7 +28,6 @@
#define CONFIG_PCI_IO_PHYS CONFIG_PCI_IO_BUS
#define CONFIG_PCI_IO_SIZE 0xe000
-#define CONFIG_PCI_CONFIG_HOST_BRIDGE
#define CONFIG_PCI_PNP
#define CONFIG_STD_DEVICES_SETTINGS "stdin=serial,vga\0" \
diff --git a/include/configs/x86-common.h b/include/configs/x86-common.h
index 349b06c..217312e 100644
--- a/include/configs/x86-common.h
+++ b/include/configs/x86-common.h
@@ -87,7 +87,9 @@
#define CONFIG_ISO_PARTITION /* Experimental */
#define CONFIG_CMD_PART
+#ifdef CONFIG_SYS_COREBOOT
#define CONFIG_CMD_CBFS
+#endif
#define CONFIG_CMD_EXT4
#define CONFIG_CMD_EXT4_WRITE
#define CONFIG_PARTITION_UUIDS
@@ -190,6 +192,7 @@
* PCI configuration
*/
#define CONFIG_PCI
+#define CONFIG_PCI_CONFIG_HOST_BRIDGE
/*-----------------------------------------------------------------------
* USB configuration
diff --git a/include/i8042.h b/include/i8042.h
index 58c85ec..e0afce1 100644
--- a/include/i8042.h
+++ b/include/i8042.h
@@ -10,52 +10,67 @@
#ifndef _I8042_H_
#define _I8042_H_
-#ifdef __I386__
-#include <common.h>
-#include <asm/io.h>
-#define in8(p) inb(p)
-#define out8(p,v) outb(v,p)
-#endif
-
/* defines */
-#define I8042_DATA_REG (CONFIG_SYS_ISA_IO + 0x0060) /* keyboard i/o buffer */
-#define I8042_STATUS_REG (CONFIG_SYS_ISA_IO + 0x0064) /* keyboard status read */
-#define I8042_COMMAND_REG (CONFIG_SYS_ISA_IO + 0x0064) /* keyboard ctrl write */
+#define I8042_DATA_REG 0x60 /* keyboard i/o buffer */
+#define I8042_STS_REG 0x64 /* keyboard status read */
+#define I8042_CMD_REG 0x64 /* keyboard ctrl write */
-enum {
- /* Output register (I8042_DATA_REG) has data for system */
- I8042_STATUS_OUT_DATA = 1 << 0,
- I8042_STATUS_IN_DATA = 1 << 1,
-};
+/* Status register bit defines */
+#define STATUS_OBF (1 << 0)
+#define STATUS_IBF (1 << 1)
-#define KBD_US 0 /* default US layout */
-#define KBD_GER 1 /* german layout */
+/* Configuration byte bit defines */
+#define CONFIG_KIRQ_EN (1 << 0)
+#define CONFIG_MIRQ_EN (1 << 1)
+#define CONFIG_SET_BIST (1 << 2)
+#define CONFIG_KCLK_DIS (1 << 4)
+#define CONFIG_MCLK_DIS (1 << 5)
+#define CONFIG_AT_TRANS (1 << 6)
-#define KBD_TIMEOUT 1000 /* 1 sec */
-#define KBD_RESET_TRIES 3
+/* i8042 commands */
+#define CMD_RD_CONFIG 0x20 /* read configuration byte */
+#define CMD_WR_CONFIG 0x60 /* write configuration byte */
+#define CMD_SELF_TEST 0xaa /* controller self-test */
+#define CMD_KBD_DIS 0xad /* keyboard disable */
+#define CMD_KBD_EN 0xae /* keyboard enable */
+#define CMD_SET_KBD_LED 0xed /* set keyboard led */
+#define CMD_RESET_KBD 0xff /* reset keyboard */
-#define AS 0 /* normal character index */
-#define SH 1 /* shift index */
-#define CN 2 /* control index */
-#define NM 3 /* numeric lock index */
-#define AK 4 /* right alt key */
-#define CP 5 /* capslock index */
-#define ST 6 /* stop output index */
-#define EX 7 /* extended code index */
-#define ES 8 /* escape and extended code index */
+/* i8042 command result */
+#define KBC_TEST_OK 0x55
+#define KBD_ACK 0xfa
+#define KBD_POR 0xaa
-#define NORMAL 0x0000 /* normal key */
-#define STP 0x0001 /* scroll lock stop output*/
-#define NUM 0x0002 /* numeric lock */
-#define CAPS 0x0004 /* capslock */
-#define SHIFT 0x0008 /* shift */
-#define CTRL 0x0010 /* control*/
-#define EXT 0x0020 /* extended scan code 0xe0 */
-#define ESC 0x0040 /* escape key press */
-#define E1 0x0080 /* extended scan code 0xe1 */
-#define BRK 0x0100 /* make break flag for keyboard */
-#define ALT 0x0200 /* right alt */
+/* keyboard scan codes */
+
+#define KBD_US 0 /* default US layout */
+#define KBD_GER 1 /* german layout */
+
+#define KBD_TIMEOUT 1000 /* 1 sec */
+#define KBD_RESET_TRIES 3
+
+#define AS 0 /* normal character index */
+#define SH 1 /* shift index */
+#define CN 2 /* control index */
+#define NM 3 /* numeric lock index */
+#define AK 4 /* right alt key */
+#define CP 5 /* capslock index */
+#define ST 6 /* stop output index */
+#define EX 7 /* extended code index */
+#define ES 8 /* escape and extended code index */
+
+#define NORMAL 0x0000 /* normal key */
+#define STP 0x0001 /* scroll lock stop output*/
+#define NUM 0x0002 /* numeric lock */
+#define CAPS 0x0004 /* capslock */
+#define SHIFT 0x0008 /* shift */
+#define CTRL 0x0010 /* control*/
+#define EXT 0x0020 /* extended scan code 0xe0 */
+#define ESC 0x0040 /* escape key press */
+#define E1 0x0080 /* extended scan code 0xe1 */
+#define BRK 0x0100 /* make break flag for keyboard */
+#define ALT 0x0200 /* right alt */
/* exports */
diff --git a/include/pci.h b/include/pci.h
index 488ff44..e24c970 100644
--- a/include/pci.h
+++ b/include/pci.h
@@ -653,6 +653,7 @@
#define pci_io_to_virt(dev, addr, len, map_flags) \
pci_bus_to_virt((dev), (addr), PCI_REGION_IO, (len), (map_flags))
+/* For driver model these are defined in macros in pci_compat.c */
extern int pci_hose_read_config_byte(struct pci_controller *hose,
pci_dev_t dev, int where, u8 *val);
extern int pci_hose_read_config_word(struct pci_controller *hose,
diff --git a/include/smsc_lpc47m.h b/include/smsc_lpc47m.h
index 32b069d..419643f 100644
--- a/include/smsc_lpc47m.h
+++ b/include/smsc_lpc47m.h
@@ -7,14 +7,35 @@
#ifndef _SMSC_LPC47M_H_
#define _SMSC_LPC47M_H_
+/* I/O address of LPC47M */
+#define LPC47M_IO_PORT 0x2e
+
+/* Logical device number */
+#define LPC47M_FDC 0 /* Floppy */
+#define LPC47M_SP2 2 /* Serial Port 2 */
+#define LPC47M_PP 3 /* Parallel Port */
+#define LPC47M_SP1 4 /* Serial Port 1 */
+#define LPC47M_KBC 7 /* Keyboard & Mouse */
+#define LPC47M_PME 10 /* Power Control */
+
/**
* Configure the base I/O port of the specified serial device and enable the
* serial device.
*
- * @dev: High 8 bits = Super I/O port, low 8 bits = logical device number.
- * @iobase: Processor I/O port address to assign to this serial device.
- * @irq: Processor IRQ number to assign to this serial device.
+ * @dev: high 8 bits = super I/O port, low 8 bits = logical device number
+ * @iobase: processor I/O port address to assign to this serial device
+ * @irq: processor IRQ number to assign to this serial device
*/
-void lpc47m_enable_serial(u16 dev, u16 iobase, u8 irq);
+void lpc47m_enable_serial(uint dev, uint iobase, uint irq);
+
+/**
+ * Configure the specified keyboard controller device and enable the keyboard
+ * controller device.
+ *
+ * @dev: high 8 bits = Super I/O port, low 8 bits = logical device number
+ * @irq0: processor IRQ number to assign to keyboard
+ * @irq1: processor IRQ number to assign to mouse
+ */
+void lpc47m_enable_kbc(uint dev, uint irq0, uint irq1);
#endif /* _SMSC_LPC47M_H_ */
diff --git a/include/vbe.h b/include/vbe.h
index 1a86db8..164ccae 100644
--- a/include/vbe.h
+++ b/include/vbe.h
@@ -102,6 +102,8 @@
#define VESA_SET_MODE 0x4f02
#define VESA_GET_CUR_MODE 0x4f03
+extern struct vbe_mode_info mode_info;
+
struct graphic_device;
int vbe_get_video_info(struct graphic_device *gdev);
diff --git a/lib/fdtdec.c b/lib/fdtdec.c
index b65e1e6..81b54f8 100644
--- a/lib/fdtdec.c
+++ b/lib/fdtdec.c
@@ -207,9 +207,8 @@
return 0;
}
- } else {
- list += (len + 1);
}
+ list += (len + 1);
}
return -ENOENT;
diff --git a/scripts/Makefile.lib b/scripts/Makefile.lib
index 1c949fc..ed30bf5 100644
--- a/scripts/Makefile.lib
+++ b/scripts/Makefile.lib
@@ -297,6 +297,17 @@
dtc-tmp = $(subst $(comma),_,$(dot-target).dts.tmp)
+# ACPI
+# ---------------------------------------------------------------------------
+quiet_cmd_acpi_c_asl= ASL $@
+cmd_acpi_c_asl= \
+ $(CPP) -x assembler-with-cpp -P -o $<.tmp $<; \
+ iasl -p $< -tc -va $<.tmp; \
+ mv $(patsubst %.asl,%.hex,$<) $@
+
+$(obj)/%.c: $(src)/%.asl
+ $(call cmd,acpi_c_asl)
+
# Bzip2
# ---------------------------------------------------------------------------
diff --git a/tools/ifdtool.c b/tools/ifdtool.c
index df16616..1f95203 100644
--- a/tools/ifdtool.c
+++ b/tools/ifdtool.c
@@ -706,10 +706,11 @@
* 0xffffffff so use an address relative to that. For an
* 8MB ROM the start address is 0xfff80000.
* @write_fname: Filename to add to the image
+ * @offset_uboot_top: Offset of the top of U-Boot
* @return number of bytes written if OK, -ve on error
*/
static int write_data(char *image, int size, unsigned int addr,
- const char *write_fname)
+ const char *write_fname, int offset_uboot_top)
{
int write_fd, write_size;
int offset;
@@ -719,6 +720,14 @@
return write_fd;
offset = (uint32_t)(addr + size);
+ if (offset_uboot_top && offset_uboot_top >= offset) {
+ fprintf(stderr, "U-Boot image overlaps with region '%s'\n",
+ write_fname);
+ fprintf(stderr,
+ "U-Boot finishes at offset %x, file starts at %x\n",
+ offset_uboot_top, offset);
+ return -EXDEV;
+ }
debug("Writing %s to offset %#x\n", write_fname, offset);
if (offset < 0 || offset + write_size > size) {
@@ -737,6 +746,171 @@
return write_size;
}
+static int scan_ucode(const void *blob, char *ucode_base, int *countp,
+ const char **datap, int *data_sizep)
+{
+ const char *data = NULL;
+ int node, count;
+ int data_size;
+ char *ucode;
+
+ for (node = 0, count = 0, ucode = ucode_base; node >= 0; count++) {
+ node = fdt_node_offset_by_compatible(blob, node,
+ "intel,microcode");
+ if (node < 0)
+ break;
+
+ data = fdt_getprop(blob, node, "data", &data_size);
+ if (!data) {
+ debug("Missing microcode data in FDT '%s': %s\n",
+ fdt_get_name(blob, node, NULL),
+ fdt_strerror(data_size));
+ return -ENOENT;
+ }
+
+ if (ucode_base)
+ memcpy(ucode, data, data_size);
+ ucode += data_size;
+ }
+
+ if (countp)
+ *countp = count;
+ if (datap)
+ *datap = data;
+ if (data_sizep)
+ *data_sizep = data_size;
+
+ return ucode - ucode_base;
+}
+
+static int remove_ucode(char *blob)
+{
+ int node, count;
+ int ret;
+
+ /* Keep going until we find no more microcode to remove */
+ do {
+ for (node = 0, count = 0; node >= 0;) {
+ int ret;
+
+ node = fdt_node_offset_by_compatible(blob, node,
+ "intel,microcode");
+ if (node < 0)
+ break;
+
+ ret = fdt_delprop(blob, node, "data");
+
+ /*
+ * -FDT_ERR_NOTFOUND means we already removed the
+ * data for this one, so we just continue.
+ * 0 means we did remove it, so offsets may have
+ * changed and we need to restart our scan.
+ * Anything else indicates an error we should report.
+ */
+ if (ret == -FDT_ERR_NOTFOUND)
+ continue;
+ else if (!ret)
+ node = 0;
+ else
+ return ret;
+ }
+ } while (count);
+
+ /* Pack down to remove excees space */
+ ret = fdt_pack(blob);
+ if (ret)
+ return ret;
+
+ return fdt_totalsize(blob);
+}
+
+static int write_ucode(char *image, int size, struct input_file *fdt,
+ int fdt_size, unsigned int ucode_ptr,
+ int collate_ucode)
+{
+ const char *data = NULL;
+ char *ucode_buf;
+ const void *blob;
+ char *ucode_base;
+ uint32_t *ptr;
+ int ucode_size;
+ int data_size;
+ int offset;
+ int count;
+ int ret;
+
+ blob = (void *)image + (uint32_t)(fdt->addr + size);
+
+ debug("DTB at %lx\n", (char *)blob - image);
+
+ /* Find out about the micrcode we have */
+ ucode_size = scan_ucode(blob, NULL, &count, &data, &data_size);
+ if (ucode_size < 0)
+ return ucode_size;
+ if (!count) {
+ debug("No microcode found in FDT\n");
+ return -ENOENT;
+ }
+
+ if (count > 1 && !collate_ucode) {
+ fprintf(stderr,
+ "Cannot handle multiple microcode blocks - please use -C flag to collate them\n");
+ return -EMLINK;
+ }
+
+ /*
+ * Collect the microcode into a buffer, remove it from the device
+ * tree and place it immediately above the (now smaller) device tree.
+ */
+ if (collate_ucode && count > 1) {
+ ucode_buf = malloc(ucode_size);
+ if (!ucode_buf) {
+ fprintf(stderr,
+ "Out of memory for microcode (%d bytes)\n",
+ ucode_size);
+ return -ENOMEM;
+ }
+ ret = scan_ucode(blob, ucode_buf, NULL, NULL, NULL);
+ if (ret < 0)
+ return ret;
+
+ /* Remove the microcode from the device tree */
+ ret = remove_ucode((char *)blob);
+ if (ret < 0) {
+ debug("Could not remove FDT microcode: %s\n",
+ fdt_strerror(ret));
+ return -EINVAL;
+ }
+ debug("Collated %d microcode block(s)\n", count);
+ debug("Device tree reduced from %x to %x bytes\n",
+ fdt_size, ret);
+ fdt_size = ret;
+
+ /*
+ * Place microcode area immediately above the FDT, aligned
+ * to a 16-byte boundary.
+ */
+ ucode_base = (char *)(((unsigned long)blob + fdt_size + 15) &
+ ~15);
+
+ data = ucode_base;
+ data_size = ucode_size;
+ memcpy(ucode_base, ucode_buf, ucode_size);
+ free(ucode_buf);
+ }
+
+ offset = (uint32_t)(ucode_ptr + size);
+ ptr = (void *)image + offset;
+
+ ptr[0] = (data - image) - size;
+ ptr[1] = data_size;
+ debug("Wrote microcode pointer at %x: addr=%x, size=%x\n", ucode_ptr,
+ ptr[0], ptr[1]);
+
+ return (collate_ucode ? data + data_size : (char *)blob + fdt_size) -
+ image;
+}
+
/**
* write_uboot() - Write U-Boot, device tree and microcode pointer
*
@@ -752,51 +926,28 @@
* @return 0 if OK, -ve on error
*/
static int write_uboot(char *image, int size, struct input_file *uboot,
- struct input_file *fdt, unsigned int ucode_ptr)
+ struct input_file *fdt, unsigned int ucode_ptr,
+ int collate_ucode)
{
const void *blob;
- const char *data;
- int uboot_size;
- uint32_t *ptr;
- int data_size;
- int offset;
- int node;
- int ret;
+ int uboot_size, fdt_size;
- uboot_size = write_data(image, size, uboot->addr, uboot->fname);
+ uboot_size = write_data(image, size, uboot->addr, uboot->fname, 0);
if (uboot_size < 0)
return uboot_size;
fdt->addr = uboot->addr + uboot_size;
debug("U-Boot size %#x, FDT at %#x\n", uboot_size, fdt->addr);
- ret = write_data(image, size, fdt->addr, fdt->fname);
- if (ret < 0)
- return ret;
+ fdt_size = write_data(image, size, fdt->addr, fdt->fname, 0);
+ if (fdt_size < 0)
+ return fdt_size;
+ blob = (void *)image + (uint32_t)(fdt->addr + size);
if (ucode_ptr) {
- blob = (void *)image + (uint32_t)(fdt->addr + size);
- debug("DTB at %lx\n", (char *)blob - image);
- node = fdt_node_offset_by_compatible(blob, 0,
- "intel,microcode");
- if (node < 0) {
- debug("No microcode found in FDT: %s\n",
- fdt_strerror(node));
- return -ENOENT;
- }
- data = fdt_getprop(blob, node, "data", &data_size);
- if (!data) {
- debug("No microcode data found in FDT: %s\n",
- fdt_strerror(data_size));
- return -ENOENT;
- }
- offset = (uint32_t)(ucode_ptr + size);
- ptr = (void *)image + offset;
- ptr[0] = (data - image) - size;
- ptr[1] = data_size;
- debug("Wrote microcode pointer at %x: addr=%x, size=%x\n",
- ucode_ptr, ptr[0], ptr[1]);
+ return write_ucode(image, size, fdt, fdt_size, ucode_ptr,
+ collate_ucode);
}
- return 0;
+ return ((char *)blob + fdt_size) - image;
}
static void print_version(void)
@@ -860,7 +1011,7 @@
int mode_dump = 0, mode_extract = 0, mode_inject = 0;
int mode_spifreq = 0, mode_em100 = 0, mode_locked = 0;
int mode_unlocked = 0, mode_write = 0, mode_write_descriptor = 0;
- int create = 0;
+ int create = 0, collate_ucode = 0;
char *region_type_string = NULL, *inject_fname = NULL;
char *desc_fname = NULL, *addr_str = NULL;
int region_type = -1, inputfreq = 0;
@@ -880,6 +1031,7 @@
int ret;
static struct option long_options[] = {
{"create", 0, NULL, 'c'},
+ {"collate-microcode", 0, NULL, 'C'},
{"dump", 0, NULL, 'd'},
{"descriptor", 1, NULL, 'D'},
{"em100", 0, NULL, 'e'},
@@ -898,12 +1050,15 @@
{0, 0, 0, 0}
};
- while ((opt = getopt_long(argc, argv, "cdD:ef:hi:lm:r:s:uU:vw:x?",
+ while ((opt = getopt_long(argc, argv, "cCdD:ef:hi:lm:r:s:uU:vw:x?",
long_options, &option_index)) != EOF) {
switch (opt) {
case 'c':
create = 1;
break;
+ case 'C':
+ collate_ucode = 1;
+ break;
case 'd':
mode_dump = 1;
break;
@@ -1113,22 +1268,25 @@
}
if (mode_write_descriptor)
- ret = write_data(image, size, -size, desc_fname);
+ ret = write_data(image, size, -size, desc_fname, 0);
if (mode_inject)
ret = inject_region(image, size, region_type, inject_fname);
if (mode_write) {
+ int offset_uboot_top = 0;
+
for (wr_idx = 0; wr_idx < wr_num; wr_idx++) {
ifile = &input_file[wr_idx];
if (ifile->type == IF_fdt) {
continue;
} else if (ifile->type == IF_uboot) {
ret = write_uboot(image, size, ifile, fdt,
- ucode_ptr);
+ ucode_ptr, collate_ucode);
+ offset_uboot_top = ret;
} else {
ret = write_data(image, size, ifile->addr,
- ifile->fname);
+ ifile->fname, offset_uboot_top);
}
if (ret < 0)
break;
diff --git a/tools/patman/gitutil.py b/tools/patman/gitutil.py
index 9e739d8..67b086b 100644
--- a/tools/patman/gitutil.py
+++ b/tools/patman/gitutil.py
@@ -264,7 +264,7 @@
"""
if series.get('version'):
version = '%s ' % series['version']
- cmd = ['git', 'format-patch', '-M', '--signoff']
+ cmd = ['git', 'format-patch', '-D', '-M', '--signoff']
if series.get('cover'):
cmd.append('--cover-letter')
prefix = series.GetPatchPrefix()