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()