sonic-buildimage/platform/mellanox/non-upstream-patches/patches/0220-UBUNTU-SAUCE-pka-Add-pka-driver.patch

10219 lines
430 KiB
Diff
Raw Normal View History

From c1e48283efef4faeee6b601fc679ea228bd8d6ef Mon Sep 17 00:00:00 2001
From: Mahantesh Salimath <mahantesh@nvidia.com>
Date: Thu, 30 Jun 2022 16:46:50 -0400
Subject: [PATCH backport 5.10 21/63] UBUNTU: SAUCE: pka: Add pka driver.
BugLink: https://bugs.launchpad.net/bugs/1980415
* This driver is picked from internal linux repo;bfdev-5.4.60 branch.
For commit history, please refer to above repo and branch.
Signed-off-by: Mahantesh Salimath <mahantesh@nvidia.com>
Reviewed-by: Khalil Blaiech <kblaiech@nvidia.com>
Signed-off-by: Mahantesh Salimath <mahantesh@nvidia.com>
Signed-off-by: Ike Panhc <ike.pan@canonical.com>
---
drivers/platform/mellanox/Kconfig | 2 +
drivers/platform/mellanox/Makefile | 1 +
drivers/platform/mellanox/mlxbf_pka/Kconfig | 14 +
drivers/platform/mellanox/mlxbf_pka/Makefile | 9 +
.../mellanox/mlxbf_pka/mlxbf_pka_addrs.h | 284 +
.../mellanox/mlxbf_pka/mlxbf_pka_config.h | 226 +
.../mellanox/mlxbf_pka/mlxbf_pka_cpu.h | 72 +
.../mellanox/mlxbf_pka/mlxbf_pka_debug.h | 66 +
.../mellanox/mlxbf_pka/mlxbf_pka_dev.c | 2414 +++++++++
.../mellanox/mlxbf_pka/mlxbf_pka_dev.h | 310 ++
.../mellanox/mlxbf_pka/mlxbf_pka_drv.c | 1398 +++++
.../mellanox/mlxbf_pka/mlxbf_pka_firmware.h | 4823 +++++++++++++++++
.../mellanox/mlxbf_pka/mlxbf_pka_ioctl.h | 127 +
.../mellanox/mlxbf_pka/mlxbf_pka_mmio.h | 49 +
.../mellanox/mlxbf_pka/mlxbf_pka_ring.h | 276 +
15 files changed, 10071 insertions(+)
create mode 100644 drivers/platform/mellanox/mlxbf_pka/Kconfig
create mode 100644 drivers/platform/mellanox/mlxbf_pka/Makefile
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_addrs.h
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_config.h
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_cpu.h
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_debug.h
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_dev.c
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_dev.h
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_drv.c
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_firmware.h
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_ioctl.h
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_mmio.h
create mode 100644 drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_ring.h
diff --git a/drivers/platform/mellanox/Kconfig b/drivers/platform/mellanox/Kconfig
index 5d329350a..946bc2375 100644
--- a/drivers/platform/mellanox/Kconfig
+++ b/drivers/platform/mellanox/Kconfig
@@ -97,6 +97,8 @@ config MLXBF_TRIO
This driver supports the TRIO PCIe root complex interface on
Mellanox BlueField SoCs.
+source "drivers/platform/mellanox/mlxbf_pka/Kconfig"
+
config NVSW_SN2201
tristate "Nvidia SN2201 platform driver support"
depends on REGMAP
diff --git a/drivers/platform/mellanox/Makefile b/drivers/platform/mellanox/Makefile
[202311][Mellanox] Integrate HW-MGMT Version 7.0030.2008 (#17659) * Intgerate HW-MGMT 7.0030.2008 Changes ## Patch List * 0285-UBUNTU-SAUCE-mlxbf-gige-Fix-intermittent-no-ip-issue.patch : * 0286-pinctrl-Introduce-struct-pinfunction-and-PINCTRL_PIN.patch : * 0287-pinctrl-mlxbf3-Add-pinctrl-driver-support.patch : * 0288-UBUNTU-SAUCE-gpio-mmio-handle-ngpios-properly-in-bgp.patch : * 0289-UBUNTU-SAUCE-gpio-mlxbf3-Add-gpio-driver-support.patch : * 0291-mlxsw-core_hwmon-Align-modules-label-name-assignment.patch : * 0292-mlxsw-i2c-Limit-single-transaction-buffer-size.patch : * 0293-mlxsw-reg-Limit-MTBR-register-records-buffer-by-one-.patch : * 0296-UBUNTU-SAUCE-mmc-sdhci-of-dwcmshc-Add-runtime-PM-ope.patch : * 0298-UBUNTU-SAUCE-mlxbf-ptm-use-0444-instead-of-S_IRUGO.patch : * 0299-UBUNTU-SAUCE-mlxbf-ptm-add-atx-debugfs-nodes.patch : * 0300-UBUNTU-SAUCE-mlxbf-ptm-update-module-version.patch : * 0301-UBUNTU-SAUCE-mlxbf-gige-Fix-kernel-panic-at-shutdown.patch : * 0302-UBUNTU-SAUCE-mlxbf-bootctl-support-SMC-call-for-sett.patch : * 0303-UBUNTU-SAUCE-Add-BF3-related-ACPI-config-and-Ring-de.patch : * 0306-dt-bindings-trivial-devices-Add-infineon-xdpe1a2g7.patch : * 0307-leds-mlxreg-Add-support-for-new-flavour-of-capabilit.patch : * 0308-leds-mlxreg-Remove-code-for-amber-LED-colour.patch : * 0308-platform_data-mlxreg-Add-capability-bit-and-mask-fie.patch : * 0309-hwmon-mlxreg-fan-Add-support-for-new-flavour-of-capa.patch : * 0310-hwmon-mlxreg-fan-Extend-number-of-supporetd-fans.patch : * 0317-platform-mellanox-Introduce-support-for-switches-equ.patch : * 0318-mellanox-Relocate-mlx-platform-driver.patch : * 0319-UBUNTU-SAUCE-mlxbf-tmfifo-fix-potential-race.patch : * 0320-UBUNTU-SAUCE-mlxbf-tmfifo-Drop-the-Rx-packet-if-no-m.patch : * 0321-UBUNTU-SAUCE-mlxbf-tmfifo-Drop-jumbo-frames.patch : * 0322-UBUNTU-SAUCE-mlxbf-tmfifo.c-Amend-previous-tmfifo-pa.patch : * 0323-mlxbf_gige-add-set_link_ksettings-ethtool-callback.patch : * 0324-mlxbf_gige-fix-white-space-in-mlxbf_gige_eth_ioctl.patch : * 0325-UBUNTU-SAUCE-mlxbf-bootctl-Fix-kernel-panic-due-to-b.patch : * 0326-platform-mellanox-mlxreg-hotplug-Add-support-for-new.patch : * 0327-platform-mellanox-mlx-platform-Change-register-name.patch : * 0328-platform-mellanox-mlx-platform-Add-support-for-new-X.patch : * [Mellanox] Don't populate arm64 Kconfig when integrating hw-mgmt Signed-off-by: Vivek Reddy <vkarri@nvidia.com> * [Mellanox] Remove thermal zone related code and replace with new one * Revert "Revert "[Mellanox] Align PSU temperature sysfs node name with hw-management change (#16820)" (#16956)" This reverts commit c2edc6f9d5fd812d89873e47456ae6c38bc05dee. * Update copyright header Signed-off-by: Kebo Liu <kebol@nvidia.com> --------- Signed-off-by: Vivek Reddy <vkarri@nvidia.com> Signed-off-by: Kebo Liu <kebol@nvidia.com> Co-authored-by: Vivek Reddy <vkarri@nvidia.com> Co-authored-by: Junchao-Mellanox <junchao@nvidia.com> Co-authored-by: Junchao-Mellanox <57339448+Junchao-Mellanox@users.noreply.github.com>
2024-01-16 10:33:50 -06:00
index a0a073adb..d89931e36 100644
--- a/drivers/platform/mellanox/Makefile
+++ b/drivers/platform/mellanox/Makefile
[202311][Mellanox] Integrate HW-MGMT Version 7.0030.2008 (#17659) * Intgerate HW-MGMT 7.0030.2008 Changes ## Patch List * 0285-UBUNTU-SAUCE-mlxbf-gige-Fix-intermittent-no-ip-issue.patch : * 0286-pinctrl-Introduce-struct-pinfunction-and-PINCTRL_PIN.patch : * 0287-pinctrl-mlxbf3-Add-pinctrl-driver-support.patch : * 0288-UBUNTU-SAUCE-gpio-mmio-handle-ngpios-properly-in-bgp.patch : * 0289-UBUNTU-SAUCE-gpio-mlxbf3-Add-gpio-driver-support.patch : * 0291-mlxsw-core_hwmon-Align-modules-label-name-assignment.patch : * 0292-mlxsw-i2c-Limit-single-transaction-buffer-size.patch : * 0293-mlxsw-reg-Limit-MTBR-register-records-buffer-by-one-.patch : * 0296-UBUNTU-SAUCE-mmc-sdhci-of-dwcmshc-Add-runtime-PM-ope.patch : * 0298-UBUNTU-SAUCE-mlxbf-ptm-use-0444-instead-of-S_IRUGO.patch : * 0299-UBUNTU-SAUCE-mlxbf-ptm-add-atx-debugfs-nodes.patch : * 0300-UBUNTU-SAUCE-mlxbf-ptm-update-module-version.patch : * 0301-UBUNTU-SAUCE-mlxbf-gige-Fix-kernel-panic-at-shutdown.patch : * 0302-UBUNTU-SAUCE-mlxbf-bootctl-support-SMC-call-for-sett.patch : * 0303-UBUNTU-SAUCE-Add-BF3-related-ACPI-config-and-Ring-de.patch : * 0306-dt-bindings-trivial-devices-Add-infineon-xdpe1a2g7.patch : * 0307-leds-mlxreg-Add-support-for-new-flavour-of-capabilit.patch : * 0308-leds-mlxreg-Remove-code-for-amber-LED-colour.patch : * 0308-platform_data-mlxreg-Add-capability-bit-and-mask-fie.patch : * 0309-hwmon-mlxreg-fan-Add-support-for-new-flavour-of-capa.patch : * 0310-hwmon-mlxreg-fan-Extend-number-of-supporetd-fans.patch : * 0317-platform-mellanox-Introduce-support-for-switches-equ.patch : * 0318-mellanox-Relocate-mlx-platform-driver.patch : * 0319-UBUNTU-SAUCE-mlxbf-tmfifo-fix-potential-race.patch : * 0320-UBUNTU-SAUCE-mlxbf-tmfifo-Drop-the-Rx-packet-if-no-m.patch : * 0321-UBUNTU-SAUCE-mlxbf-tmfifo-Drop-jumbo-frames.patch : * 0322-UBUNTU-SAUCE-mlxbf-tmfifo.c-Amend-previous-tmfifo-pa.patch : * 0323-mlxbf_gige-add-set_link_ksettings-ethtool-callback.patch : * 0324-mlxbf_gige-fix-white-space-in-mlxbf_gige_eth_ioctl.patch : * 0325-UBUNTU-SAUCE-mlxbf-bootctl-Fix-kernel-panic-due-to-b.patch : * 0326-platform-mellanox-mlxreg-hotplug-Add-support-for-new.patch : * 0327-platform-mellanox-mlx-platform-Change-register-name.patch : * 0328-platform-mellanox-mlx-platform-Add-support-for-new-X.patch : * [Mellanox] Don't populate arm64 Kconfig when integrating hw-mgmt Signed-off-by: Vivek Reddy <vkarri@nvidia.com> * [Mellanox] Remove thermal zone related code and replace with new one * Revert "Revert "[Mellanox] Align PSU temperature sysfs node name with hw-management change (#16820)" (#16956)" This reverts commit c2edc6f9d5fd812d89873e47456ae6c38bc05dee. * Update copyright header Signed-off-by: Kebo Liu <kebol@nvidia.com> --------- Signed-off-by: Vivek Reddy <vkarri@nvidia.com> Signed-off-by: Kebo Liu <kebol@nvidia.com> Co-authored-by: Vivek Reddy <vkarri@nvidia.com> Co-authored-by: Junchao-Mellanox <junchao@nvidia.com> Co-authored-by: Junchao-Mellanox <57339448+Junchao-Mellanox@users.noreply.github.com>
2024-01-16 10:33:50 -06:00
@@ -9,5 +9,6 @@ obj-$(CONFIG_MLXBF_TMFIFO) += mlxbf-tmfifo.o
obj-$(CONFIG_MLXBF_TRIO) += mlx-trio.o
obj-$(CONFIG_MLXREG_HOTPLUG) += mlxreg-hotplug.o
obj-$(CONFIG_MLXREG_IO) += mlxreg-io.o
[202311][Mellanox] Integrate HW-MGMT Version 7.0030.2008 (#17659) * Intgerate HW-MGMT 7.0030.2008 Changes ## Patch List * 0285-UBUNTU-SAUCE-mlxbf-gige-Fix-intermittent-no-ip-issue.patch : * 0286-pinctrl-Introduce-struct-pinfunction-and-PINCTRL_PIN.patch : * 0287-pinctrl-mlxbf3-Add-pinctrl-driver-support.patch : * 0288-UBUNTU-SAUCE-gpio-mmio-handle-ngpios-properly-in-bgp.patch : * 0289-UBUNTU-SAUCE-gpio-mlxbf3-Add-gpio-driver-support.patch : * 0291-mlxsw-core_hwmon-Align-modules-label-name-assignment.patch : * 0292-mlxsw-i2c-Limit-single-transaction-buffer-size.patch : * 0293-mlxsw-reg-Limit-MTBR-register-records-buffer-by-one-.patch : * 0296-UBUNTU-SAUCE-mmc-sdhci-of-dwcmshc-Add-runtime-PM-ope.patch : * 0298-UBUNTU-SAUCE-mlxbf-ptm-use-0444-instead-of-S_IRUGO.patch : * 0299-UBUNTU-SAUCE-mlxbf-ptm-add-atx-debugfs-nodes.patch : * 0300-UBUNTU-SAUCE-mlxbf-ptm-update-module-version.patch : * 0301-UBUNTU-SAUCE-mlxbf-gige-Fix-kernel-panic-at-shutdown.patch : * 0302-UBUNTU-SAUCE-mlxbf-bootctl-support-SMC-call-for-sett.patch : * 0303-UBUNTU-SAUCE-Add-BF3-related-ACPI-config-and-Ring-de.patch : * 0306-dt-bindings-trivial-devices-Add-infineon-xdpe1a2g7.patch : * 0307-leds-mlxreg-Add-support-for-new-flavour-of-capabilit.patch : * 0308-leds-mlxreg-Remove-code-for-amber-LED-colour.patch : * 0308-platform_data-mlxreg-Add-capability-bit-and-mask-fie.patch : * 0309-hwmon-mlxreg-fan-Add-support-for-new-flavour-of-capa.patch : * 0310-hwmon-mlxreg-fan-Extend-number-of-supporetd-fans.patch : * 0317-platform-mellanox-Introduce-support-for-switches-equ.patch : * 0318-mellanox-Relocate-mlx-platform-driver.patch : * 0319-UBUNTU-SAUCE-mlxbf-tmfifo-fix-potential-race.patch : * 0320-UBUNTU-SAUCE-mlxbf-tmfifo-Drop-the-Rx-packet-if-no-m.patch : * 0321-UBUNTU-SAUCE-mlxbf-tmfifo-Drop-jumbo-frames.patch : * 0322-UBUNTU-SAUCE-mlxbf-tmfifo.c-Amend-previous-tmfifo-pa.patch : * 0323-mlxbf_gige-add-set_link_ksettings-ethtool-callback.patch : * 0324-mlxbf_gige-fix-white-space-in-mlxbf_gige_eth_ioctl.patch : * 0325-UBUNTU-SAUCE-mlxbf-bootctl-Fix-kernel-panic-due-to-b.patch : * 0326-platform-mellanox-mlxreg-hotplug-Add-support-for-new.patch : * 0327-platform-mellanox-mlx-platform-Change-register-name.patch : * 0328-platform-mellanox-mlx-platform-Add-support-for-new-X.patch : * [Mellanox] Don't populate arm64 Kconfig when integrating hw-mgmt Signed-off-by: Vivek Reddy <vkarri@nvidia.com> * [Mellanox] Remove thermal zone related code and replace with new one * Revert "Revert "[Mellanox] Align PSU temperature sysfs node name with hw-management change (#16820)" (#16956)" This reverts commit c2edc6f9d5fd812d89873e47456ae6c38bc05dee. * Update copyright header Signed-off-by: Kebo Liu <kebol@nvidia.com> --------- Signed-off-by: Vivek Reddy <vkarri@nvidia.com> Signed-off-by: Kebo Liu <kebol@nvidia.com> Co-authored-by: Vivek Reddy <vkarri@nvidia.com> Co-authored-by: Junchao-Mellanox <junchao@nvidia.com> Co-authored-by: Junchao-Mellanox <57339448+Junchao-Mellanox@users.noreply.github.com>
2024-01-16 10:33:50 -06:00
+obj-$(CONFIG_MLXBF_PKA) += mlxbf_pka/
obj-$(CONFIG_MLXREG_LC) += mlxreg-lc.o
obj-$(CONFIG_NVSW_SN2201) += nvsw-sn2201.o
diff --git a/drivers/platform/mellanox/mlxbf_pka/Kconfig b/drivers/platform/mellanox/mlxbf_pka/Kconfig
new file mode 100644
index 000000000..ebc038ec7
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/Kconfig
@@ -0,0 +1,14 @@
+# SPDX-License-Identifier: GPL-2.0-only OR Linux-OpenIB
+#
+# Platform support for Mellanox BlueField PKA
+#
+
+config MLXBF_PKA
+ tristate "Mellanox BlueField Public Key Accelerator driver"
+ depends on ARM64 && IOMMU_API && VFIO_IOMMU_TYPE1 && VFIO_PLATFORM
+ help
+ If you say yes to this option, support will be included for the
+ Public Key Accelerator device on Mellanox BlueField SoCs.
+
+ This driver can also be built as a module. If so, the module will
+ be called pka-mlxbf.
diff --git a/drivers/platform/mellanox/mlxbf_pka/Makefile b/drivers/platform/mellanox/mlxbf_pka/Makefile
new file mode 100644
index 000000000..d9f5be4d6
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/Makefile
@@ -0,0 +1,9 @@
+# SPDX-License-Identifier: GPL-2.0-only OR Linux-OpenIB
+#
+# Makefile for Mellanox BlueField PKA Driver
+#
+
+obj-m += mlxbf-pka.o
+
+mlxbf-pka-y := mlxbf_pka_drv.o
+mlxbf-pka-y += mlxbf_pka_dev.o
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_addrs.h b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_addrs.h
new file mode 100644
index 000000000..cd2a4d814
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_addrs.h
@@ -0,0 +1,284 @@
+//
+// BSD LICENSE
+//
+// Copyright(c) 2016 Mellanox Technologies, Ltd. All rights reserved.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in
+// the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Mellanox Technologies nor the names of its
+// contributors may be used to endorse or promote products derived
+// from this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+
+#ifndef __PKA_ADDRS_H__
+#define __PKA_ADDRS_H__
+
+// Define memory size in bytes
+#define MEM_SIZE_4KB 0x1000
+#define MEM_SIZE_8KB 0x2000
+#define MEM_SIZE_16KB 0x4000
+#define MEM_SIZE_32KB 0x8000
+#define MEM_SIZE_64KB 0x10000
+
+//
+// COMMON SPACE
+//
+#define CRYPTO_COMMON_BASE 0x0
+
+// Common IO CSR addresses/offsets: These are all addressed as 8-byte registers.
+#define DEV_INFO_ADDR (0x00 | CRYPTO_COMMON_BASE)
+#define DEV_CTL_ADDR (0x08 | CRYPTO_COMMON_BASE)
+#define MMIO_INFO_ADDR (0x10 | CRYPTO_COMMON_BASE)
+#define SCRATCHPAD_ADDR (0x20 | CRYPTO_COMMON_BASE)
+#define SEMAPHORE0_ADDR (0x28 | CRYPTO_COMMON_BASE)
+#define SEMAPHORE1_ADDR (0x30 | CRYPTO_COMMON_BASE)
+#define CLOCK_COUNT_ADDR (0x38 | CRYPTO_COMMON_BASE)
+#define INT_SETUP_ADDR (0x40 | CRYPTO_COMMON_BASE)
+#define CRED_CTL_ADDR (0x50 | CRYPTO_COMMON_BASE)
+#define SAM_CTL_ADDR (0x58 | CRYPTO_COMMON_BASE)
+
+//
+// CRYPTO SPACE
+//
+
+// All addresses/offsets herein are BYTE addresses.
+
+// EIP154 CSRS:
+
+// Global Control Space CSR addresses/offsets. These are accessed from the
+// ARM as 8 byte reads/writes however only the bottom 32 bits are implemented.
+#define PKA_CLOCK_SWITCH_ADDR 0x11C68
+#define PKA_CLK_FORCE_ADDR 0x11C80
+#define MODE_SELECTION_ADDR 0x11C88
+#define PKA_PROT_STATUS_ADDR 0x11C90
+#define PKA_OPTIONS_ADDR 0x11DF0
+#define PKA_VERSION_ADDR 0x11DF8
+
+// Advanced Interrupt Controller CSR addresses/offsets. These are accessed
+// from the ARM as 8 byte reads/writes however only the bottom 32 bits are
+// implemented.
+#define AIC_POL_CTRL_ADDR 0x11E00
+#define AIC_TYPE_CTRL_ADDR 0x11E08
+#define AIC_ENABLE_CTRL_ADDR 0x11E10
+#define AIC_RAW_STAT_ADDR 0x11E18
+#define AIC_ENABLE_SET_ADDR 0x11E18
+#define AIC_ENABLED_STAT_ADDR 0x11E20
+#define AIC_ACK_ADDR 0x11E20
+#define AIC_ENABLE_CLR_ADDR 0x11E28
+#define AIC_OPTIONS_ADDR 0x11E30
+#define AIC_VERSION_ADDR 0x11E38
+
+// The True Random Number Generator CSR addresses/offsets. These are accessed
+// from the ARM as 8 byte reads/writes however only the bottom 32 bits are
+// implemented.
+#define TRNG_OUTPUT_0_ADDR 0x12000
+#define TRNG_OUTPUT_1_ADDR 0x12008
+#define TRNG_OUTPUT_2_ADDR 0x12010
+#define TRNG_OUTPUT_3_ADDR 0x12018
+#define TRNG_STATUS_ADDR 0x12020
+#define TRNG_INTACK_ADDR 0x12020
+#define TRNG_CONTROL_ADDR 0x12028
+#define TRNG_CONFIG_ADDR 0x12030
+#define TRNG_ALARMCNT_ADDR 0x12038
+#define TRNG_FROENABLE_ADDR 0x12040
+#define TRNG_FRODETUNE_ADDR 0x12048
+#define TRNG_ALARMMASK_ADDR 0x12050
+#define TRNG_ALARMSTOP_ADDR 0x12058
+#define TRNG_BLOCKCNT_ADDR 0x120E8
+#define TRNG_OPTIONS_ADDR 0x120F0
+#define TRNG_TEST_ADDR 0x120E0
+#define TRNG_RAW_L_ADDR 0x12060
+#define TRNG_RAW_H_ADDR 0x12068
+#define TRNG_RUN_CNT_ADDR 0x12080
+#define TRNG_MONOBITCNT_ADDR 0x120B8
+#define TRNG_POKER_3_0_ADDR 0x120C0
+#define TRNG_POKER_7_4 0x120C8
+#define TRNG_POKER_B_8 0x120D0
+#define TRNG_POKER_F_C 0x120D8
+
+#define TRNG_PS_AI_0_ADDR 0x12080
+#define TRNG_PS_AI_1_ADDR 0x12088
+#define TRNG_PS_AI_2_ADDR 0x12090
+#define TRNG_PS_AI_3_ADDR 0x12098
+#define TRNG_PS_AI_4_ADDR 0x120A0
+#define TRNG_PS_AI_5_ADDR 0x120A8
+#define TRNG_PS_AI_6_ADDR 0x120B0
+#define TRNG_PS_AI_7_ADDR 0x120B8
+#define TRNG_PS_AI_8_ADDR 0x120C0
+#define TRNG_PS_AI_9_ADDR 0x120C8
+#define TRNG_PS_AI_10_ADDR 0x120D0
+#define TRNG_PS_AI_11_ADDR 0x120D8
+
+// Control register address/offset. This is accessed from the ARM using 8
+// byte reads/writes however only the bottom 32 bits are implemented.
+#define PKA_MASTER_SEQ_CTRL_ADDR 0x27F90
+
+// Ring CSRs: These are all accessed from the ARM using 8 byte reads/writes
+// however only the bottom 32 bits are implemented.
+
+// Ring 0 CSRS
+#define COMMAND_COUNT_0_ADDR 0x80080
+#define RESULT_COUNT_0_ADDR 0x80088
+#define IRQ_THRESH_0_ADDR 0x80090
+
+// Ring 1 CSRS:
+#define COMMAND_COUNT_1_ADDR 0x90080
+#define RESULT_COUNT_1_ADDR 0x90088
+#define IRQ_THRESH_1_ADDR 0x90090
+
+// Ring 2 CSRS:
+#define COMMAND_COUNT_2_ADDR 0xA0080
+#define RESULT_COUNT_2_ADDR 0xA0088
+#define IRQ_THRESH_2_ADDR 0xA0090
+
+// Ring 3 CSRS:
+#define COMMAND_COUNT_3_ADDR 0xB0080
+#define RESULT_COUNT_3_ADDR 0xB0088
+#define IRQ_THRESH_3_ADDR 0xB0090
+
+// EIP154 RAM regions: Note that the FARM_PROG_RAM_X address range overlaps
+// with the FARM_DATA_RAM_X and FARM_DATA_RAM_X_EXT address ranges. This
+// conflict is resolved by using the FARM_PROG_RAM_X only when the
+// Sequencer is in SW reset, and the DATA_RAMs are picked only when the
+// engine is operation.
+//
+// Note:
+// The FARM_DATA_RAM_X_EXT RAMs may also be
+// called the LNME FIFO RAMs in some of the documentation.
+//
+// PKA_BUFFER_RAM : 1024 x 64 - 8K bytes
+// PKA_SECURE_RAM : 1536 x 64 - 12K bytes
+// PKA_MASTER_PROG_RAM : 8192 x 32 - 32K bytes
+// FARM_DATA_RAM_X : 1024 x 64 - 8K bytes
+// FARM_DATA_RAM_X_EXT : 256 x 32 - 1K bytes
+// FARM_PROG_RAM_X : 2048 x 32 - 8K bytes
+//
+// Note:
+// *TBD* Since hardware guys multiplied the address per 2, the size of
+// each memory/registers group increased and become two times larger.
+// Memory size should be adjusted accordingly:
+// PKA Buffer RAM size : 8KB --> 16KB
+// PKA Secure RAM size : 8KB --> 16KB
+// PKA Master Program RAM size : 32KB --> 64KB
+// PKA Farm Data RAM size : 4KB --> 8KB
+// PKA Farm Data RAM extension size : 4KB --> 8KB
+// PKA Farm Program RAM size : 8KB --> 16KB
+//
+#define PKA_BUFFER_RAM_BASE 0x00000
+#define PKA_BUFFER_RAM_SIZE MEM_SIZE_16KB // 0x00000...0x03FFF
+
+#define PKA_SECURE_RAM_BASE 0x20000
+#define PKA_SECURE_RAM_SIZE MEM_SIZE_16KB // 0x20000...0x23FFF
+
+#define PKA_MASTER_PROG_RAM_BASE 0x30000
+#define PKA_MASTER_PROG_RAM_SIZE MEM_SIZE_64KB // 0x30000...0x3FFFF
+
+#define FARM_DATA_RAM_0_BASE 0x40000
+#define FARM_DATA_RAM_0_SIZE MEM_SIZE_8KB // 0x40000...0x41FFF
+#define FARM_DATA_RAM_0_EXT_BASE 0x42000
+#define FARM_DATA_RAM_0_EXT_SIZE MEM_SIZE_8KB // 0x42000...0x43FFF
+#define FARM_PROG_RAM_0_BASE 0x40000
+#define FARM_PROG_RAM_0_SIZE MEM_SIZE_16KB // 0x40000...0x43FFF
+#define FARM_DATA_RAM_1_BASE 0x44000
+#define FARM_DATA_RAM_1_SIZE MEM_SIZE_8KB // 0x44000...0x45FFF
+#define FARM_DATA_RAM_1_EXT_BASE 0x46000
+#define FARM_DATA_RAM_1_EXT_SIZE MEM_SIZE_8KB // 0x46000...0x47FFF
+#define FARM_PROG_RAM_1_BASE 0x44000
+#define FARM_PROG_RAM_1_SIZE MEM_SIZE_16KB // 0x44000...0x47FFF
+#define FARM_DATA_RAM_2_BASE 0x48000
+#define FARM_DATA_RAM_2_SIZE MEM_SIZE_8KB // 0x48000...0x49FFF
+#define FARM_DATA_RAM_2_EXT_BASE 0x4A000
+#define FARM_DATA_RAM_2_EXT_SIZE MEM_SIZE_8KB // 0x4A000...0x4BFFF
+#define FARM_PROG_RAM_2_BASE 0x48000
+#define FARM_PROG_RAM_2_SIZE MEM_SIZE_16KB // 0x48000...0x4BFFF
+#define FARM_DATA_RAM_3_BASE 0x4C000
+#define FARM_DATA_RAM_3_SIZE MEM_SIZE_8KB // 0x4C000...0x4DFFF
+#define FARM_DATA_RAM_3_EXT_BASE 0x4E000
+#define FARM_DATA_RAM_3_EXT_SIZE MEM_SIZE_8KB // 0x4E000...0x4FFFF
+#define FARM_PROG_RAM_3_BASE 0x4C000
+#define FARM_PROG_RAM_3_SIZE MEM_SIZE_16KB // 0x4C000...0x4FFFF
+#define FARM_DATA_RAM_4_BASE 0x50000
+#define FARM_DATA_RAM_4_SIZE MEM_SIZE_8KB // 0x50000...0x51FFF
+#define FARM_DATA_RAM_4_EXT_BASE 0x52000
+#define FARM_DATA_RAM_4_EXT_SIZE MEM_SIZE_8KB // 0x52000...0x53FFF
+#define FARM_PROG_RAM_4_BASE 0x50000
+#define FARM_PROG_RAM_4_SIZE MEM_SIZE_16KB // 0x50000...0x53FFF
+#define FARM_DATA_RAM_5_BASE 0x54000
+#define FARM_DATA_RAM_5_SIZE MEM_SIZE_8KB // 0x54000...0x55FFF
+#define FARM_DATA_RAM_5_EXT_BASE 0x56000
+#define FARM_DATA_RAM_5_EXT_SIZE MEM_SIZE_8KB // 0x56000...0x57FFF
+#define FARM_PROG_RAM_5_BASE 0x54000
+#define FARM_PROG_RAM_5_SIZE MEM_SIZE_16KB // 0x54000...0x57FFF
+
+// PKA Buffer RAM offsets. These are NOT real CSR's but instead are
+// specific offset/addresses within the EIP154 PKA_BUFFER_RAM.
+
+// Ring 0:
+#define RING_CMMD_BASE_0_ADDR 0x00000
+#define RING_RSLT_BASE_0_ADDR 0x00010
+#define RING_SIZE_TYPE_0_ADDR 0x00020
+#define RING_RW_PTRS_0_ADDR 0x00028
+#define RING_RW_STAT_0_ADDR 0x00030
+
+// Ring 1
+#define RING_CMMD_BASE_1_ADDR 0x00040
+#define RING_RSLT_BASE_1_ADDR 0x00050
+#define RING_SIZE_TYPE_1_ADDR 0x00060
+#define RING_RW_PTRS_1_ADDR 0x00068
+#define RING_RW_STAT_1_ADDR 0x00070
+
+// Ring 2
+#define RING_CMMD_BASE_2_ADDR 0x00080
+#define RING_RSLT_BASE_2_ADDR 0x00090
+#define RING_SIZE_TYPE_2_ADDR 0x000A0
+#define RING_RW_PTRS_2_ADDR 0x000A8
+#define RING_RW_STAT_2_ADDR 0x000B0
+
+// Ring 3
+#define RING_CMMD_BASE_3_ADDR 0x000C0
+#define RING_RSLT_BASE_3_ADDR 0x000D0
+#define RING_SIZE_TYPE_3_ADDR 0x000E0
+#define RING_RW_PTRS_3_ADDR 0x000E8
+#define RING_RW_STAT_3_ADDR 0x000F0
+
+// Ring Options
+#define PKA_RING_OPTIONS_ADDR 0x07FF8
+
+// Alternate Window RAM size
+#define PKA_WINDOW_RAM_REGION_SIZE MEM_SIZE_16KB
+
+// Currently, we do not use these MiCA specific CSRs.
+
+// The PKI (not EIP154) CSR address/offsets: These are all addressed as
+// 8-byte registers.
+#define PKA_INT_MASK_ADDR 0x00
+#define PKA_INT_MASK_SET_ADDR 0x08
+#define PKA_INT_MASK_RESET_ADDR 0x10
+#define PKA_ZEROIZE_ADDR 0x40
+#define TST_FRO_ADDR 0x50
+#define FRO_COUNT_ADDR 0x58
+#define PKA_PARITY_CTL_ADDR 0x60
+#define PKA_PARITY_STAT_ADDR 0x68
+
+#endif // __PKA_ADDRS_H__
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_config.h b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_config.h
new file mode 100644
index 000000000..5b69d55be
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_config.h
@@ -0,0 +1,226 @@
+//
+// BSD LICENSE
+//
+// Copyright(c) 2016 Mellanox Technologies, Ltd. All rights reserved.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in
+// the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Mellanox Technologies nor the names of its
+// contributors may be used to endorse or promote products derived
+// from this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+
+#ifndef __PKA_CONFIG_H__
+#define __PKA_CONFIG_H__
+
+#include "mlxbf_pka_addrs.h"
+
+// The maximum number of PKA shims refered to as IO blocks.
+#define PKA_MAX_NUM_IO_BLOCKS 8
+// The maximum number of Rings supported by IO block (shim).
+#define PKA_MAX_NUM_IO_BLOCK_RINGS 4
+
+#define PKA_MAX_NUM_RINGS \
+ (PKA_MAX_NUM_IO_BLOCK_RINGS * PKA_MAX_NUM_IO_BLOCKS)
+
+// Resources are regions which include info control/status words,
+// count registers and host window ram.
+#define PKA_MAX_NUM_RING_RESOURCES 3
+
+// PKA Ring resources.
+// Define Ring resources parameters including base address, size (in bytes)
+// and ring spacing.
+#define PKA_RING_WORDS_ADDR PKA_BUFFER_RAM_BASE
+#define PKA_RING_CNTRS_ADDR COMMAND_COUNT_0_ADDR
+
+#define PKA_RING_WORDS_SIZE 0x40 // 64 bytes
+#define PKA_RING_CNTRS_SIZE 0x20 // 32 bytes (3 count registers)
+#define PKA_RING_MEM_SIZE 0x4000 // 16K bytes
+
+#define PKA_RING_WORDS_SPACING 0x40 // 64 bytes
+#define PKA_RING_CNTRS_SPACING 0x10000 // 64K bytes
+#define PKA_RING_MEM_0_SPACING 0x4000 // 16K bytes
+#define PKA_RING_MEM_1_SPACING 0x10000 // 64K bytes
+
+// PKA Window RAM parameters.
+// Define whether to split or not Window RAM during PKA device creation phase.
+#define SPLIT_WINDOW_RAM_MODE_ENABLED 1
+#define SPLIT_WINDOW_RAM_MODE_DISABLED 0
+#define PKA_SPLIT_WINDOW_RAM_MODE SPLIT_WINDOW_RAM_MODE_DISABLED
+// Defines for Window RAM partition. It is valid for 16K memory.
+#define PKA_WINDOW_RAM_RING_MEM_SIZE 0x0800 // 2KB
+#define PKA_WINDOW_RAM_DATA_MEM_SIZE 0x3800 // 14KB
+
+// Offset mask, common to both Window and Alternate Window RAM.
+#define PKA_WINDOW_RAM_OFFSET_MASK1 0x730000
+
+// Macro for mapping PKA Ring address into Window RAM address. It converts the
+// ring address, either physical address or virtual address, to valid address
+// into the Window RAM. This is done assuming the Window RAM base, size and
+// mask. Here, base is the actual physical address of the Window RAM, with the
+// help of mask it is reduced to Window RAM offset within that PKA block.
+// Further, with the help of addr and size, we arrive at the Window RAM
+// offset address for a PKA Ring within the given Window RAM.
+#define PKA_RING_MEM_ADDR(base, mask, addr, size) \
+ ((base & mask) | (((addr) & 0xffff) | \
+ ((((addr) & ~((size) - 1)) & 0xf0000) >> 2)))
+
+// PKA Master Sequencer Control/Status Register
+// Write '1' to bit [31] puts the Master controller Sequencer in a reset
+// reset state. Resetting the Sequencer (in order to load other firmware)
+// should only be done when the EIP-154 is not performing any operations.
+#define PKA_MASTER_SEQ_CTRL_RESET_VAL 0x80000000
+// Write '1' to bit [30] will reset all Command and Result counters. This
+// bit is write-only and self clearing and can only be set if the Reset
+// bit [31] is 1.
+#define PKA_MASTER_SEQ_CTRL_CLEAR_COUNTERS_VAL 0x40000000
+// Bit [8] in the PKA Master Sequencer Control/Status Register is tied to
+// the 'pka_master_irq interrupt' on the EIP-154 interrupt controller.
+#define PKA_MASTER_SEQ_CTRL_MASTER_IRQ_BIT 8
+// Sequencer status bits are used by the Master controller Sequencer to
+// reflect status. Bit [0] is tied to the 'pka_master_irq' interrupt on
+// the EIP-154 interrupt controller.
+#define PKA_MASTER_SEQ_CTRL_STATUS_BYTE 0x01
+// 'pka_master_irq' mask for the Master controller Sequencer Status Register.
+#define PKA_MASTER_SEQ_CTRL_MASTER_IRQ_MASK 0x100
+
+// Advanced Interrupt Controller (AIC) configuration
+// AIC Polarity Control Register is used to set each individual interrupt
+// signal (High Level / Rising Edge) during the initialization phase.
+// '0' = Low level or falling edge.
+// '1' = High level or rising edge.
+#define PKA_AIC_POL_CTRL_REG_VAL 0x000FFFFF
+// AIC Type Control Register is used to set each interrupt to level or edge.
+// '0' = Level.
+// '1' = Edge.
+#define PKA_AIC_TYPE_CTRL_REG_VAL 0x000FFFFF
+// AIC Enable Control Register is used to enable interrupt inputs.
+// '0' = Disabled.
+// '1' = Enabled.
+#define PKA_AIC_ENABLE_CTRL_REG_VAL 0x000F030F
+// AIC Enabled Status Register bits reflect the status of the interrupts
+// gated with the enable bits of the AIC_ENABLE_CTRL Register.
+// '0' = Inactive.
+// '1' = Pending.
+#define PKA_AIC_ENABLE_STAT_REG_VAL 0x000F030F
+
+// 'pka_master_irq' mask for the AIC Enabled Status Register.
+#define PKA_AIC_ENABLED_STAT_MASTER_IRQ_MASK 0x100
+
+// PKA_RING_OPTIONS field to specify the priority in which rings are handled:
+// '00' = full rotating priority,
+// '01' = fixed priority (ring 0 lowest),
+// '10' = ring 0 has the highest priority and the remaining rings have
+// rotating priority,
+// '11' = reserved, do not use.
+#define PKA_FULL_ROTATING_PRIORITY 0x0
+#define PKA_FIXED_PRIORITY 0x1
+#define PKA_RING_0_HAS_THE_HIGHEST_PRIORITY 0x2
+#define PKA_RESERVED 0x3
+#define PKA_RING_OPTIONS_PRIORITY PKA_FULL_ROTATING_PRIORITY
+
+// 'Signature' byte used because the ring options are transferred through RAM
+// which does not have a defined reset value. The EIP-154 master controller
+// keeps reading the PKA_RING_OPTIONS word at start-up until the Signature
+// byte contains 0x46 and the Reserved field contains zero.
+#define PKA_RING_OPTIONS_SIGNATURE_BYTE 0x46
+
+// Order of the result reporting: Two schemas are available:
+// InOrder - This means that the results will be reported in the same order
+// as the commands were provided.
+// OutOfOrder - This means that the results are reported as soon as they are
+// available
+#define PKA_RING_TYPE_IN_ORDER_BIT 1
+#define PKA_RING_TYPE_OUT_OF_ORDER_BIT 0
+#define PKA_RING_TYPE_IN_ORDER PKA_RING_TYPE_OUT_OF_ORDER_BIT
+
+// Byte order of the data written/read to/from Rings.
+// Little Endian (LE) - The least significant bytes have the lowest address.
+// Big Endian (BE) - The most significant bytes come first.
+#define PKA_RING_BYTE_ORDER_LE 0
+#define PKA_RING_BYTE_ORDER_BE 1
+#define PKA_RING_BYTE_ORDER PKA_RING_BYTE_ORDER_LE
+
+// 'trng_clk_on' mask for PKA Clock Switch Forcing Register. Turn on the
+// TRNG clock. When the TRNG is controlled via the Host slave interface,
+// this engine needs to be turned on by setting bit 11.
+#define PKA_CLK_FORCE_TRNG_ON 0x800
+
+// Number of TRNG Output registers
+#define PKA_TRNG_OUTPUT_CNT 4
+
+// TRNG Configuration
+#define PKA_TRNG_CONFIG_REG_VAL 0x00020008
+// TRNG Alarm Counter Register Value
+#define PKA_TRNG_ALARMCNT_REG_VAL 0x000200FF
+// TRNG FRO Enable Register Value
+#define PKA_TRNG_FROENABLE_REG_VAL 0x00FFFFFF
+// TRNG Control Register Value; Set bit 10 to start the EIP-76 a.k.a TRNG
+// engine, gathering entropy from the FROs.
+#define PKA_TRNG_CONTROL_REG_VAL 0x00000400
+
+// TRNG Control bit
+#define PKA_TRNG_CONTROL_TEST_MODE 0x100
+
+// TRNG Control Register Value; Set bit 10 and 12 to start the EIP-76 a.k.a TRNG
+// engine with DRBG enabled, gathering entropy from the FROs.
+#define PKA_TRNG_CONTROL_DRBG_REG_VAL 0x00001400
+
+// DRBG enabled TRNG 'request_data' value. REQ_DATA_VAL (in accordance with
+// DATA_BLOCK_MASK) requests 256 blocks of 128-bit random output.
+// 4095 blocks is the max number that can be requested for the TRNG(with DRBG)
+// configuration on Bluefield platforms.
+#define PKA_TRNG_CONTROL_REQ_DATA_VAL 0x10010000
+
+// Mask for 'Data Block' in TRNG Control Register.
+#define PKA_TRNG_DRBG_DATA_BLOCK_MASK 0xfff00000
+
+// Set bit 12 of TRNG Control Register to enable DRBG functionality.
+#define PKA_TRNG_CONTROL_DRBG_ENABLE_VAL 0x00001000
+
+// Set bit 8 a.ka 'test_sp_800_90 DRBG' bit in the TRNG Test Register.
+#define PKA_TRNG_TEST_DRBG_VAL 0x00000080
+
+// Number of Personalization String/Additional Input Registers
+#define PKA_TRNG_PS_AI_REG_COUNT 12
+
+// DRBG Reseed enable
+#define PKA_TRNG_CONTROL_DRBG_RESEED 0x00008000
+
+// TRNG Status bits
+#define PKA_TRNG_STATUS_READY 0x1
+#define PKA_TRNG_STATUS_SHUTDOWN_OFLO 0x2
+#define PKA_TRNG_STATUS_TEST_READY 0x100
+#define PKA_TRNG_STATUS_MONOBIT_FAIL 0x80
+#define PKA_TRNG_STATUS_RUN_FAIL 0x10
+#define PKA_TRNG_STATUS_POKER_FAIL 0x40
+
+// TRNG Alarm Counter bits
+#define PKA_TRNG_ALARMCNT_STALL_RUN_POKER 0x8000
+
+// TRNG Test bits
+#define PKA_TRNG_TEST_KNOWN_NOISE 0x20
+#define PKA_TRNG_TEST_NOISE 0x2000
+
+#endif // __PKA_CONFIG_H__
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_cpu.h b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_cpu.h
new file mode 100644
index 000000000..12a368c13
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_cpu.h
@@ -0,0 +1,72 @@
+//
+// BSD LICENSE
+//
+// Copyright(c) 2016 Mellanox Technologies, Ltd. All rights reserved.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in
+// the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Mellanox Technologies nor the names of its
+// contributors may be used to endorse or promote products derived
+// from this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+
+#ifndef __PKA_CPU_H__
+#define __PKA_CPU_H__
+
+#include <linux/types.h>
+#include <linux/timex.h>
+
+#define PKA_AARCH_64
+#define MAX_CPU_NUMBER 16 // BlueField specific
+
+#define MEGA 1000000
+#define GIGA 1000000000
+
+#define MS_PER_S 1000
+#define US_PER_S 1000000
+#define NS_PER_S 1000000000
+
+// Initial guess at our CPU speed. We set this to be larger than any
+// possible real speed, so that any calculated delays will be too long,
+// rather than too short.
+//
+//*Warning: use dummy value for frequency
+//#define CPU_HZ_MAX (2 * GIGA) // Cortex A72 : 2 GHz max -> 2.5 GHz max
+#define CPU_HZ_MAX (1255 * MEGA) // CPU Freq for High/Bin Chip
+
+// YIELD hints the CPU to switch to another thread if possible
+// and executes as a NOP otherwise.
+#define pka_cpu_yield() ({ asm volatile("yield" : : : "memory"); })
+// ISB flushes the pipeline, then restarts. This is guaranteed to
+// stall the CPU a number of cycles.
+#define pka_cpu_relax() ({ asm volatile("isb" : : : "memory"); })
+
+// Processor speed in hertz; used in routines which might be called very
+// early in boot.
+static inline uint64_t pka_early_cpu_speed(void)
+{
+ return CPU_HZ_MAX;
+}
+
+#endif // __PKA_CPU_H__
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_debug.h b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_debug.h
new file mode 100644
index 000000000..a44af6eb1
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_debug.h
@@ -0,0 +1,66 @@
+//
+// BSD LICENSE
+//
+// Copyright(c) 2016 Mellanox Technologies, Ltd. All rights reserved.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in
+// the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Mellanox Technologies nor the names of its
+// contributors may be used to endorse or promote products derived
+// from this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+
+#ifndef __PKA_DEBUG_H__
+#define __PKA_DEBUG_H__
+
+// PKA library bitmask. Use those bits to enable debug messages
+#define PKA_DRIVER 0x0001
+#define PKA_DEV 0x0002
+#define PKA_RING 0x0004
+#define PKA_QUEUE 0x0008
+#define PKA_MEM 0x0010
+#define PKA_USER 0x0020
+#define PKA_TESTS 0x0040
+// PKA debug mask. This indicates the debug/verbosity level.
+#define PKA_DEBUG_LIB_MASK 0x0040
+
+#define PKA_PRINT(lib, fmt, args...) \
+ ({ pr_info(#lib": "fmt, ##args); })
+
+#define PKA_ERROR(lib, fmt, args...) \
+ ({ pr_err(#lib": %s: error: "fmt, __func__, ##args); })
+
+#define PKA_DEBUG(lib, fmt, args...) \
+ ({ \
+ if (lib & PKA_DEBUG_LIB_MASK) \
+ pr_debug(#lib": %s: "fmt, __func__, ##args); \
+ })
+
+#define PKA_PANIC(lib, msg, args...) \
+ ({ \
+ pr_info(#lib": %s: panic: "msg, __func__, ##args); \
+ panic(msg, ##args); \
+ })
+
+#endif // __PKA_DEBUG_H__
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_dev.c b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_dev.c
new file mode 100644
index 000000000..c90c70134
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_dev.c
@@ -0,0 +1,2414 @@
+//
+// BSD LICENSE
+//
+// Copyright(c) 2016 Mellanox Technologies, Ltd. All rights reserved.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in
+// the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Mellanox Technologies nor the names of its
+// contributors may be used to endorse or promote products derived
+// from this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+
+#include <linux/delay.h>
+#include <linux/kernel.h>
+#include <linux/slab.h>
+#include <linux/ioport.h>
+#include <linux/timex.h>
+#include <linux/vfio.h>
+
+#include "mlxbf_pka_dev.h"
+
+#define BYTES_PER_WORD 4
+#define BYTES_PER_DOUBLE_WORD 8
+
+// Personalization string "NVIDIA-MELLANOX-BLUEFIELD-TRUE_RANDOM_NUMBER_GEN"
+uint32_t pka_trng_drbg_ps_str[] =
+{
+ 0x4e564944, 0x49412d4d, 0x454c4c41, 0x4e4f582d,
+ 0x424c5545, 0x4649454c, 0x442d5452, 0x55455f52,
+ 0x414e444f, 0x4d5f4e55, 0x4d424552, 0x5f47454e
+};
+
+// Personalization string for DRBG test
+uint32_t pka_trng_drbg_test_ps_str[] =
+{
+ 0x64299d83, 0xc34d7098, 0x5bd1f51d, 0xddccfdc1,
+ 0xdd0455b7, 0x166279e5, 0x0974cb1b, 0x2f2cd100,
+ 0x59a5060a, 0xca79940d, 0xd4e29a40, 0x56b7b779
+};
+
+// First Entropy string for DRBG test
+uint32_t pka_trng_drbg_test_etpy_str1[] =
+{
+ 0xaa6bbcab, 0xef45e339, 0x136ca1e7, 0xbce1c881,
+ 0x9fa37b09, 0x63b53667, 0xb36e0053, 0xa202ed81,
+ 0x4650d90d, 0x8eed6127, 0x666f2402, 0x0dfd3af9
+};
+
+// Second Entropy string for DRBG test
+uint32_t pka_trng_drbg_test_etpy_str2[] =
+{
+ 0x35c1b7a1, 0x0154c52b, 0xd5777390, 0x226a4fdb,
+ 0x5f16080d, 0x06b68369, 0xd0c93d00, 0x3336e27f,
+ 0x1abf2c37, 0xe6ab006c, 0xa4adc6e1, 0x8e1907a2
+};
+
+// Known answer for DRBG test
+uint32_t pka_trng_drbg_test_output[] =
+{
+ 0xb663b9f1, 0x24943e13, 0x80f7dce5, 0xaba1a16f
+};
+
+pka_dev_gbl_config_t pka_gbl_config;
+
+// Global PKA shim resource info table
+static pka_dev_gbl_shim_res_info_t pka_gbl_res_tbl[PKA_MAX_NUM_IO_BLOCKS];
+
+// Start a PKA device timer.
+static uint64_t pka_dev_timer_start(uint32_t usec)
+{
+ uint64_t cur_time = get_cycles();
+ return (cur_time + (pka_early_cpu_speed() * usec) / 1000000ULL);
+}
+
+// Test a PKA device timer for completion.
+static int pka_dev_timer_done(uint64_t timer)
+{
+ return (get_cycles() >= timer);
+}
+
+// Return register base address
+static uint64_t pka_dev_get_register_base(uint64_t base, uint64_t reg_addr)
+{
+ return (base + reg_addr) & PAGE_MASK;
+}
+
+// Return register offset
+static uint64_t pka_dev_get_register_offset(uint64_t base, uint64_t reg_addr)
+{
+ return (base + reg_addr) & ~PAGE_MASK;
+}
+
+// Return word offset within io memory
+static uint64_t pka_dev_get_word_offset(uint64_t mem_base, uint64_t word_addr,
+ uint64_t mem_size)
+{
+ return (mem_base + word_addr) & (mem_size - 1);
+}
+
+static uint64_t pka_dev_io_read(void *mem_ptr, uint64_t mem_off)
+{
+ uint64_t data;
+
+ data = pka_mmio_read(mem_ptr + mem_off);
+
+ return data;
+}
+
+static void pka_dev_io_write(void *mem_ptr, uint64_t mem_off, uint64_t value)
+{
+ pka_mmio_write(mem_ptr + mem_off, value);
+}
+
+// Add the resource to the global resource table
+static int pka_dev_add_resource(pka_dev_res_t *res_ptr, uint32_t shim_idx)
+{
+ uint8_t res_cnt;
+
+ res_cnt = pka_gbl_res_tbl[shim_idx].res_cnt;
+
+ if (res_cnt >= PKA_DEV_SHIM_RES_CNT)
+ return -ENOMEM;
+
+ pka_gbl_res_tbl[shim_idx].res_tbl[res_cnt] = res_ptr;
+ pka_gbl_res_tbl[shim_idx].res_cnt++;
+
+ return 0;
+}
+
+// Remove the resource from the global resource table
+static int pka_dev_put_resource(pka_dev_res_t *res, uint32_t shim_idx)
+{
+ pka_dev_res_t *res_ptr;
+ uint8_t res_idx;
+
+ for (res_idx = 0; res_idx < PKA_DEV_SHIM_RES_CNT; res_idx++)
+ {
+ res_ptr = pka_gbl_res_tbl[shim_idx].res_tbl[res_idx];
+ if (res_ptr && strcmp(res_ptr->name, res->name) == 0)
+ {
+ pka_gbl_res_tbl[shim_idx].res_tbl[res_idx] = NULL;
+ pka_gbl_res_tbl[shim_idx].res_cnt--;
+ break;
+ }
+ }
+
+ // Check whether the resource shares the same memory map; If so,
+ // the memory map shouldn't be released.
+ for (res_idx = 0; res_idx < PKA_DEV_SHIM_RES_CNT; res_idx++)
+ {
+ res_ptr = pka_gbl_res_tbl[shim_idx].res_tbl[res_idx];
+ if (res_ptr && (res_ptr->base == res->base))
+ return -EBUSY;
+ }
+
+ return 0;
+}
+
+static void* pka_dev_get_resource_ioaddr(uint64_t res_base, uint32_t shim_idx)
+{
+ pka_dev_res_t *res_ptr;
+ uint8_t res_cnt, res_idx;
+
+ res_cnt = pka_gbl_res_tbl[shim_idx].res_cnt;
+
+ if (res_cnt == 0)
+ return NULL;
+
+ for (res_idx = 0; res_idx < res_cnt; res_idx++)
+ {
+ res_ptr = pka_gbl_res_tbl[shim_idx].res_tbl[res_idx];
+ if (res_ptr->base == res_base)
+ return res_ptr->ioaddr;
+ }
+
+ return NULL;
+}
+
+// Set PKA device resource config - - map io memory if needed.
+static int pka_dev_set_resource_config(pka_dev_shim_t *shim,
+ pka_dev_res_t *res_ptr,
+ uint64_t res_base,
+ uint64_t res_size,
+ uint64_t res_type,
+ char *res_name)
+{
+ int ret = 0;
+
+ if (res_ptr->status == PKA_DEV_RES_STATUS_MAPPED)
+ return -EPERM;
+
+ if (res_type == PKA_DEV_RES_TYPE_REG)
+ res_ptr->base = res_base;
+
+ if (res_type == PKA_DEV_RES_TYPE_MEM)
+ res_ptr->base = shim->mem_res.eip154_base + res_base;
+
+ res_ptr->size = res_size;
+ res_ptr->type = res_type;
+ res_ptr->name = res_name;
+ res_ptr->status = PKA_DEV_RES_STATUS_UNMAPPED;
+ res_ptr->ioaddr = pka_dev_get_resource_ioaddr(res_ptr->base,
+ shim->shim_id);
+ if (!res_ptr->ioaddr)
+ {
+ if (!request_mem_region(res_ptr->base, res_ptr->size, res_ptr->name))
+ {
+ PKA_ERROR(PKA_DEV, "failed to get io memory region\n");
+ return -EPERM;
+ }
+
+ res_ptr->ioaddr = ioremap(res_ptr->base, res_ptr->size);
+ }
+
+ res_ptr->status = PKA_DEV_RES_STATUS_MAPPED;
+
+ if (!res_ptr->ioaddr || pka_dev_add_resource(res_ptr, shim->shim_id))
+ {
+ PKA_ERROR(PKA_DEV, "unable to map io memory\n");
+ release_mem_region(res_ptr->base, res_ptr->size);
+ return -ENOMEM;
+ }
+ return ret;
+}
+
+// Unset PKA device resource config - unmap io memory if needed.
+static void pka_dev_unset_resource_config(pka_dev_shim_t *shim,
+ pka_dev_res_t *res_ptr)
+{
+ int ret = -EBUSY;
+
+ if (res_ptr->status != PKA_DEV_RES_STATUS_MAPPED)
+ return;
+
+ if (res_ptr->ioaddr &&
+ ret != pka_dev_put_resource(res_ptr, shim->shim_id))
+ {
+ iounmap(res_ptr->ioaddr);
+ release_mem_region(res_ptr->base, res_ptr->size);
+ }
+
+ res_ptr->status = PKA_DEV_RES_STATUS_UNMAPPED;
+}
+
+int pka_dev_clear_ring_counters(pka_dev_ring_t *ring)
+{
+ pka_dev_shim_t *shim;
+ pka_dev_res_t *master_seq_ctrl_ptr;
+ void *master_reg_ptr;
+ uint64_t master_reg_base, master_reg_off;
+
+ shim = ring->shim;
+ master_seq_ctrl_ptr = &shim->resources.master_seq_ctrl;
+ master_reg_base = master_seq_ctrl_ptr->base;
+ master_reg_ptr = master_seq_ctrl_ptr->ioaddr;
+ master_reg_off = pka_dev_get_register_offset(master_reg_base,
+ PKA_MASTER_SEQ_CTRL_ADDR);
+
+ // push the EIP-154 master controller into reset.
+ pka_dev_io_write(master_reg_ptr, master_reg_off,
+ PKA_MASTER_SEQ_CTRL_RESET_VAL);
+
+ // clear counters.
+ pka_dev_io_write(master_reg_ptr, master_reg_off,
+ PKA_MASTER_SEQ_CTRL_CLEAR_COUNTERS_VAL);
+
+ // take the EIP-154 master controller out of reset.
+ pka_dev_io_write(master_reg_ptr, master_reg_off, 0);
+
+ return 0;
+}
+
+// Initialize ring. Set ring parameters and configure ring resources.
+// It returns 0 on success, a negative error code on failure.
+static int pka_dev_init_ring(pka_dev_ring_t *ring, uint32_t ring_id,
+ pka_dev_shim_t *shim)
+{
+ int ret = 0;
+
+ pka_dev_res_t *ring_info_words_ptr;
+ pka_dev_res_t *ring_counters_ptr;
+ pka_dev_res_t *ring_window_ram_ptr;
+
+ uint32_t ring_words_off;
+ uint32_t ring_cntrs_off;
+ uint32_t ring_mem_off;
+ uint32_t ring_mem_base;
+
+ uint32_t shim_ring_id;
+ uint8_t window_ram_split;
+
+ if (ring->status != PKA_DEV_RING_STATUS_UNDEFINED)
+ {
+ PKA_ERROR(PKA_DEV, "PKA ring must be undefined\n");
+ return -EPERM;
+ }
+
+ if (ring_id > PKA_MAX_NUM_RINGS - 1)
+ {
+ PKA_ERROR(PKA_DEV, "invalid ring identifier\n");
+ return -EINVAL;
+ }
+
+ ring->ring_id = ring_id;
+ ring->shim = shim;
+ ring->resources_num = PKA_MAX_NUM_RING_RESOURCES;
+
+ shim_ring_id = ring_id % PKA_MAX_NUM_IO_BLOCK_RINGS;
+ shim->rings[shim_ring_id] = ring;
+
+ // Configure ring information control/status words resource
+ ring_info_words_ptr = &ring->resources.info_words;
+ ring_words_off = shim_ring_id * PKA_RING_WORDS_SPACING;
+ ring_info_words_ptr->base = ring_words_off + shim->mem_res.eip154_base +
+ PKA_RING_WORDS_ADDR;
+ ring_info_words_ptr->size = PKA_RING_WORDS_SIZE;
+ ring_info_words_ptr->type = PKA_DEV_RES_TYPE_MEM;
+ ring_info_words_ptr->status = PKA_DEV_RES_STATUS_UNMAPPED;
+ ring_info_words_ptr->name = "PKA_RING_INFO";
+
+ // Configure ring counters registers resource
+ ring_counters_ptr = &ring->resources.counters;
+ ring_cntrs_off = shim_ring_id * PKA_RING_CNTRS_SPACING;
+ ring_counters_ptr->base = ring_cntrs_off + shim->mem_res.eip154_base +
+ PKA_RING_CNTRS_ADDR;
+ ring_counters_ptr->size = PKA_RING_CNTRS_SIZE;
+ ring_counters_ptr->type = PKA_DEV_RES_TYPE_REG;
+ ring_counters_ptr->status = PKA_DEV_RES_STATUS_UNMAPPED;
+ ring_counters_ptr->name = "PKA_RING_CNTRS";
+
+ // Configure ring window RAM resource
+ window_ram_split = shim->window_ram_split;
+ if (window_ram_split == PKA_SHIM_WINDOW_RAM_SPLIT_ENABLED)
+ {
+ ring_mem_off = shim_ring_id * PKA_RING_MEM_1_SPACING;
+ ring_mem_base = ring_mem_off + shim->mem_res.alt_wndw_ram_0_base;
+ }
+ else
+ {
+ ring_mem_off = shim_ring_id * PKA_RING_MEM_0_SPACING;
+ ring_mem_base = ring_mem_off + shim->mem_res.wndw_ram_base;
+ }
+
+ ring_window_ram_ptr = &ring->resources.window_ram;
+ ring_window_ram_ptr->base = ring_mem_base;
+ ring_window_ram_ptr->size = PKA_RING_MEM_SIZE;
+ ring_window_ram_ptr->type = PKA_DEV_RES_TYPE_MEM;
+ ring_window_ram_ptr->status = PKA_DEV_RES_STATUS_UNMAPPED;
+ ring_window_ram_ptr->name = "PKA_RING_WINDOW";
+
+ ring->ring_info = kzalloc(sizeof(pka_dev_hw_ring_info_t), GFP_KERNEL);
+ if (!ring->ring_info)
+ {
+ PKA_ERROR(PKA_DEV, "unable to kmalloc\n");
+ kfree(ring->ring_info);
+ return -ENOMEM;
+ }
+
+ mutex_init(&ring->mutex);
+ ring->status = PKA_DEV_RING_STATUS_INITIALIZED;
+
+ return ret;
+}
+
+// Release a given Ring.
+static int pka_dev_release_ring(pka_dev_ring_t *ring)
+{
+ int ret = 0;
+
+ pka_dev_shim_t *shim;
+ uint32_t shim_ring_id;
+
+ if (ring->status == PKA_DEV_RING_STATUS_UNDEFINED)
+ return ret;
+
+ if (ring->status == PKA_DEV_RING_STATUS_BUSY)
+ {
+ PKA_ERROR(PKA_DEV, "PKA ring is busy\n");
+ return -EBUSY;
+ }
+
+ shim = ring->shim;
+
+ if (shim->status == PKA_SHIM_STATUS_RUNNING)
+ {
+ PKA_ERROR(PKA_DEV, "PKA shim is running\n");
+ return -EPERM;
+ }
+
+ pka_dev_unset_resource_config(shim, &ring->resources.info_words);
+ pka_dev_unset_resource_config(shim, &ring->resources.counters);
+ pka_dev_unset_resource_config(shim, &ring->resources.window_ram);
+
+ kfree(ring->ring_info);
+
+ ring->status = PKA_DEV_RING_STATUS_UNDEFINED;
+ shim_ring_id = ring->ring_id % PKA_MAX_NUM_IO_BLOCK_RINGS;
+ shim->rings[shim_ring_id] = NULL;
+ shim->rings_num--;
+
+ return ret;
+}
+
+// Partition the window RAM for a given PKA ring. Here we statically divide
+// the 16K memory region into three partitions: First partition is reserved
+// for command descriptor ring (1K), second partition is reserved for result
+// descriptor ring (1K), and the remaining 14K are reserved for vector data.
+// Through this memroy partition scheme, command/result descriptor rings hold
+// a total of 1KB/64B = 16 descriptors each. The adresses for the rings start
+// at offset 0x3800. Also note that it is possible to have rings full while
+// the vector data can support more data, the opposite can also happen, but
+// it is not suitable. For instance ECC point multiplication requires 8 input
+// vectors and 2 output vectors, a total of 10 vectors. If each vector has a
+// length of 24 words (24x4B = 96B), we can process 14KB/960B = 14 operations
+// which is close to 16 the total descriptors supported by rings. On the other
+// hand, using 12K vector data region, allows to process only 12 operations,
+// while rings can hold 32 descriptors (ring usage is significantly low).
+// For ECDSA verify, we have 12 vectors which require 1152B, with 14KB we can
+// handle 12 operations, against 10 operations with 12KB vector data memory.
+// We believe that the aformentionned memory partition help us to leverage
+// the trade-off between supported descriptors and required vectors. Note
+// that these examples gives approximative values and does not include buffer
+// word padding across vectors.
+//
+// The function also writes the result descriptor rings base addresses, size
+// and type, and initialize the read and write pointers and statistics. It
+// returns 0 on success, a negative error code on failure.
+//
+// This function must be called once per ring, at initialization before any
+// other fonctions are called.
+static int pka_dev_partition_mem(pka_dev_ring_t *ring)
+{
+ int ret = 0;
+
+ pka_dev_shim_t *shim;
+ pka_dev_hw_ring_info_t *ring_info;
+
+ uint32_t ring_mem_base;
+ uint32_t ring_mem_size;
+ uint32_t data_mem_base;
+ uint32_t data_mem_size;
+
+ uint64_t cmd_desc_ring_base;
+ uint32_t cmd_desc_ring_size;
+ uint64_t rslt_desc_ring_base;
+ uint32_t rslt_desc_ring_size;
+
+ uint16_t num_cmd_desc;
+ uint16_t host_desc_size;
+ uint8_t ring_in_order;
+
+ uint64_t window_ram_base;
+ uint64_t window_ram_size;
+
+ shim = ring->shim;
+
+ if (!ring->shim ||
+ ring->status != PKA_DEV_RING_STATUS_INITIALIZED)
+ return -EPERM;
+
+ ring_in_order = shim->ring_type;
+ window_ram_base = ring->resources.window_ram.base;
+ window_ram_size = ring->resources.window_ram.size;
+ // Partition ring memory. Give ring pair (cmmd descriptor ring and rslt
+ // descriptor ring) an equal portion of the memory. The cmmd descriptor
+ // ring and result descriptor ring are used as "non-overlapping" ring.
+ // Currently set aside 1/8 of the window RAM for command/result descriptor
+ // rings - giving a total of 1K/64B = 16 descriptors per ring.
+ // The remaining memory is "Data Memory" - i.e. memory to hold the command
+ // operands and results - also called input/output vectors (in all cases
+ // these vectors are just single large integers - often in the range of
+ // hundreds to thousands of bits long).
+ ring_mem_size = PKA_WINDOW_RAM_RING_MEM_SIZE / 2;
+ data_mem_size = PKA_WINDOW_RAM_DATA_MEM_SIZE;
+ data_mem_base = window_ram_base;
+ ring_mem_base = data_mem_base + data_mem_size;
+
+ num_cmd_desc = ring_mem_size / CMD_DESC_SIZE;
+ host_desc_size = CMD_DESC_SIZE / BYTES_PER_WORD;
+
+ cmd_desc_ring_size = num_cmd_desc * CMD_DESC_SIZE;
+ rslt_desc_ring_size = cmd_desc_ring_size;
+
+ ring->num_cmd_desc = num_cmd_desc;
+
+ // The command and result descriptor rings may be placed at different
+ // (non-overlapping) locations in Window RAM memory space. PKI command
+ // interface: Most of the functionality is defined by the EIP-154 master
+ // firmware on the EIP-154 master controller Sequencer.
+ cmd_desc_ring_base = ring_mem_base;
+ rslt_desc_ring_base = ring_mem_base + cmd_desc_ring_size;
+
+ cmd_desc_ring_base =
+ PKA_RING_MEM_ADDR(window_ram_base, shim->mem_res.wndw_ram_off_mask,
+ cmd_desc_ring_base, window_ram_size);
+ rslt_desc_ring_base =
+ PKA_RING_MEM_ADDR(window_ram_base, shim->mem_res.wndw_ram_off_mask,
+ rslt_desc_ring_base, window_ram_size);
+
+ ring_info = ring->ring_info;
+ // Fill ring information.
+ ring_info->cmmd_base = cmd_desc_ring_base;
+ ring_info->rslt_base = rslt_desc_ring_base;
+ ring_info->size = num_cmd_desc - 1;
+ ring_info->host_desc_size = host_desc_size;
+ ring_info->in_order = ring_in_order;
+ ring_info->cmmd_rd_ptr = 0x0;
+ ring_info->rslt_wr_ptr = 0x0;
+ ring_info->cmmd_rd_stats = 0x0;
+ ring_info->rslt_wr_stats = 0x0;
+
+ return ret;
+}
+
+// Write the ring base address, ring size and type, and initialize (clear)
+// the read and write pointers and statistics.
+static int pka_dev_write_ring_info(pka_dev_res_t *buffer_ram_ptr,
+ uint8_t ring_id,
+ uint32_t ring_cmmd_base_val,
+ uint32_t ring_rslt_base_val,
+ uint32_t ring_size_type_val)
+{
+ uint32_t ring_spacing;
+ uint64_t word_off;
+ int ret = 0;
+
+ if (buffer_ram_ptr->status != PKA_DEV_RES_STATUS_MAPPED ||
+ buffer_ram_ptr->type != PKA_DEV_RES_TYPE_MEM)
+ return -EPERM;
+
+ PKA_DEBUG(PKA_DEV, "Writing ring information control/status words\n");
+
+ ring_spacing = ring_id * PKA_RING_WORDS_SPACING;
+
+ // Write the command ring base address that the EIP-154
+ // master firmware uses with the command ring read pointer
+ // to get command descriptors from the Host ring. After the
+ // initialization, although the word is writeable it should
+ // be regarded as read-only.
+ word_off = pka_dev_get_word_offset(buffer_ram_ptr->base,
+ RING_CMMD_BASE_0_ADDR + ring_spacing,
+ PKA_BUFFER_RAM_SIZE);
+ pka_dev_io_write(buffer_ram_ptr->ioaddr, word_off, ring_cmmd_base_val);
+
+ // Write the result ring base address that the EIP-154
+ // master firmware uses with the result ring write pointer
+ // to put the result descriptors in the Host ring. After
+ // the initialization, although the word is writeable it
+ // should be regarded as read-only.
+ word_off = pka_dev_get_word_offset(buffer_ram_ptr->base,
+ RING_RSLT_BASE_0_ADDR + ring_spacing,
+ PKA_BUFFER_RAM_SIZE);
+ pka_dev_io_write(buffer_ram_ptr->ioaddr, word_off, ring_rslt_base_val);
+
+ // Write the ring size (number of descriptors), the size of
+ // the descriptor and the result reporting scheme. After the
+ // initialization, although the word is writeable it should
+ // be regarded as read-only.
+ word_off = pka_dev_get_word_offset(buffer_ram_ptr->base,
+ RING_SIZE_TYPE_0_ADDR + ring_spacing,
+ PKA_BUFFER_RAM_SIZE);
+ pka_dev_io_write(buffer_ram_ptr->ioaddr, word_off, ring_size_type_val);
+
+ // Write the command and result ring indices that the EIP-154
+ // master firmware uses. This word should be written with zero
+ // when the ring information is initialized. After the
+ // initialization, although the word is writeable it should be
+ // regarded as read-only.
+ word_off = pka_dev_get_word_offset(buffer_ram_ptr->base,
+ RING_RW_PTRS_0_ADDR + ring_spacing,
+ PKA_BUFFER_RAM_SIZE);
+ pka_dev_io_write(buffer_ram_ptr->ioaddr, word_off, 0);
+
+ // Write the ring statistics (two 16-bit counters, one for
+ // commands and one for results) from EIP-154 master firmware
+ // point of view. This word should be written with zero when
+ // the ring information is initialized. After the initializa-
+ // -tion, although the word is writeable it should be regarded
+ // as read-only.
+ word_off = pka_dev_get_word_offset(buffer_ram_ptr->base,
+ RING_RW_STAT_0_ADDR + ring_spacing,
+ PKA_BUFFER_RAM_SIZE);
+ pka_dev_io_write(buffer_ram_ptr->ioaddr, word_off, 0);
+
+ return ret;
+}
+
+// Set up the control/status words. Upon a PKI command the EIP-154 master
+// firmware will read and partially update the ring information.
+static int pka_dev_set_ring_info(pka_dev_ring_t *ring)
+{
+ int ret = 0;
+
+ pka_dev_shim_t *shim;
+ pka_dev_hw_ring_info_t *ring_info;
+ pka_dev_res_t *buffer_ram_ptr;
+
+ uint32_t ring_cmmd_base_val;
+ uint32_t ring_rslt_base_val;
+ uint32_t ring_size_type_val;
+
+ uint8_t ring_id;
+
+ shim = ring->shim;
+ // Ring info configuration MUST be done when the PKA ring
+ // is initilaized.
+ if ((shim->status != PKA_SHIM_STATUS_INITIALIZED &&
+ shim->status != PKA_SHIM_STATUS_RUNNING &&
+ shim->status != PKA_SHIM_STATUS_STOPPED) ||
+ ring->status != PKA_DEV_RING_STATUS_INITIALIZED)
+ return -EPERM;
+
+ ring_id = ring->ring_id % PKA_MAX_NUM_IO_BLOCK_RINGS;
+
+ // Partition ring memory.
+ ret = pka_dev_partition_mem(ring);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to initialize ring memory\n");
+ return ret;
+ }
+
+ // Fill ring infomation.
+ ring_info = ring->ring_info;
+
+ ring_cmmd_base_val = ring_info->cmmd_base;
+ ring_rslt_base_val = ring_info->rslt_base;
+
+ ring_size_type_val = (ring_info->in_order & 0x0001) << 31;
+ ring_size_type_val |= (ring_info->host_desc_size & 0x03FF) << 18;
+ ring_size_type_val |= (ring->num_cmd_desc - 1) & 0xFFFF;
+
+ buffer_ram_ptr = &shim->resources.buffer_ram;
+ // Write ring information status/control words in the PKA Buffer RAM
+ ret = pka_dev_write_ring_info(buffer_ram_ptr, ring_id, ring_cmmd_base_val,
+ ring_rslt_base_val, ring_size_type_val);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to wirte ring information\n");
+ return ret;
+ }
+
+ ring->status = PKA_DEV_RING_STATUS_READY;
+
+ return ret;
+}
+
+// Create shim. Set shim parameters and configure shim resources.
+// It returns 0 on success, a negative error code on failure.
+static int pka_dev_create_shim(pka_dev_shim_t *shim, uint32_t shim_id,
+ uint8_t split, struct pka_dev_mem_res *mem_res)
+{
+ int ret = 0;
+
+ uint64_t reg_base;
+ uint64_t reg_size;
+
+ if (shim->status == PKA_SHIM_STATUS_CREATED)
+ return ret;
+
+ if (shim->status != PKA_SHIM_STATUS_UNDEFINED)
+ {
+ PKA_ERROR(PKA_DEV, "PKA device must be undefined\n");
+ return -EPERM;
+ }
+
+ if (shim_id > PKA_MAX_NUM_IO_BLOCKS - 1)
+ {
+ PKA_ERROR(PKA_DEV, "invalid shim identifier\n");
+ return -EINVAL;
+ }
+
+ shim->shim_id = shim_id;
+ shim->mem_res = *mem_res;
+
+ if (split)
+ shim->window_ram_split = PKA_SHIM_WINDOW_RAM_SPLIT_ENABLED;
+ else
+ shim->window_ram_split = PKA_SHIM_WINDOW_RAM_SPLIT_DISABLED;
+
+ shim->ring_type = PKA_RING_TYPE_IN_ORDER;
+ shim->ring_priority = PKA_RING_OPTIONS_PRIORITY;
+ shim->rings_num = PKA_MAX_NUM_IO_BLOCK_RINGS;
+ shim->rings = kzalloc(sizeof(pka_dev_ring_t) * shim->rings_num,
+ GFP_KERNEL);
+ if (!shim->rings)
+ {
+ PKA_ERROR(PKA_DEV, "unable to kmalloc\n");
+ return -ENOMEM;
+ }
+
+ // Set PKA device Buffer RAM config
+ ret = pka_dev_set_resource_config(shim, &shim->resources.buffer_ram,
+ PKA_BUFFER_RAM_BASE,
+ PKA_BUFFER_RAM_SIZE,
+ PKA_DEV_RES_TYPE_MEM,
+ "PKA_BUFFER_RAM");
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "unable to set Buffer RAM config\n");
+ return ret;
+ }
+
+ // Set PKA device Master Program RAM config
+ ret = pka_dev_set_resource_config(shim, &shim->resources.master_prog_ram,
+ PKA_MASTER_PROG_RAM_BASE,
+ PKA_MASTER_PROG_RAM_SIZE,
+ PKA_DEV_RES_TYPE_MEM,
+ "PKA_MASTER_PROG_RAM");
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "unable to set Master Program RAM config\n");
+ return ret;
+ }
+
+ // Set PKA device Master Controller register
+ reg_size = PAGE_SIZE;
+ reg_base = pka_dev_get_register_base(shim->mem_res.eip154_base,
+ PKA_MASTER_SEQ_CTRL_ADDR);
+ ret = pka_dev_set_resource_config(shim, &shim->resources.master_seq_ctrl,
+ reg_base, reg_size,
+ PKA_DEV_RES_TYPE_REG,
+ "PKA_MASTER_SEQ_CTRL");
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "unable to set Master Controller register "
+ "config\n");
+ return ret;
+ }
+
+ // Set PKA device AIC registers
+ reg_size = PAGE_SIZE;
+ reg_base = pka_dev_get_register_base(shim->mem_res.eip154_base,
+ AIC_POL_CTRL_ADDR);
+ ret = pka_dev_set_resource_config(shim, &shim->resources.aic_csr,
+ reg_base, reg_size,
+ PKA_DEV_RES_TYPE_REG,
+ "PKA_AIC_CSR");
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "unable to set AIC registers config\n");
+ return ret;
+ }
+
+ // Set PKA device TRNG registers
+ reg_size = PAGE_SIZE;
+ reg_base = pka_dev_get_register_base(shim->mem_res.eip154_base,
+ TRNG_OUTPUT_0_ADDR);
+ ret = pka_dev_set_resource_config(shim, &shim->resources.trng_csr,
+ reg_base, reg_size,
+ PKA_DEV_RES_TYPE_REG,
+ "PKA_TRNG_CSR");
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "unable to setup the TRNG\n");
+ return ret;
+ }
+
+ // Set PKA device 'glue' logic registers
+ reg_size = PAGE_SIZE;
+ reg_base = pka_dev_get_register_base(shim->mem_res.csr_base,
+ PKA_INT_MASK_ADDR);
+ ret = pka_dev_set_resource_config(shim, &shim->resources.ext_csr,
+ reg_base, reg_size,
+ PKA_DEV_RES_TYPE_REG,
+ "PKA_EXT_CSR");
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "unable to setup the MiCA specific registers\n");
+ return ret;
+ }
+
+ shim->status = PKA_SHIM_STATUS_CREATED;
+
+ return ret;
+}
+
+// Delete shim and unset shim resources.
+static int pka_dev_delete_shim(pka_dev_shim_t *shim)
+{
+ int ret = 0;
+ pka_dev_res_t *res_buffer_ram, *res_master_prog_ram;
+ pka_dev_res_t *res_master_seq_ctrl, *res_aic_csr, *res_trng_csr;
+
+ PKA_DEBUG(PKA_DEV, "PKA device delete shim\n");
+
+ if (shim->status == PKA_SHIM_STATUS_UNDEFINED)
+ return ret;
+
+ if (shim->status != PKA_SHIM_STATUS_FINALIZED &&
+ shim->status != PKA_SHIM_STATUS_CREATED)
+ {
+ PKA_ERROR(PKA_DEV, "PKA device status must be finalized\n");
+ return -EPERM;
+ }
+
+ res_buffer_ram = &shim->resources.buffer_ram;
+ res_master_prog_ram = &shim->resources.master_prog_ram;
+ res_master_seq_ctrl = &shim->resources.master_seq_ctrl;
+ res_aic_csr = &shim->resources.aic_csr;
+ res_trng_csr = &shim->resources.trng_csr;
+
+ pka_dev_unset_resource_config(shim, res_buffer_ram);
+ pka_dev_unset_resource_config(shim, res_master_prog_ram);
+ pka_dev_unset_resource_config(shim, res_master_seq_ctrl);
+ pka_dev_unset_resource_config(shim, res_aic_csr);
+ pka_dev_unset_resource_config(shim, res_trng_csr);
+
+ kfree(shim->rings);
+
+ shim->status = PKA_SHIM_STATUS_UNDEFINED;
+
+ return ret;
+}
+
+static int pka_dev_config_aic_interrupts(pka_dev_res_t *aic_csr_ptr)
+{
+ int ret = 0;
+
+ uint64_t csr_reg_base, csr_reg_off;
+ void *csr_reg_ptr;
+
+ if (aic_csr_ptr->status != PKA_DEV_RES_STATUS_MAPPED ||
+ aic_csr_ptr->type != PKA_DEV_RES_TYPE_REG)
+ return -EPERM;
+
+ PKA_DEBUG(PKA_DEV, "configure the AIC so that all interrupts "
+ "are properly recognized\n");
+
+ csr_reg_base = aic_csr_ptr->base;
+ csr_reg_ptr = aic_csr_ptr->ioaddr;
+
+ // Configure the signal polarity for each interrupt.
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, AIC_POL_CTRL_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_AIC_POL_CTRL_REG_VAL);
+
+ // Configure the signal type for each interrupt
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, AIC_TYPE_CTRL_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_AIC_TYPE_CTRL_REG_VAL);
+
+ // Set the enable control register
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, AIC_ENABLE_CTRL_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_AIC_ENABLE_CTRL_REG_VAL);
+
+ // Set the enabled status register
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, AIC_ENABLED_STAT_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_AIC_ENABLE_STAT_REG_VAL);
+
+ // *TBD* Write PKA_INT_MASK_RESET with 1's for each interrupt bit
+ // to allow them to propagate out the interrupt controller.
+ // EIP-154 interrupts can still be programmed and observed via polling
+ // regardless of whether PKA_INT_MASK is masking out the interrupts or
+ // not. The mask is for system propagation, i.e. propagate to the GIC.
+ // Bit positions are as follows:
+ // Bit 10 - parity_error_irq (non EIP-154 interrupt)
+ // Bit 9 - trng_irq
+ // Bit 8 - pka_master_irq
+ // Bits 7:4 - pka_queue_*_result_irq
+ // Bits 3:0 - pka_queue_*_empty_irq
+
+ return ret;
+}
+
+static int pka_dev_load_image(pka_dev_res_t *res_ptr, const uint32_t *data_buf,
+ uint32_t size)
+{
+ uint64_t data_rd;
+ int mismatches;
+ int i, j, ret = 0;
+
+ if (res_ptr->status != PKA_DEV_RES_STATUS_MAPPED ||
+ res_ptr->type != PKA_DEV_RES_TYPE_MEM)
+ return -EPERM;
+
+ // Note that the image size is in word of 4 bytes and memory 'writes'
+ // are 8 bytes aligned, thus the memory start address and end address
+ // are shifted.
+ if (res_ptr->size < (size * BYTES_PER_WORD) << 1)
+ {
+ PKA_ERROR(PKA_DEV, "image size greater than memory size\n");
+ return -EINVAL;
+ }
+
+ for (i = 0, j = 0; i < size; i++, j += BYTES_PER_DOUBLE_WORD)
+ pka_dev_io_write(res_ptr->ioaddr, j,
+ (uint64_t) data_buf[i]);
+
+ mismatches = 0;
+ PKA_DEBUG(PKA_DEV, "PKA DEV: verifying image (%u words)\n", size);
+ for (i = 0, j = 0; i < size; i++, j += BYTES_PER_DOUBLE_WORD)
+ {
+ data_rd = pka_dev_io_read(res_ptr->ioaddr, j);
+ if (data_rd != (uint64_t) data_buf[i])
+ {
+ mismatches += 1;
+ PKA_DEBUG(PKA_DEV, "error while loading image: "
+ "addr:0x%llx expected data: 0x%x actual data: 0x%llx\n",
+ res_ptr->base + j,
+ data_buf[i], data_rd);
+ }
+ }
+
+ if (mismatches > 0)
+ {
+ PKA_PANIC(PKA_DEV, "error while loading image: mismatches: %d\n",
+ mismatches);
+ return -EAGAIN;
+ }
+
+ return ret;
+}
+
+static int
+pka_dev_config_master_seq_controller(pka_dev_shim_t *shim,
+ pka_dev_res_t *master_seq_ctrl_ptr)
+{
+ pka_dev_res_t *aic_csr_ptr, *master_prog_ram;
+ void *aic_reg_ptr, *master_reg_ptr;
+
+ uint64_t aic_reg_base, aic_reg_off;
+ uint64_t master_reg_base, master_reg_off;
+
+ const uint32_t *boot_img_ptr, *master_img_ptr;
+ uint32_t boot_img_size, master_img_size;
+
+ uint32_t pka_master_irq;
+
+ uint64_t timer;
+ uint8_t status_bits;
+ uint8_t shim_fw_id;
+ int ret = 0;
+
+ if (master_seq_ctrl_ptr->status != PKA_DEV_RES_STATUS_MAPPED ||
+ master_seq_ctrl_ptr->type != PKA_DEV_RES_TYPE_REG)
+ return -EPERM;
+
+ master_reg_base = master_seq_ctrl_ptr->base;
+ master_reg_ptr = master_seq_ctrl_ptr->ioaddr;
+ master_reg_off = pka_dev_get_register_offset(master_reg_base,
+ PKA_MASTER_SEQ_CTRL_ADDR);
+
+ PKA_DEBUG(PKA_DEV, "push the EIP-154 master controller into reset\n");
+ pka_dev_io_write(master_reg_ptr, master_reg_off,
+ PKA_MASTER_SEQ_CTRL_RESET_VAL);
+
+ shim_fw_id = pka_firmware_get_id();
+
+ // Load boot image into PKA_MASTER_PROG_RAM
+ boot_img_size = pka_firmware_array[shim_fw_id].boot_img_size;
+ PKA_DEBUG(PKA_DEV, "loading boot image (%d words)\n", boot_img_size);
+
+ boot_img_ptr = pka_firmware_array[shim_fw_id].boot_img;
+ ret = pka_dev_load_image(&shim->resources.master_prog_ram,
+ boot_img_ptr, boot_img_size);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to load boot image\n");
+ return ret;
+ }
+
+ PKA_DEBUG(PKA_DEV, "take the EIP-154 master controller out of reset\n");
+ pka_dev_io_write(master_reg_ptr, master_reg_off, 0);
+
+ // Poll for 'pka_master_irq' bit in AIC_ENABLED_STAT register to indicate
+ // sequencer is initialized
+ aic_csr_ptr = &shim->resources.aic_csr;
+ if (aic_csr_ptr->status != PKA_DEV_RES_STATUS_MAPPED ||
+ aic_csr_ptr->type != PKA_DEV_RES_TYPE_REG)
+ return -EPERM;
+
+ aic_reg_base = aic_csr_ptr->base;
+ aic_reg_ptr = aic_csr_ptr->ioaddr;
+ aic_reg_off = pka_dev_get_register_offset(aic_reg_base,
+ AIC_ENABLED_STAT_ADDR);
+
+ pka_master_irq = 0;
+ PKA_DEBUG(PKA_DEV, "poll for 'pka_master_irq'\n");
+ timer = pka_dev_timer_start(100000); // 100 msec
+ while (pka_master_irq == 0)
+ {
+ pka_master_irq |= pka_dev_io_read(aic_reg_ptr, aic_reg_off)
+ & PKA_AIC_ENABLED_STAT_MASTER_IRQ_MASK;
+ if (pka_dev_timer_done(timer))
+ {
+ //PKA_PANIC(PKA_DEV, "failed to load firmware\n");
+ return -EAGAIN;
+ }
+ }
+ PKA_DEBUG(PKA_DEV, "'pka_master_irq' is active\n");
+
+ // Verify that the EIP-154 boot firmware has finished without errors
+ status_bits = (uint8_t)((pka_dev_io_read(master_reg_ptr,
+ master_reg_off) >> PKA_MASTER_SEQ_CTRL_MASTER_IRQ_BIT)
+ & 0xff);
+ if (status_bits != PKA_MASTER_SEQ_CTRL_STATUS_BYTE)
+ {
+ // If the error indication (bit [15]) is set,
+ // the EIP-154 boot firmware encountered an error and is stopped.
+ if ((status_bits >> (PKA_MASTER_SEQ_CTRL_MASTER_IRQ_BIT - 1)) == 1)
+ {
+ PKA_ERROR(PKA_DEV,
+ "boot firmware encountered an error 0x%x and is stopped\n",
+ status_bits);
+ return -EAGAIN;
+ }
+ PKA_DEBUG(PKA_DEV, "boot firmware in progress %d", status_bits);
+ }
+ PKA_DEBUG(PKA_DEV, "boot firmware has finished successfully\n");
+
+ PKA_DEBUG(PKA_DEV, "push the EIP-154 master controller into reset\n");
+ pka_dev_io_write(master_reg_ptr, master_reg_off,
+ PKA_MASTER_SEQ_CTRL_RESET_VAL);
+
+ // Load Master image into PKA_MASTER_PROG_RAM
+ master_img_size = pka_firmware_array[shim_fw_id].master_img_size;
+ PKA_DEBUG(PKA_DEV, "loading master image (%d words)\n",
+ master_img_size);
+ master_prog_ram = &shim->resources.master_prog_ram;
+ master_img_ptr = pka_firmware_array[shim_fw_id].master_img;
+ ret = pka_dev_load_image(master_prog_ram, master_img_ptr,
+ master_img_size);
+ if (ret)
+ {
+ pr_err("PKA DEV: failed to load master image\n");
+ return ret;
+ }
+
+ PKA_DEBUG(PKA_DEV, "take the EIP-154 master controller out of reset\n");
+ pka_dev_io_write(master_reg_ptr, master_reg_off, 0);
+
+ return ret;
+}
+
+// Configure ring options.
+static int pka_dev_config_ring_options(pka_dev_res_t *buffer_ram_ptr,
+ uint32_t rings_num, uint8_t ring_priority)
+{
+ uint64_t control_word;
+ uint64_t word_off;
+ int ret = 0;
+
+ if (buffer_ram_ptr->status != PKA_DEV_RES_STATUS_MAPPED ||
+ buffer_ram_ptr->type != PKA_DEV_RES_TYPE_MEM)
+ return -EPERM;
+
+ if (rings_num > PKA_MAX_NUM_RINGS ||
+ rings_num < 1)
+ {
+ PKA_ERROR(PKA_DEV, "invalid rings number\n");
+ return -EINVAL;
+ }
+
+ PKA_DEBUG(PKA_DEV, "Configure PKA ring options control word\n");
+
+ // Write PKA_RING_OPTIONS control word located in the PKA_BUFFER_RAM. The
+ // value of this word is determined by the PKA I/O block (Shim). Set the
+ // number of implemented command/result ring pairs that is available in
+ // this EIP-154, encoded as binary value, which is 4.
+ control_word = (uint64_t) 0x0;
+ control_word |= ring_priority & 0xff;
+ control_word |= ((rings_num - 1) << 8) & 0xff00;
+ control_word |= (PKA_RING_OPTIONS_SIGNATURE_BYTE << 24) & 0xff000000;
+ word_off = pka_dev_get_word_offset(buffer_ram_ptr->base,
+ PKA_RING_OPTIONS_ADDR, PKA_BUFFER_RAM_SIZE);
+ pka_dev_io_write(buffer_ram_ptr->ioaddr, word_off, control_word);
+
+ return ret;
+}
+
+static int pka_dev_config_trng_clk(pka_dev_res_t *aic_csr_ptr)
+{
+ int ret = 0;
+
+ uint64_t csr_reg_base, csr_reg_off;
+ uint64_t timer;
+ uint32_t trng_clk_en = 0;
+ void *csr_reg_ptr;
+
+ if (aic_csr_ptr->status != PKA_DEV_RES_STATUS_MAPPED ||
+ aic_csr_ptr->type != PKA_DEV_RES_TYPE_REG)
+ return -EPERM;
+
+ PKA_DEBUG(PKA_DEV, "Turn on TRNG clock\n");
+
+ csr_reg_base = aic_csr_ptr->base;
+ csr_reg_ptr = aic_csr_ptr->ioaddr;
+
+ // Enable the TRNG clock in PKA_CLK_FORCE.
+ // In general, this register should be left in its default state of all
+ // zeroes! Only when the TRNG is directly controlled via the Host slave
+ // interface, the engine needs to be turned on using the trng_clk_on
+ // bit in this register. In case the TRNG is controlled via internal
+ // firmware, this is not required.
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, PKA_CLK_FORCE_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_CLK_FORCE_TRNG_ON);
+ // Check whether the system clock for TRNG engine is enabled. The clock
+ // MUST be running to provide access to the TRNG.
+ timer = pka_dev_timer_start(100000); // 100 msec
+ while (trng_clk_en == 0)
+ {
+ trng_clk_en |= pka_dev_io_read(csr_reg_ptr, csr_reg_off)
+ & PKA_CLK_FORCE_TRNG_ON;
+ if (pka_dev_timer_done(timer))
+ {
+ PKA_DEBUG(PKA_DEV, "Failed to enable TRNG clock\n");
+ return -EAGAIN;
+ }
+ }
+ PKA_DEBUG(PKA_DEV, "'trng_clk_on' is enabled\n");
+
+ return ret;
+}
+
+static int pka_dev_trng_wait_test_ready(void *csr_reg_ptr, uint64_t csr_reg_base)
+{
+ uint64_t csr_reg_off, timer, test_ready, csr_reg_val;
+
+ test_ready = 0;
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_STATUS_ADDR);
+ timer = pka_dev_timer_start(1000000); // 1000 ms
+
+ while (!test_ready)
+ {
+ csr_reg_val = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ test_ready = csr_reg_val & PKA_TRNG_STATUS_TEST_READY;
+
+ if (pka_dev_timer_done(timer))
+ {
+ PKA_DEBUG(PKA_DEV, "TRNG: TEST ready timer done, 0x%llx\n", csr_reg_val);
+ return 1;
+ }
+ }
+
+ return 0;
+}
+
+static int pka_dev_trng_enable_test(void *csr_reg_ptr, uint64_t csr_reg_base,
+ uint32_t test)
+{
+ uint64_t csr_reg_val, csr_reg_off;
+
+ // Set the test_mode bit in the TRNG_CONTROL register and the
+ // test_known_noise bit in the TRNG_TEST register this will
+ // immediately set the test_ready bit (in the TRNG_STATUS register)
+ // to indicate that data can be written. It will also reset the
+ // monobit test, run test and poker test circuits to their
+ // initial states. Note that the TRNG need not be enabled for this
+ // test.
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_CONTROL_ADDR);
+ csr_reg_val = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_CONTROL_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off,
+ csr_reg_val | PKA_TRNG_CONTROL_TEST_MODE);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_TEST_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, test);
+
+ // Wait until the 'test_ready' bit is set
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_STATUS_ADDR);
+ do
+ {
+ csr_reg_val = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ } while((csr_reg_val & PKA_TRNG_STATUS_TEST_READY) == 0);
+
+ // Check whether the 'monobit test', 'run test' and 'poker test'
+ // are reset.
+ if (csr_reg_val & (PKA_TRNG_STATUS_MONOBIT_FAIL
+ | PKA_TRNG_STATUS_RUN_FAIL
+ | PKA_TRNG_STATUS_POKER_FAIL))
+ {
+ PKA_ERROR(PKA_DEV, "Test bits aren't reset, TRNG_STATUS:0x%llx\n",
+ csr_reg_val);
+ return -EAGAIN;
+ }
+
+ // Set 'stall_run_poker' bit to allow inspecting the state of the
+ // result counters which would otherwise be reset immediately for
+ // the next 20,000 bits block to test.
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_ALARMCNT_ADDR);
+ csr_reg_val = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off,
+ csr_reg_val | PKA_TRNG_ALARMCNT_STALL_RUN_POKER);
+
+ return 0;
+}
+
+static int pka_dev_trng_test_circuits(void *csr_reg_ptr, uint64_t csr_reg_base,
+ uint64_t datal, uint64_t datah,
+ int count, uint8_t add_half,
+ uint64_t *monobit_fail_cnt,
+ uint64_t *run_fail_cnt,
+ uint64_t *poker_fail_cnt)
+{
+ uint64_t status, csr_reg_off;
+ int test_idx, error;
+
+ if (monobit_fail_cnt == NULL || run_fail_cnt == NULL || poker_fail_cnt == NULL)
+ return -EINVAL;
+
+ error = 0;
+
+ for (test_idx = 0; test_idx < count; test_idx++)
+ {
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_RAW_L_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, datal);
+
+ if (add_half)
+ {
+ if (test_idx < count - 1)
+ {
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_RAW_H_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, datah);
+ }
+ }
+ else
+ {
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_RAW_H_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, datah);
+ }
+
+ // Wait until the test_ready bit in the TRNG_STATUS register
+ // becomes 1 again, signaling readiness for the next 64 bits
+ // of test data. At this point, the previous test data has
+ // been handled so the counter states can be inspected.
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_STATUS_ADDR);
+ do
+ {
+ status = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ } while((status & PKA_TRNG_STATUS_TEST_READY) == 0);
+
+ // Check test status bits.
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_INTACK_ADDR);
+ if (status & PKA_TRNG_STATUS_MONOBIT_FAIL)
+ {
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_STATUS_MONOBIT_FAIL);
+ *monobit_fail_cnt += 1;
+ }
+ else if (status & PKA_TRNG_STATUS_RUN_FAIL)
+ {
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_STATUS_RUN_FAIL);
+ *run_fail_cnt += 1;
+ }
+ else if (status & PKA_TRNG_STATUS_POKER_FAIL)
+ {
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_STATUS_POKER_FAIL);
+ *poker_fail_cnt += 1;
+ }
+
+ }
+
+ error = (*monobit_fail_cnt || *poker_fail_cnt || *run_fail_cnt) ? -EIO : 0;
+
+ return error;
+}
+
+static void pka_dev_trng_disable_test(void *csr_reg_ptr, uint64_t csr_reg_base)
+{
+ uint64_t status, val, csr_reg_off;
+
+ // When done, clear the test_known_noise bit in the TRNG_TEST
+ // register (will immediately clear the test_ready bit in the
+ // TRNG_STATUS register and reset the monobit test, run test
+ // and poker test circuits) and clear the test_mode bit in
+ // the TRNG_CONTROL register.
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_TEST_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_STATUS_ADDR);
+ status = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+
+ if (status & PKA_TRNG_STATUS_TEST_READY)
+ PKA_PRINT(PKA_DEV, "Warning: Test ready bit is still set\n");
+
+ if (status & (PKA_TRNG_STATUS_MONOBIT_FAIL
+ | PKA_TRNG_STATUS_RUN_FAIL
+ | PKA_TRNG_STATUS_POKER_FAIL))
+ PKA_PRINT(PKA_DEV,
+ "Warning: Test bits are still set, TRNG_STATUS:0x%llx\n", status);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_CONTROL_ADDR);
+ val = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off,
+ (val & ~PKA_TRNG_STATUS_TEST_READY));
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_ALARMCNT_ADDR);
+ val = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off,
+ (val & ~PKA_TRNG_ALARMCNT_STALL_RUN_POKER));
+
+ return;
+}
+
+static int pka_dev_trng_test_known_answer_basic(void *csr_reg_ptr,
+ uint64_t csr_reg_base)
+{
+ int ret, cnt_idx, cnt_off;
+ uint64_t monobit_fail_cnt, run_fail_cnt, poker_fail_cnt, monobit_cnt;
+ uint64_t poker_cnt[4], csr_reg_off;
+ uint64_t poker_test_exp_cnt[4] = {
+ 0x20f42bf4, 0xaf415f4, 0xf4f4fff4, 0xfff4f4f4
+ };
+
+ PKA_DEBUG(PKA_DEV, "Run known-answer test circuits\n");
+
+ monobit_fail_cnt = 0;
+ run_fail_cnt = 0;
+ poker_fail_cnt = 0;
+
+ ret = pka_dev_trng_enable_test(csr_reg_ptr, csr_reg_base,
+ PKA_TRNG_TEST_KNOWN_NOISE);
+ if (ret)
+ return ret;
+
+ ret = pka_dev_trng_test_circuits(csr_reg_ptr, csr_reg_base, 0x11111333,
+ 0x3555779f, 11, 0, &monobit_fail_cnt, &run_fail_cnt,
+ &poker_fail_cnt);
+
+ ret |= pka_dev_trng_test_circuits(csr_reg_ptr, csr_reg_base, 0x01234567,
+ 0x89abcdef, 302, 1, &monobit_fail_cnt, &run_fail_cnt,
+ &poker_fail_cnt);
+
+ PKA_DEBUG(PKA_DEV, "monobit_fail_cnt : 0x%llx\n", monobit_fail_cnt);
+ PKA_DEBUG(PKA_DEV, "poker_fail_cnt : 0x%llx\n", poker_fail_cnt);
+ PKA_DEBUG(PKA_DEV, "run_fail_cnt : 0x%llx\n", run_fail_cnt);
+
+ for (cnt_idx = 0, cnt_off = 0; cnt_idx < 4; cnt_idx++, cnt_off += 8)
+ {
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ (TRNG_POKER_3_0_ADDR + cnt_off));
+ poker_cnt[cnt_idx] = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ }
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_MONOBITCNT_ADDR);
+ monobit_cnt = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+
+ if (!ret)
+ {
+ if (memcmp(poker_cnt, poker_test_exp_cnt, sizeof(poker_test_exp_cnt)))
+ {
+ PKA_DEBUG(PKA_DEV, "invalid poker counters!\n");
+ ret = -EIO;
+ }
+
+ if (monobit_cnt != 9978)
+ {
+ PKA_DEBUG(PKA_DEV, "invalid sum of squares!\n");
+ ret = -EIO;
+ }
+ }
+
+ pka_dev_trng_disable_test(csr_reg_ptr, csr_reg_base);
+
+ return ret;
+}
+
+static int pka_dev_trng_test_known_answer_poker_fail(void *csr_reg_ptr,
+ uint64_t csr_reg_base)
+{
+ uint64_t monobit_fail_cnt, run_fail_cnt, poker_fail_cnt;
+ int ret;
+
+ monobit_fail_cnt = 0;
+ run_fail_cnt = 0;
+ poker_fail_cnt = 0;
+
+ PKA_DEBUG(PKA_DEV, "Run known-answer test circuits (poker fail)\n");
+
+ pka_dev_trng_enable_test(csr_reg_ptr, csr_reg_base,
+ PKA_TRNG_TEST_KNOWN_NOISE);
+
+ // Ignore the return value here as it is expected that poker test should
+ // fail. Check failure counts thereafter to assert only poker test has failed.
+ pka_dev_trng_test_circuits(csr_reg_ptr, csr_reg_base, 0xffffffff,
+ 0xffffffff, 11, 0, &monobit_fail_cnt, &run_fail_cnt, &poker_fail_cnt);
+
+ PKA_DEBUG(PKA_DEV, "monobit_fail_cnt : 0x%llx\n", monobit_fail_cnt);
+ PKA_DEBUG(PKA_DEV, "poker_fail_cnt : 0x%llx\n", poker_fail_cnt);
+ PKA_DEBUG(PKA_DEV, "run_fail_cnt : 0x%llx\n", run_fail_cnt);
+
+ if (poker_fail_cnt && !run_fail_cnt && !monobit_fail_cnt)
+ ret = 0;
+ else
+ ret = -EIO;
+
+ pka_dev_trng_disable_test(csr_reg_ptr, csr_reg_base);
+
+ return ret;
+}
+
+static int pka_dev_trng_test_unknown_answer(void *csr_reg_ptr,
+ uint64_t csr_reg_base)
+{
+ uint64_t datal, datah, csr_reg_off;
+ int ret, test_idx;
+
+ datah = 0;
+ datal = 0;
+ ret = 0;
+
+ PKA_DEBUG(PKA_DEV, "Run unknown-answer self test\n");
+
+ // First reset, the RAW registers.
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_RAW_L_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_RAW_H_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+
+ // There is a small probability for this test to fail,
+ // So run the test 10 times, if it succeeds once then
+ // assume that the test passed.
+ for (test_idx = 0; test_idx < 10; test_idx++)
+ {
+ pka_dev_trng_enable_test(csr_reg_ptr, csr_reg_base, PKA_TRNG_TEST_NOISE);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_RAW_L_ADDR);
+ datal = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_RAW_H_ADDR);
+ datah = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+
+ PKA_DEBUG(PKA_DEV, "datal=0x%llx\n", datal);
+ PKA_DEBUG(PKA_DEV, "datah=0x%llx\n", datah);
+
+ if (!datah && !datal)
+ {
+ ret = -EIO;
+ }
+ else
+ {
+ ret = 0;
+ break;
+ }
+
+ pka_dev_trng_disable_test(csr_reg_ptr, csr_reg_base);
+ }
+
+ return ret;
+}
+
+// Test TRNG
+static int pka_dev_test_trng(void *csr_reg_ptr, uint64_t csr_reg_base)
+{
+ int ret;
+
+ ret = 0;
+
+ ret = pka_dev_trng_test_known_answer_basic(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ goto exit;
+
+ ret = pka_dev_trng_test_known_answer_poker_fail(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ goto exit;
+
+ ret = pka_dev_trng_test_unknown_answer(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ goto exit;
+
+exit:
+ return ret;
+}
+
+static void pka_dev_trng_write_ps_ai_str(void *csr_reg_ptr,
+ uint64_t csr_reg_base,
+ uint32_t input_str[])
+{
+ uint64_t csr_reg_off;
+ int i;
+
+ for (i = 0; i < PKA_TRNG_PS_AI_REG_COUNT; i++)
+ {
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_PS_AI_0_ADDR + (i * 0x8));
+
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, input_str[i]);
+ }
+}
+
+static void pka_dev_trng_drbg_generate(void *csr_reg_ptr, uint64_t csr_reg_base)
+{
+ uint64_t csr_reg_off;
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_CONTROL_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_CONTROL_REQ_DATA_VAL);
+}
+
+static int pka_dev_test_trng_drbg(void *csr_reg_ptr, uint64_t csr_reg_base)
+{
+ uint64_t csr_reg_off, csr_reg_val;
+ int i, ret;
+
+ ret = 0;
+
+ // Make sure the engine is idle.
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_CONTROL_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+
+ // Enable DRBG, TRNG need not be enabled for this test.
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_CONTROL_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_CONTROL_DRBG_ENABLE_VAL);
+
+ // Set 'test_sp_800_90' bit in the TRNG_TEST register
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_TEST_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_TEST_DRBG_VAL);
+
+ // Wait for 'test_ready' bit to be set.
+ ret = pka_dev_trng_wait_test_ready(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ goto exit;
+
+ // Instantiate
+ pka_dev_trng_write_ps_ai_str(csr_reg_ptr, csr_reg_base, pka_trng_drbg_test_ps_str);
+ ret = pka_dev_trng_wait_test_ready(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ goto exit;
+
+ // Generate
+ pka_dev_trng_write_ps_ai_str(csr_reg_ptr, csr_reg_base, pka_trng_drbg_test_etpy_str1);
+ ret = pka_dev_trng_wait_test_ready(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ goto exit;
+
+ // A standard NIST SP 800-90A DRBG known-answer test discards
+ // the result of the first 'Generate' function and only checks
+ // the result of the second 'Generate' function. Hence 'Generate'
+ // is performed again.
+
+ // Generate
+ pka_dev_trng_write_ps_ai_str(csr_reg_ptr, csr_reg_base, pka_trng_drbg_test_etpy_str2);
+ ret = pka_dev_trng_wait_test_ready(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ goto exit;
+
+ // Check output registers
+ for (i = 0; i < PKA_TRNG_OUTPUT_CNT; i++)
+ {
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_OUTPUT_0_ADDR + (i * 0x8));
+
+ csr_reg_val = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+
+ if ((uint32_t)csr_reg_val != pka_trng_drbg_test_output[i])
+ {
+ PKA_DEBUG(PKA_DEV,
+ "DRBG known answer test failed for output register:%d, 0x%x\n",
+ i, (uint32_t)csr_reg_val);
+ ret = 1;
+ goto exit;
+ }
+ }
+
+ // Clear 'test_sp_800_90' bit in the TRNG_TEST register.
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_TEST_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+
+exit:
+ return ret;
+}
+
+// Configure the TRNG.
+static int pka_dev_config_trng_drbg(pka_dev_res_t *aic_csr_ptr,
+ pka_dev_res_t *trng_csr_ptr)
+{
+ int ret = 0;
+
+ uint64_t csr_reg_base, csr_reg_off;
+ void *csr_reg_ptr;
+
+ if (trng_csr_ptr->status != PKA_DEV_RES_STATUS_MAPPED ||
+ trng_csr_ptr->type != PKA_DEV_RES_TYPE_REG)
+ return -EPERM;
+
+ PKA_DEBUG(PKA_DEV, "Starting up the TRNG\n");
+
+ ret = pka_dev_config_trng_clk(aic_csr_ptr);
+ if (ret)
+ return ret;
+
+ csr_reg_base = trng_csr_ptr->base;
+ csr_reg_ptr = trng_csr_ptr->ioaddr;
+
+ // Perform NIST known-answer tests on the complete SP 800-90A DRBG
+ // without BC_DF functionality.
+ ret = pka_dev_test_trng_drbg(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ return ret;
+
+ // Starting up the TRNG with a DRBG
+
+ // Make sure the engine is idle.
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_CONTROL_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+
+ // Disable all FROs initially
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_FROENABLE_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_FRODETUNE_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+
+ // Write all configuration values in the TRNG_CONFIG and TRNG_ALARMCNT,
+ // write zeroes to the TRNG_ALARMMASK and TRNG_ALARMSTOP registers.
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_CONFIG_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_CONFIG_REG_VAL);
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_ALARMCNT_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_ALARMCNT_REG_VAL);
+
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_ALARMMASK_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_ALARMSTOP_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+
+ // Enable all FROs in the TRNG_FROENABLE register. Note that this can
+ // only be done after clearing the TRNG_ALARMSTOP register.
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_FROENABLE_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_FROENABLE_REG_VAL);
+
+ // Optionally, write 'Personalization string' of upto 384 bits in
+ // TRNG_PS_AI_... registers. The contents of these registers will be
+ // XOR-ed into the output of the SHA-256 'Conditioning Function' to be
+ // used as seed value for the actual DRBG.
+ pka_dev_trng_write_ps_ai_str(csr_reg_ptr, csr_reg_base, pka_trng_drbg_ps_str);
+
+
+ // Run TRNG tests after configuring TRNG.
+ // NOTE: TRNG need not be enabled to carry out these tests.
+ ret = pka_dev_test_trng(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ return ret;
+
+ // Start the actual engine by setting the 'enable_trng' and 'drbg_en' bit
+ // in the TRNG_CONTROL register (also a nice point to set the interrupt mask
+ // bits).
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_CONTROL_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_CONTROL_DRBG_REG_VAL);
+
+ // The engine is now ready to handle the first 'Generate' request using
+ // the 'request_data' bit of the TRNG_CONTROL register. The first output
+ // for these requests will take a while, as Noise Source and Conditioning
+ // Function must first generate seed entropy for the DRBG.
+
+
+ // Optionally, when buffer RAM is configured: Set a data available
+ // interrupt threshold using the 'load_thresh' and 'blocks_thresh'
+ // fields of the TRNG_INTACK register. This allows delaying the data
+ // available interrupt until the indicated number of 128-bit words are
+ // available in the buffer RAM.
+
+ // Start the actual 'Generate' operation using the 'request_data' and 'data_blocks'
+ // fields of the TRNG_CONTROL register.
+
+ pka_dev_trng_drbg_generate(csr_reg_ptr, csr_reg_base);
+
+ mdelay(200);
+
+ return ret;
+}
+
+// Triggers hardaware zeorize to initialize PKA internal memories
+static int pka_dev_ram_zeroize(pka_dev_res_t *ext_csr_ptr)
+{
+ uint64_t csr_reg_base, csr_reg_off, csr_reg_value;
+ uint64_t timer;
+ void *csr_reg_ptr;
+
+ if (ext_csr_ptr->status != PKA_DEV_RES_STATUS_MAPPED ||
+ ext_csr_ptr->type != PKA_DEV_RES_TYPE_REG)
+ return -EPERM;
+
+ PKA_DEBUG(PKA_DEV, "Starting memory zeroize\n");
+
+ csr_reg_base = ext_csr_ptr->base;
+ csr_reg_ptr = ext_csr_ptr->ioaddr;
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ PKA_ZEROIZE_ADDR);
+ // When PKA_ZEROIZE register is written (with any value)
+ // sensitive data in the PKA is zeroed out.
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 1);
+
+ // Now wait until the zeroize completes
+ timer = pka_dev_timer_start(10000000); // 10000 ms
+ csr_reg_value = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ while (csr_reg_value != 0)
+ {
+ csr_reg_value = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+
+ if (pka_dev_timer_done(timer))
+ {
+ PKA_DEBUG(PKA_DEV, "Timeout while PKA zeorize\n");
+ return -EBUSY;
+ }
+ }
+
+ return 0;
+}
+
+// Initialize PKA IO block refered to as shim. It configures shim's
+// parameters and prepare resources by mapping corresponding memory.
+// The function also configures shim registers and load firmware to
+// shim internal rams. The pka_dev_shim_t passed as input is also an
+// output. It returns 0 on success, a negative error code on failure.
+static int pka_dev_init_shim(pka_dev_shim_t *shim)
+{
+ const uint32_t *farm_img_ptr;
+ uint32_t farm_img_size, data[4], i;
+ uint8_t shim_fw_id;
+
+ int ret = 0;
+
+ if (shim->status != PKA_SHIM_STATUS_CREATED)
+ {
+ PKA_ERROR(PKA_DEV, "PKA device must be created\n");
+ return -EPERM;
+ }
+
+ // First of all, trigger a hardware zeroize to initialize internal
+ // RAM memories
+ ret = pka_dev_ram_zeroize(&shim->resources.ext_csr);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to zeroize PKA\n");
+ return ret;
+ }
+
+ // Configure AIC registers
+ ret = pka_dev_config_aic_interrupts(&shim->resources.aic_csr);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to configure AIC\n");
+ return ret;
+ }
+
+ shim_fw_id = pka_firmware_get_id();
+
+ // Load Farm image into PKA_BUFFER_RAM for non-High Assurance mode
+ // or into PKA_SECURE_RAM for High Assurance mode.
+ farm_img_size = pka_firmware_array[shim_fw_id].farm_img_size;
+ PKA_DEBUG(PKA_DEV, "loading farm image (%d words)\n", farm_img_size);
+
+ farm_img_ptr = pka_firmware_array[shim_fw_id].farm_img;
+ // The IP provider suggests using the zeroize function to initialize
+ // the Buffer RAM. But a bug has been detected when writing ECC bits.
+ // Thus a workaround is used, and has already been shown to work; it
+ // consists of padding the farm image. Then all RAM locations will be
+ // written with correct ECC before the IP reads the image out.
+ ret = pka_dev_load_image(&shim->resources.buffer_ram, farm_img_ptr,
+ farm_img_size);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to load farm image\n");
+ return ret;
+ }
+
+ // Configure EIP-154 Master controller Sequencer
+ ret = pka_dev_config_master_seq_controller(shim,
+ &shim->resources.master_seq_ctrl);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to configure Master controller "
+ "Sequencer\n");
+ return ret;
+ }
+
+ // Configure PKA Ring options control word
+ ret = pka_dev_config_ring_options(&shim->resources.buffer_ram,
+ shim->rings_num, shim->ring_priority);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to configure ring options\n");
+ return ret;
+ }
+
+ shim->trng_enabled = PKA_SHIM_TRNG_ENABLED;
+ shim->trng_err_cycle = 0;
+
+ // Configure the TRNG
+ ret = pka_dev_config_trng_drbg(&shim->resources.aic_csr,
+ &shim->resources.trng_csr);
+
+ // Pull out data from the content of the TRNG buffer RAM and
+ // start the re-generation of new numbers; read and drop 512
+ // words. The read must be done over the 4 TRNG_OUTPUT_X registers
+ // at a time.
+ i = 0;
+ while (i < 128)
+ {
+ pka_dev_trng_read(shim, data, sizeof(data));
+ i++;
+ }
+
+ if (ret)
+ {
+ // Keep running without TRNG since it does not hurt, but
+ // notify users.
+ PKA_ERROR(PKA_DEV, "failed to configure TRNG\n");
+ shim->trng_enabled = PKA_SHIM_TRNG_DISABLED;
+ }
+
+ mutex_init(&shim->mutex);
+ shim->busy_ring_num = 0;
+ shim->status = PKA_SHIM_STATUS_INITIALIZED;
+
+ return ret;
+}
+
+// Release a given shim.
+static int pka_dev_release_shim(pka_dev_shim_t *shim)
+{
+ int ret = 0;
+
+ uint32_t ring_idx;
+
+ if (shim->status != PKA_SHIM_STATUS_INITIALIZED &&
+ shim->status != PKA_SHIM_STATUS_STOPPED)
+ {
+ PKA_ERROR(PKA_DEV, "PKA device must be initialized or stopped\n");
+ return -EPERM;
+ }
+
+ // Release rings which belong to the shim. The operating system might
+ // release ring devices before shim devices. The global configuration
+ // must be checked before proceeding to the release of ring devices.
+ if (pka_gbl_config.dev_rings_cnt)
+ {
+ for (ring_idx = 0; ring_idx < shim->rings_num; ring_idx++)
+ {
+ ret = pka_dev_release_ring(shim->rings[ring_idx]);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to release ring %d\n", ring_idx);
+ return ret;
+ }
+ }
+ }
+
+ shim->busy_ring_num = 0;
+ shim->status = PKA_SHIM_STATUS_FINALIZED;
+
+ return ret;
+}
+
+// Return the ring associated with the given identifier.
+pka_dev_ring_t *pka_dev_get_ring(uint32_t ring_id)
+{
+ return pka_gbl_config.dev_rings[ring_id];
+}
+
+// Return the shim associated with the given identifier.
+pka_dev_shim_t *pka_dev_get_shim(uint32_t shim_id)
+{
+ return pka_gbl_config.dev_shims[shim_id];
+}
+
+
+static pka_dev_ring_t *__pka_dev_register_ring(uint32_t ring_id,
+ uint32_t shim_id)
+{
+ pka_dev_shim_t *shim;
+ pka_dev_ring_t *ring;
+
+ int ret;
+
+ shim = pka_dev_get_shim(shim_id);
+ if (!shim)
+ return NULL;
+
+ ring = kzalloc(sizeof(pka_dev_ring_t), GFP_KERNEL);
+ if (!ring)
+ return ring;
+
+ ring->status = PKA_DEV_RING_STATUS_UNDEFINED;
+
+ // Initialize ring.
+ ret = pka_dev_init_ring(ring, ring_id, shim);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to initialize ring %d\n", ring_id);
+ pka_dev_release_ring(ring);
+ kfree(ring);
+ return NULL;
+ }
+
+ return ring;
+}
+
+pka_dev_ring_t *pka_dev_register_ring(uint32_t ring_id, uint32_t shim_id)
+{
+ pka_dev_ring_t *ring;
+
+ ring = __pka_dev_register_ring(ring_id, shim_id);
+ if (ring)
+ {
+ pka_gbl_config.dev_rings[ring->ring_id] = ring;
+ pka_gbl_config.dev_rings_cnt += 1;
+ }
+
+ return ring;
+}
+
+static int __pka_dev_unregister_ring(pka_dev_ring_t *ring)
+{
+ int ret;
+
+ if (!ring)
+ return -EINVAL;
+
+ // Release ring
+ ret = pka_dev_release_ring(ring);
+ if (ret)
+ return ret;
+
+ kfree(ring);
+
+ return ret;
+}
+
+int pka_dev_unregister_ring(pka_dev_ring_t *ring)
+{
+ pka_gbl_config.dev_rings[ring->ring_id] = NULL;
+ pka_gbl_config.dev_rings_cnt -= 1;
+
+ return __pka_dev_unregister_ring(ring);
+}
+
+static pka_dev_shim_t *__pka_dev_register_shim(uint32_t shim_id,
+ struct pka_dev_mem_res *mem_res)
+{
+ pka_dev_shim_t *shim;
+
+ uint8_t split;
+ int ret = 0;
+
+ PKA_DEBUG(PKA_DEV, "register shim id=%u\n", shim_id);
+
+ shim = kzalloc(sizeof(pka_dev_shim_t), GFP_KERNEL);
+ if (!shim)
+ return shim;
+
+ // Shim state MUST be set to undefined before calling 'pka_dev_create_shim'
+ // function
+ shim->status = PKA_SHIM_STATUS_UNDEFINED;
+
+ // Set the Window RAM user mode
+ split = PKA_SPLIT_WINDOW_RAM_MODE;
+
+ // Create PKA shim
+ ret = pka_dev_create_shim(shim, shim_id, split, mem_res);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to create shim %u\n", shim_id);
+ pka_dev_delete_shim(shim);
+ kfree(shim);
+ return NULL;
+ }
+
+ // Initialize PKA shim
+ ret = pka_dev_init_shim(shim);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to init shim %u\n", shim_id);
+ pka_dev_release_shim(shim);
+ pka_dev_delete_shim(shim);
+ kfree(shim);
+ return NULL;
+ }
+
+ return shim;
+}
+
+pka_dev_shim_t *pka_dev_register_shim(uint32_t shim_id, uint8_t shim_fw_id,
+ struct pka_dev_mem_res *mem_res)
+{
+ pka_dev_shim_t *shim;
+
+ pka_firmware_set_id(shim_fw_id);
+
+ shim = __pka_dev_register_shim(shim_id, mem_res);
+ if (shim)
+ {
+ pka_gbl_config.dev_shims[shim->shim_id] = shim;
+ pka_gbl_config.dev_shims_cnt += 1;
+ }
+
+ return shim;
+}
+
+static int __pka_dev_unregister_shim(pka_dev_shim_t *shim)
+{
+ int ret = 0;
+
+ if (!shim)
+ return -EINVAL;
+
+ // Release shim
+ ret = pka_dev_release_shim(shim);
+ if (ret)
+ return ret;
+
+ // Delete shim
+ ret = pka_dev_delete_shim(shim);
+ if (ret)
+ return ret;
+
+ kfree(shim);
+
+ return ret;
+}
+
+int pka_dev_unregister_shim(pka_dev_shim_t *shim)
+{
+ pka_gbl_config.dev_shims[shim->shim_id] = NULL;
+ pka_gbl_config.dev_shims_cnt -= 1;
+
+ return __pka_dev_unregister_shim(shim);
+}
+
+static bool pka_dev_trng_shutdown_oflo(pka_dev_res_t *trng_csr_ptr,
+ uint64_t *err_cycle)
+{
+ uint64_t csr_reg_base, csr_reg_off, csr_reg_value;
+ uint64_t curr_cycle_cnt, fro_stopped_mask, fro_enabled_mask;
+ void *csr_reg_ptr;
+
+ csr_reg_base = trng_csr_ptr->base;
+ csr_reg_ptr = trng_csr_ptr->ioaddr;
+
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_STATUS_ADDR);
+ csr_reg_value = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+
+ if (csr_reg_value & PKA_TRNG_STATUS_SHUTDOWN_OFLO)
+ {
+ curr_cycle_cnt = get_cycles();
+ // See if any FROs were shut down. If they were, toggle bits in the
+ // FRO detune register and reenable the FROs.
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_ALARMSTOP_ADDR);
+ fro_stopped_mask = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ if (fro_stopped_mask)
+ {
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_FROENABLE_ADDR);
+ fro_enabled_mask = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_FRODETUNE_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, fro_stopped_mask);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_FROENABLE_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off,
+ fro_stopped_mask | fro_enabled_mask);
+ }
+
+ // Reset the error
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_ALARMMASK_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_ALARMSTOP_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, 0);
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_INTACK_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off,
+ PKA_TRNG_STATUS_SHUTDOWN_OFLO);
+
+ // If we're seeing this error again within about a second,
+ // the hardware is malfunctioning. Disable the trng and return
+ // an error.
+ if (*err_cycle && (curr_cycle_cnt - *err_cycle < 1000000000))
+ {
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_CONTROL_ADDR);
+ csr_reg_value = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ csr_reg_value &= ~PKA_TRNG_CONTROL_REG_VAL;
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, csr_reg_value);
+ return false;
+ }
+
+ *err_cycle = curr_cycle_cnt;
+ }
+
+ return true;
+}
+
+static int pka_dev_trng_drbg_reseed(void *csr_reg_ptr, uint64_t csr_reg_base)
+{
+ uint64_t csr_reg_off;
+ int ret;
+
+ ret = 0;
+
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base, TRNG_CONTROL_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_CONTROL_DRBG_RESEED);
+
+ ret = pka_dev_trng_wait_test_ready(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ return ret;
+
+ // Write personalization string
+ pka_dev_trng_write_ps_ai_str(csr_reg_ptr, csr_reg_base, pka_trng_drbg_ps_str);
+
+ return ret;
+}
+
+// Read from DRBG enabled TRNG
+int pka_dev_trng_read(pka_dev_shim_t *shim, uint32_t *data, uint32_t cnt)
+{
+ int ret = 0;
+
+ pka_dev_res_t *trng_csr_ptr;
+ uint64_t csr_reg_base, csr_reg_off, csr_reg_value;
+ uint64_t timer;
+ uint32_t data_idx, word_cnt;
+ uint8_t output_idx, trng_ready = 0;
+ void *csr_reg_ptr;
+
+ if (!shim || !data || (cnt % PKA_TRNG_OUTPUT_CNT != 0))
+ return -EINVAL;
+
+ if (!cnt)
+ return ret;
+
+ mutex_lock(&shim->mutex);
+
+ trng_csr_ptr = &shim->resources.trng_csr;
+
+ if (trng_csr_ptr->status != PKA_DEV_RES_STATUS_MAPPED ||
+ trng_csr_ptr->type != PKA_DEV_RES_TYPE_REG)
+ {
+ ret = -EPERM;
+ goto exit;
+ }
+
+ csr_reg_base = trng_csr_ptr->base;
+ csr_reg_ptr = trng_csr_ptr->ioaddr;
+
+ if (!pka_dev_trng_shutdown_oflo(trng_csr_ptr,
+ &shim->trng_err_cycle))
+ {
+ ret = -EWOULDBLOCK;
+ goto exit;
+ }
+
+ // Determine the number of 32-bit words.
+ word_cnt = cnt >> 2;
+
+ for (data_idx = 0; data_idx < word_cnt; data_idx++)
+ {
+ output_idx = data_idx % PKA_TRNG_OUTPUT_CNT;
+
+ // Tell the hardware to advance
+ if (output_idx == 0)
+ {
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_INTACK_ADDR);
+ pka_dev_io_write(csr_reg_ptr, csr_reg_off, PKA_TRNG_STATUS_READY);
+ trng_ready = 0;
+
+ // Check if 'data_blocks' field is zero in TRNG_CONTROL register,
+ // if it is then we have to issue a 'Reseed' and Generate' request
+ // for DRBG enabled TRNG.
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_CONTROL_ADDR);
+ csr_reg_value = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+
+ if (!((uint32_t)csr_reg_value & PKA_TRNG_DRBG_DATA_BLOCK_MASK))
+ {
+ // Issue reseed
+ ret = pka_dev_trng_drbg_reseed(csr_reg_ptr, csr_reg_base);
+ if (ret)
+ {
+ ret = -EBUSY;
+ goto exit;
+ }
+
+ // Issue generate request
+ pka_dev_trng_drbg_generate(csr_reg_ptr, csr_reg_base);
+ }
+
+ }
+
+ // Wait until a data word is available in the TRNG_OUTPUT_X
+ // registers (using the interrupt and/or 'ready' status bit in the
+ // TRNG_STATUS register. The only way this would hang if the TRNG
+ // never initialized, and we would not call this function if that
+ // happened.
+ timer = pka_dev_timer_start(1000000); // 1000 ms
+ csr_reg_off =
+ pka_dev_get_register_offset(csr_reg_base, TRNG_STATUS_ADDR);
+ while (trng_ready == 0)
+ {
+ csr_reg_value = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ trng_ready = csr_reg_value & PKA_TRNG_STATUS_READY;
+
+ if (pka_dev_timer_done(timer))
+ {
+ PKA_DEBUG(PKA_DEV,
+ "Shim %u got error obtaining random number\n",
+ shim->shim_id);
+ ret = -EBUSY;
+ goto exit;
+ }
+ }
+
+ // Read the registers
+ csr_reg_off = pka_dev_get_register_offset(csr_reg_base,
+ TRNG_OUTPUT_0_ADDR + (output_idx * 0x8));
+ csr_reg_value = pka_dev_io_read(csr_reg_ptr, csr_reg_off);
+ data[data_idx] = (uint32_t) csr_reg_value;
+ }
+
+exit:
+ mutex_unlock(&shim->mutex);
+ return ret;
+}
+
+bool pka_dev_has_trng(pka_dev_shim_t *shim)
+{
+ if (!shim)
+ return false;
+
+ return (shim->trng_enabled == PKA_SHIM_TRNG_ENABLED);
+}
+
+// Syscall to open ring.
+int __pka_dev_open_ring(uint32_t ring_id)
+{
+ pka_dev_shim_t *shim;
+ pka_dev_ring_t *ring;
+
+ int ret = 0;
+
+ if (pka_gbl_config.dev_rings_cnt == 0)
+ return -EPERM;
+
+ ring = pka_dev_get_ring(ring_id);
+ if (!ring || !ring->shim)
+ return -ENXIO;
+
+ shim = ring->shim;
+
+ mutex_lock(&ring->mutex);
+
+ if (shim->status == PKA_SHIM_STATUS_UNDEFINED ||
+ shim->status == PKA_SHIM_STATUS_CREATED ||
+ shim->status == PKA_SHIM_STATUS_FINALIZED)
+ {
+ ret = -EPERM;
+ goto unlock_return;
+ }
+
+ if (ring->status == PKA_DEV_RING_STATUS_BUSY)
+ {
+ ret = -EBUSY;
+ goto unlock_return;
+ }
+
+ if (ring->status != PKA_DEV_RING_STATUS_INITIALIZED)
+ {
+ ret = -EPERM;
+ goto unlock_return;
+ }
+
+ // Set ring information words.
+ ret = pka_dev_set_ring_info(ring);
+ if (ret)
+ {
+ PKA_ERROR(PKA_DEV, "failed to set ring information\n");
+ ret = -EWOULDBLOCK;
+ goto unlock_return;
+ }
+
+ if (shim->busy_ring_num == 0)
+ shim->status = PKA_SHIM_STATUS_RUNNING;
+
+ ring->status = PKA_DEV_RING_STATUS_BUSY;
+ shim->busy_ring_num += 1;
+
+unlock_return:
+ mutex_unlock(&ring->mutex);
+ return ret;
+}
+
+// Open ring.
+int pka_dev_open_ring(pka_ring_info_t *ring_info)
+{
+ return __pka_dev_open_ring(ring_info->ring_id);
+}
+
+// Syscall to close ring.
+int __pka_dev_close_ring(uint32_t ring_id)
+{
+ pka_dev_shim_t *shim;
+ pka_dev_ring_t *ring;
+
+ int ret = 0;
+
+ if (pka_gbl_config.dev_rings_cnt == 0)
+ return -EPERM;
+
+ ring = pka_dev_get_ring(ring_id);
+ if (!ring || !ring->shim)
+ return -ENXIO;
+
+ shim = ring->shim;
+
+ mutex_lock(&ring->mutex);
+
+ if (shim->status != PKA_SHIM_STATUS_RUNNING &&
+ ring->status != PKA_DEV_RING_STATUS_BUSY)
+ {
+ ret = -EPERM;
+ goto unlock_return;
+ }
+
+ ring->status = PKA_DEV_RING_STATUS_INITIALIZED;
+ shim->busy_ring_num -= 1;
+
+ if (shim->busy_ring_num == 0)
+ shim->status = PKA_SHIM_STATUS_STOPPED;
+
+unlock_return:
+ mutex_unlock(&ring->mutex);
+ return ret;
+}
+
+// Close ring.
+int pka_dev_close_ring(pka_ring_info_t *ring_info)
+{
+ if (ring_info)
+ {
+ return __pka_dev_close_ring(ring_info->ring_id);
+ }
+
+ return 0;
+}
+
+// Syscall to map ring into memory (kernel-space).
+static int __pka_dev_mmap_ring(uint32_t ring_id)
+{
+ //not implemented
+ return -1;
+}
+
+// Map ring into memory (user-space).
+int pka_dev_mmap_ring(pka_ring_info_t *ring_info)
+{
+ return __pka_dev_mmap_ring(ring_info->ring_id);
+}
+
+// Syscall to unmap ring (kernel-space).
+static int __pka_dev_munmap_ring(uint32_t ring_id)
+{
+ //not implemented
+ return -1;
+}
+
+// Unmap ring (user-space).
+int pka_dev_munmap_ring(pka_ring_info_t *ring_info)
+{
+ if (ring_info)
+ {
+ return __pka_dev_munmap_ring(ring_info->ring_id);
+ }
+
+ return 0;
+}
+
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_dev.h b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_dev.h
new file mode 100644
index 000000000..06ac28623
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_dev.h
@@ -0,0 +1,310 @@
+//
+// BSD LICENSE
+//
+// Copyright(c) 2016 Mellanox Technologies, Ltd. All rights reserved.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in
+// the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Mellanox Technologies nor the names of its
+// contributors may be used to endorse or promote products derived
+// from this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+
+#ifndef __PKA_DEV_H__
+#define __PKA_DEV_H__
+
+///
+/// @file
+///
+/// API to handle the PKA EIP-154 I/O block (shim). It provides functions
+/// and data structures to initialize and configure the PKA shim. It's the
+/// "southband interface" for communication with PKA hardware resources.
+///
+
+#include <linux/mutex.h>
+#include <linux/types.h>
+#include "mlxbf_pka_firmware.h"
+
+#include <linux/vfio.h>
+
+#include "mlxbf_pka_config.h"
+#include "mlxbf_pka_cpu.h"
+#include "mlxbf_pka_debug.h"
+#include "mlxbf_pka_ioctl.h"
+#include "mlxbf_pka_mmio.h"
+#include "mlxbf_pka_ring.h"
+
+#define PKA_SYSFS_RING_DEVICES "/sys/bus/platform/devices"
+#define PKA_VFIO_DIR "/dev/vfio"
+#define PKA_VFIO_CONTAINER_PATH "/dev/vfio/vfio"
+#define PKA_VFIO_GROUP_FMT "/dev/vfio/%d"
+
+#define PKA_DEVFS_RING_DEVICES "/dev/pka/%d"
+
+// Defines specific to device-tree and Linux operating system.
+// Careful, all constants MUST be conform with both devicetree
+// (DTS) and ACPI tables (SSDT).
+// *TBD* Better to be detected automatically (or passed as arg
+// so far).
+#define PKA_DEV_RING_DT_PREFIX_0 "45000000.eip154:ring@%d"
+#define PKA_DEV_RING_DT_PREFIX_1 "47000000.eip154:ring@%d"
+#define PKA_DEV_RING_DT_PREFIX_2 "4d000000.eip154:ring@%d"
+#define PKA_DEV_RING_DT_PREFIX_3 "4f000000.eip154:ring@%d"
+#define PKA_DEV_RING_DT_PREFIX_4 "44000000.eip154:ring@%d"
+#define PKA_DEV_RING_DT_PREFIX_5 "46000000.eip154:ring@%d"
+#define PKA_DEV_RING_DT_PREFIX_6 "4c000000.eip154:ring@%d"
+#define PKA_DEV_RING_DT_PREFIX_7 "4e000000.eip154:ring@%d"
+
+#define PKA_DEV_RING_ACPI_PREFIX "MLNXBF11:%02x"
+
+/// Device resource structure
+typedef struct
+{
+ void *ioaddr; ///< (iore)map-ped version of addr, for
+ /// driver internal use.
+
+ uint64_t base; ///< base address of the device's
+ /// resource
+
+ uint64_t size; ///< size of IO
+
+ uint8_t type; ///< type of resource addr points to
+ int8_t status; ///< status of the resource
+
+ char *name; ///< name of the resource
+} pka_dev_res_t;
+
+/// defines for pka_dev_res->type
+#define PKA_DEV_RES_TYPE_MEM 1 // resource type is memory
+#define PKA_DEV_RES_TYPE_REG 2 // resource type is register
+
+/// defines for pka_dev_res->status
+#define PKA_DEV_RES_STATUS_MAPPED 1 // the resource is (iore)-mapped
+#define PKA_DEV_RES_STATUS_UNMAPPED -1 // the resource is unmapped
+
+/// PKA Ring resources structure
+typedef struct
+{
+ pka_dev_res_t info_words; // ring information words
+ pka_dev_res_t counters; // ring counters
+ pka_dev_res_t window_ram; // window RAM
+} pka_dev_ring_res_t;
+
+typedef struct pka_dev_shim_s pka_dev_shim_t;
+
+/// PKA Ring structure
+typedef struct
+{
+ uint32_t ring_id; ///< ring identifier.
+
+ pka_dev_shim_t *shim; ///< pointer to the shim associated
+ /// to the ring.
+
+ uint32_t resources_num; ///< number of ring ressources.
+ pka_dev_ring_res_t resources; ///< ring resources.
+
+ pka_dev_hw_ring_info_t *ring_info; ///< ring information.
+ uint32_t num_cmd_desc; ///< number of command descriptors.
+
+ int8_t status; ///< status of the ring.
+
+ struct mutex mutex; ///< mutex lock for sharing ring device
+} pka_dev_ring_t;
+
+/// defines for pka_dev_ring->status
+#define PKA_DEV_RING_STATUS_UNDEFINED -1
+#define PKA_DEV_RING_STATUS_INITIALIZED 1
+#define PKA_DEV_RING_STATUS_READY 2
+#define PKA_DEV_RING_STATUS_BUSY 3
+#define PKA_DEV_RING_STATUS_FINALIZED 4
+
+/// PKA Shim resources structure
+typedef struct
+{
+ pka_dev_res_t buffer_ram; // buffer RAM
+ pka_dev_res_t master_prog_ram; // master controller program RAM
+ pka_dev_res_t master_seq_ctrl; // master sequencer controller CSR
+ pka_dev_res_t aic_csr; // interrupt controller CSRs
+ pka_dev_res_t trng_csr; // TRNG module CSRs
+ pka_dev_res_t ext_csr; // MiCA specific CSRs (glue logic)
+} pka_dev_shim_res_t;
+
+#define PKA_DEV_SHIM_RES_CNT 6 // Number of PKA device resources
+
+/// Platform global shim resource information
+typedef struct
+{
+ pka_dev_res_t *res_tbl[PKA_DEV_SHIM_RES_CNT];
+ uint8_t res_cnt;
+} pka_dev_gbl_shim_res_info_t;
+
+struct pka_dev_mem_res
+{
+ uint64_t eip154_base; ///< base address for eip154 mmio registers
+ uint64_t eip154_size; ///< eip154 mmio register region size
+
+ uint64_t wndw_ram_off_mask; ///< common offset mask for alt window ram and window ram
+ uint64_t wndw_ram_base; ///< base address for window ram
+ uint64_t wndw_ram_size; ///< window ram region size
+
+ uint64_t alt_wndw_ram_0_base; ///< base address for alternate window ram 0
+ uint64_t alt_wndw_ram_1_base; ///< base address for alternate window ram 1
+ uint64_t alt_wndw_ram_2_base; ///< base address for alternate window ram 2
+ uint64_t alt_wndw_ram_3_base; ///< base address for alternate window ram 3
+ uint64_t alt_wndw_ram_size; ///< alternate window ram regions size
+
+ uint64_t csr_base; ///< base address for csr registers
+ uint64_t csr_size; ///< csr area size
+};
+
+
+/// PKA Shim structure
+struct pka_dev_shim_s
+{
+ struct pka_dev_mem_res mem_res;
+
+ uint64_t trng_err_cycle; ///< TRNG error cycle
+
+ uint32_t shim_id; ///< shim identifier
+
+ uint32_t rings_num; ///< Number of supported rings (hw
+ /// specific)
+
+ pka_dev_ring_t **rings; ///< pointer to rings which belong to
+ /// the shim.
+
+ uint8_t ring_priority; ///< specify the priority in which
+ /// rings are handled.
+
+ uint8_t ring_type; ///< indicates whether the result
+ /// ring delivers results strictly
+ /// in-order.
+
+ pka_dev_shim_res_t resources; ///< shim resources
+
+ uint8_t window_ram_split; ///< Window RAM mode. if non-zero,
+ /// the splitted window RAM scheme
+ /// is used.
+
+ uint32_t busy_ring_num; ///< Number of active rings (rings in
+ /// busy state)
+
+ uint8_t trng_enabled; ///< Whether the TRNG engine is
+ /// enabled.
+
+ int8_t status; ///< status of the shim
+
+ struct mutex mutex; ///< mutex lock for sharing shim
+};
+
+/// defines for pka_dev_shim->status
+#define PKA_SHIM_STATUS_UNDEFINED -1
+#define PKA_SHIM_STATUS_CREATED 1
+#define PKA_SHIM_STATUS_INITIALIZED 2
+#define PKA_SHIM_STATUS_RUNNING 3
+#define PKA_SHIM_STATUS_STOPPED 4
+#define PKA_SHIM_STATUS_FINALIZED 5
+
+/// defines for pka_dev_shim->window_ram_split
+#define PKA_SHIM_WINDOW_RAM_SPLIT_ENABLED 1 // window RAM is splitted into
+ // 4 * 16KB blocks
+
+#define PKA_SHIM_WINDOW_RAM_SPLIT_DISABLED 2 // window RAM is not splitted
+ // and occupies 64KB
+
+/// defines for pka_dev_shim->trng_enabled
+#define PKA_SHIM_TRNG_ENABLED 1
+#define PKA_SHIM_TRNG_DISABLED 0
+
+/// Platform global configuration structure
+typedef struct
+{
+ uint32_t dev_shims_cnt; ///< number of registered PKA shims.
+ uint32_t dev_rings_cnt; ///< number of registered Rings.
+
+ pka_dev_shim_t *dev_shims[PKA_MAX_NUM_IO_BLOCKS]; ///< table of registered
+ /// PKA shims.
+
+ pka_dev_ring_t *dev_rings[PKA_MAX_NUM_RINGS]; ///< table of registered
+ /// Rings.
+} pka_dev_gbl_config_t;
+
+extern pka_dev_gbl_config_t pka_gbl_config;
+
+/// Ring getter for pka_dev_gbl_config_t structure which holds all system
+/// global configuration. This configuration is shared and common to kernel
+/// device driver associated with PKA hardware.
+pka_dev_ring_t *pka_dev_get_ring(uint32_t ring_id);
+
+/// Shim getter for pka_dev_gbl_config_t structure which holds all system
+/// global configuration. This configuration is shared and common to kernel
+/// device driver associated with PKA hardware.
+pka_dev_shim_t *pka_dev_get_shim(uint32_t shim_id);
+
+/// Register a Ring. This function initializes a Ring and configures its
+/// related resources, and returns a pointer to that ring.
+pka_dev_ring_t *pka_dev_register_ring(uint32_t ring_id, uint32_t shim_id);
+
+/// Unregister a Ring
+int pka_dev_unregister_ring(pka_dev_ring_t *ring);
+
+/// Register PKA IO block. This function initializes a shim and configures its
+/// related resources, and returns a pointer to that ring.
+pka_dev_shim_t *pka_dev_register_shim(uint32_t shim_id, uint8_t shim_fw_id,
+ struct pka_dev_mem_res *mem_res);
+
+/// Unregister PKA IO block
+int pka_dev_unregister_shim(pka_dev_shim_t *shim);
+
+/// Reset a Ring.
+int pka_dev_reset_ring(pka_dev_ring_t *ring);
+
+/// Clear ring counters. This function resets the master sequencer controller
+/// to clear the command and result counters.
+int pka_dev_clear_ring_counters(pka_dev_ring_t *ring);
+
+/// Read data from the TRNG. Drivers can fill up to 'cnt' bytes of data into
+/// the buffer 'data'. The buffer 'data' is aligned for any type and 'cnt' is
+/// a multiple of 4.
+int pka_dev_trng_read(pka_dev_shim_t *shim, uint32_t *data, uint32_t cnt);
+
+/// Return true if the TRNG engine is enabled, false if not.
+bool pka_dev_has_trng(pka_dev_shim_t *shim);
+
+/// Open the file descriptor associated with ring. It returns an integer value,
+/// which is used to refer to the file. If un-successful, it returns a negative
+/// error.
+int pka_dev_open_ring(pka_ring_info_t *ring_info);
+
+/// Close the file descriptor associated with ring. The function returns 0 if
+/// successful, negative value to indicate an error.
+int pka_dev_close_ring(pka_ring_info_t *ring_info);
+
+/// Map ring resources.
+int pka_dev_mmap_ring(pka_ring_info_t *ring_info);
+
+/// Unmap ring resources.
+int pka_dev_munmap_ring(pka_ring_info_t *ring_info);
+
+#endif /// __PKA_DEV_H__
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_drv.c b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_drv.c
new file mode 100644
index 000000000..b8b5a465e
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_drv.c
@@ -0,0 +1,1398 @@
+// SPDX-License-Identifier: GPL-2.0 or BSD-3-Clause
+
+#include <linux/acpi.h>
+#include <linux/cdev.h>
+#include <linux/device.h>
+#include <linux/hw_random.h>
+#include <linux/interrupt.h>
+#include <linux/iommu.h>
+#include <linux/kernel.h>
+#include <linux/module.h>
+#include <linux/mutex.h>
+#include <linux/of_device.h>
+#include <linux/of_irq.h>
+#include <linux/platform_device.h>
+#include <linux/slab.h>
+#include <linux/types.h>
+#include <linux/uaccess.h>
+#include <linux/vfio.h>
+
+#include "mlxbf_pka_dev.h"
+
+
+#define PKA_DRIVER_VERSION "v3.0"
+#define PKA_DRIVER_NAME "pka-mlxbf"
+
+#define PKA_DRIVER_DESCRIPTION "BlueField PKA driver"
+
+#define PKA_DEVICE_COMPAT "mlx,mlxbf-pka"
+#define PKA_RING_DEVICE_COMPAT "mlx,mlxbf-pka-ring"
+
+#define PKA_DEVICE_ACPIHID_BF1 "MLNXBF10"
+#define PKA_RING_DEVICE_ACPIHID_BF1 "MLNXBF11"
+
+#define PKA_DEVICE_ACPIHID_BF2 "MLNXBF20"
+#define PKA_RING_DEVICE_ACPIHID_BF2 "MLNXBF21"
+
+#define PKA_DEVICE_ACCESS_MODE 0666
+
+#define PKA_DEVICE_RES_CNT 7
+enum pka_mem_res_idx {
+ PKA_ACPI_EIP154_IDX = 0,
+ PKA_ACPI_WNDW_RAM_IDX,
+ PKA_ACPI_ALT_WNDW_RAM_0_IDX,
+ PKA_ACPI_ALT_WNDW_RAM_1_IDX,
+ PKA_ACPI_ALT_WNDW_RAM_2_IDX,
+ PKA_ACPI_ALT_WNDW_RAM_3_IDX,
+ PKA_ACPI_CSR_IDX
+};
+
+enum pka_plat_type {
+ PKA_PLAT_TYPE_BF1 = 0, /* Platform type Bluefield-1 */
+ PKA_PLAT_TYPE_BF2 /* Platform type Bluefield-2 */
+};
+
+static DEFINE_MUTEX(pka_drv_lock);
+
+static uint32_t pka_device_cnt;
+static uint32_t pka_ring_device_cnt;
+
+const char pka_compat[] = PKA_DEVICE_COMPAT;
+const char pka_ring_compat[] = PKA_RING_DEVICE_COMPAT;
+
+const char pka_acpihid_bf1[] = PKA_DEVICE_ACPIHID_BF1;
+const char pka_ring_acpihid_bf1[] = PKA_RING_DEVICE_ACPIHID_BF1;
+
+const char pka_acpihid_bf2[] = PKA_DEVICE_ACPIHID_BF2;
+const char pka_ring_acpihid_bf2[] = PKA_RING_DEVICE_ACPIHID_BF2;
+
+struct pka_drv_plat_info {
+ enum pka_plat_type type;
+ uint8_t fw_id;
+};
+
+static struct pka_drv_plat_info pka_drv_plat[] = {
+ [PKA_PLAT_TYPE_BF1] = {
+ .type = PKA_PLAT_TYPE_BF1,
+ .fw_id = PKA_FIRMWARE_IMAGE_0_ID
+ },
+ [PKA_PLAT_TYPE_BF2] = {
+ .type = PKA_PLAT_TYPE_BF2,
+ .fw_id = PKA_FIRMWARE_IMAGE_2_ID
+ }
+};
+
+static const struct acpi_device_id pka_drv_acpi_ids[] = {
+ { PKA_DEVICE_ACPIHID_BF1, (kernel_ulong_t)&pka_drv_plat[PKA_PLAT_TYPE_BF1] },
+ { PKA_RING_DEVICE_ACPIHID_BF1, 0 },
+ { PKA_DEVICE_ACPIHID_BF2, (kernel_ulong_t)&pka_drv_plat[PKA_PLAT_TYPE_BF2] },
+ { PKA_RING_DEVICE_ACPIHID_BF2, 0 },
+ {},
+};
+
+struct pka_info {
+ struct device *dev; /* the device this info belongs to */
+ const char *name; /* device name */
+ const char *version; /* device driver version */
+ const char *compat;
+ const char *acpihid;
+ uint8_t flag;
+ struct module *module;
+ void *priv; /* optional private data */
+};
+
+/* defines for pka_info->flags */
+#define PKA_DRIVER_FLAG_RING_DEVICE 1
+#define PKA_DRIVER_FLAG_DEVICE 2
+
+struct pka_platdata {
+ struct platform_device *pdev;
+ struct pka_info *info;
+ spinlock_t lock;
+ unsigned long irq_flags;
+};
+
+/* Bits in pka_platdata.irq_flags */
+enum {
+ PKA_IRQ_DISABLED = 0,
+};
+
+struct pka_ring_region {
+ u64 off;
+ u64 addr;
+ resource_size_t size;
+ u32 flags;
+ u32 type;
+ void __iomem *ioaddr;
+};
+
+/* defines for pka_ring_region->flags */
+#define PKA_RING_REGION_FLAG_READ (1 << 0) /* Region supports read */
+#define PKA_RING_REGION_FLAG_WRITE (1 << 1) /* Region supports write */
+#define PKA_RING_REGION_FLAG_MMAP (1 << 2) /* Region supports mmap */
+
+/* defines for pka_ring_region->type */
+#define PKA_RING_RES_TYPE_NONE 0
+#define PKA_RING_RES_TYPE_WORDS 1 /* info control/status words */
+#define PKA_RING_RES_TYPE_CNTRS 2 /* count registers */
+#define PKA_RING_RES_TYPE_MEM 4 /* window RAM region */
+
+#define PKA_DRIVER_RING_DEV_MAX PKA_MAX_NUM_RINGS
+
+struct pka_ring_device {
+ struct pka_info *info;
+ struct device *device;
+ struct iommu_group *group;
+ int32_t group_id;
+ uint32_t device_id;
+ uint32_t parent_device_id;
+ struct mutex mutex;
+ uint32_t flags;
+ struct module *parent_module;
+ pka_dev_ring_t *ring;
+ int minor;
+ uint32_t num_regions;
+ struct pka_ring_region *regions;
+};
+
+#define PKA_DRIVER_DEV_MAX PKA_MAX_NUM_IO_BLOCKS
+#define PKA_DRIVER_RING_NUM_REGIONS_MAX PKA_MAX_NUM_RING_RESOURCES
+
+/* defines for region index */
+#define PKA_RING_REGION_WORDS_IDX 0
+#define PKA_RING_REGION_CNTRS_IDX 1
+#define PKA_RING_REGION_MEM_IDX 2
+
+#define PKA_RING_REGION_OFFSET_SHIFT 40
+#define PKA_RING_REGION_OFFSET_MASK \
+ (((u64)(1) << PKA_RING_REGION_OFFSET_SHIFT) - 1)
+
+#define PKA_RING_OFFSET_TO_INDEX(off) \
+ (off >> PKA_RING_REGION_OFFSET_SHIFT)
+
+#define PKA_RING_REGION_INDEX_TO_OFFSET(index) \
+ ((u64)(index) << PKA_RING_REGION_OFFSET_SHIFT)
+
+struct pka_device {
+ struct pka_info *info;
+ struct device *device;
+ uint32_t device_id;
+ uint8_t fw_id; /* firmware identifier */
+ struct mutex mutex;
+ struct resource *resource[PKA_DEVICE_RES_CNT];
+ pka_dev_shim_t *shim;
+ long irq; /* interrupt number */
+ struct hwrng rng;
+};
+
+/* defines for pka_device->irq */
+#define PKA_IRQ_CUSTOM -1
+#define PKA_IRQ_NONE 0
+
+/* Hardware interrupt handler */
+static irqreturn_t pka_drv_irq_handler(int irq, void *device)
+{
+ struct pka_device *pka_dev = (struct pka_device *)device;
+ struct platform_device *pdev = to_platform_device(pka_dev->device);
+ struct pka_platdata *priv = platform_get_drvdata(pdev);
+
+ PKA_DEBUG(PKA_DRIVER,
+ "handle irq in device %u\n", pka_dev->device_id);
+
+ /* Just disable the interrupt in the interrupt controller */
+
+ spin_lock(&priv->lock);
+ if (!__test_and_set_bit(PKA_IRQ_DISABLED, &priv->irq_flags))
+ disable_irq_nosync(irq);
+ spin_unlock(&priv->lock);
+
+ return IRQ_HANDLED;
+}
+
+static int pka_drv_register_irq(struct pka_device *pka_dev)
+{
+ if (pka_dev->irq && (pka_dev->irq != PKA_IRQ_CUSTOM)) {
+ /*
+ * Allow sharing the irq among several devices (child devices
+ * so far)
+ */
+ return request_irq(pka_dev->irq,
+ (irq_handler_t) pka_drv_irq_handler,
+ IRQF_SHARED, pka_dev->info->name,
+ pka_dev);
+ }
+
+ return -ENXIO;
+}
+
+static int pka_drv_ring_regions_init(struct pka_ring_device *ring_dev)
+{
+ struct pka_ring_region *region;
+ pka_dev_ring_t *ring;
+ pka_dev_res_t *res;
+ uint32_t num_regions;
+
+ ring = ring_dev->ring;
+ if (!ring || !ring->shim)
+ return -ENXIO;
+
+ num_regions = ring->resources_num;
+ ring_dev->num_regions = num_regions;
+ ring_dev->regions = kcalloc(num_regions,
+ sizeof(struct pka_ring_region),
+ GFP_KERNEL);
+ if (!ring_dev->regions)
+ return -ENOMEM;
+
+ /* Information words region */
+ res = &ring->resources.info_words;
+ region = &ring_dev->regions[PKA_RING_REGION_WORDS_IDX];
+ /* map offset to the physical address */
+ region->off =
+ PKA_RING_REGION_INDEX_TO_OFFSET(PKA_RING_REGION_WORDS_IDX);
+ region->addr = res->base;
+ region->size = res->size;
+ region->type = PKA_RING_RES_TYPE_WORDS;
+ region->flags |= (PKA_RING_REGION_FLAG_MMAP |
+ PKA_RING_REGION_FLAG_READ |
+ PKA_RING_REGION_FLAG_WRITE);
+
+ /* Count regiters region */
+ res = &ring->resources.counters;
+ region = &ring_dev->regions[PKA_RING_REGION_CNTRS_IDX];
+ /* map offset to the physical address */
+ region->off =
+ PKA_RING_REGION_INDEX_TO_OFFSET(PKA_RING_REGION_CNTRS_IDX);
+ region->addr = res->base;
+ region->size = res->size;
+ region->type = PKA_RING_RES_TYPE_CNTRS;
+ region->flags |= (PKA_RING_REGION_FLAG_MMAP |
+ PKA_RING_REGION_FLAG_READ |
+ PKA_RING_REGION_FLAG_WRITE);
+
+ /* Window ram region */
+ res = &ring->resources.window_ram;
+ region = &ring_dev->regions[PKA_RING_REGION_MEM_IDX];
+ /* map offset to the physical address */
+ region->off =
+ PKA_RING_REGION_INDEX_TO_OFFSET(PKA_RING_REGION_MEM_IDX);
+ region->addr = res->base;
+ region->size = res->size;
+ region->type = PKA_RING_RES_TYPE_MEM;
+ region->flags |= (PKA_RING_REGION_FLAG_MMAP |
+ PKA_RING_REGION_FLAG_READ |
+ PKA_RING_REGION_FLAG_WRITE);
+
+ return 0;
+}
+
+static void pka_drv_ring_regions_cleanup(struct pka_ring_device *ring_dev)
+{
+ /* clear vfio device regions */
+ ring_dev->num_regions = 0;
+ kfree(ring_dev->regions);
+}
+
+static int pka_drv_ring_open(void *device_data)
+{
+ struct pka_ring_device *ring_dev = device_data;
+ struct pka_info *info = ring_dev->info;
+ pka_ring_info_t ring_info;
+
+ int error;
+
+ PKA_DEBUG(PKA_DRIVER,
+ "open ring device %u (device_data:%p)\n",
+ ring_dev->device_id, ring_dev);
+
+ if (!try_module_get(info->module))
+ return -ENODEV;
+
+ ring_info.ring_id = ring_dev->device_id;
+ error = pka_dev_open_ring(&ring_info);
+ if (error) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to open ring %u\n", ring_dev->device_id);
+ module_put(info->module);
+ return error;
+ }
+
+ /* Initialize regions */
+ error = pka_drv_ring_regions_init(ring_dev);
+ if (error) {
+ PKA_DEBUG(PKA_DRIVER, "failed to initialize regions\n");
+ pka_dev_close_ring(&ring_info);
+ module_put(info->module);
+ return error;
+ }
+
+ return 0;
+}
+
+static void pka_drv_ring_release(void *device_data)
+{
+ struct pka_ring_device *ring_dev = device_data;
+ struct pka_info *info = ring_dev->info;
+ pka_ring_info_t ring_info;
+
+ int error;
+
+ PKA_DEBUG(PKA_DRIVER,
+ "release ring device %u (device_data:%p)\n",
+ ring_dev->device_id, ring_dev);
+
+ pka_drv_ring_regions_cleanup(ring_dev);
+
+ ring_info.ring_id = ring_dev->device_id;
+ error = pka_dev_close_ring(&ring_info);
+ if (error)
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to close ring %u\n",
+ ring_dev->device_id);
+
+ module_put(info->module);
+}
+
+static int pka_drv_ring_mmap_region(struct pka_ring_region region,
+ struct vm_area_struct *vma)
+{
+ u64 req_len, pgoff, req_start;
+
+ req_len = vma->vm_end - vma->vm_start;
+ pgoff = vma->vm_pgoff &
+ ((1U << (PKA_RING_REGION_OFFSET_SHIFT - PAGE_SHIFT)) - 1);
+ req_start = pgoff << PAGE_SHIFT;
+
+ region.size = roundup(region.size, PAGE_SIZE);
+
+ if (req_start + req_len > region.size)
+ return -EINVAL;
+
+ vma->vm_page_prot = pgprot_noncached(vma->vm_page_prot);
+ vma->vm_pgoff = (region.addr >> PAGE_SHIFT) + pgoff;
+
+ return remap_pfn_range(vma, vma->vm_start, vma->vm_pgoff,
+ req_len, vma->vm_page_prot);
+}
+
+static int pka_drv_ring_mmap(void *device_data, struct vm_area_struct *vma)
+{
+ struct pka_ring_device *ring_dev = device_data;
+ struct pka_ring_region *region;
+ unsigned int index;
+
+ PKA_DEBUG(PKA_DRIVER, "mmap device %u\n", ring_dev->device_id);
+
+ index = vma->vm_pgoff >> (PKA_RING_REGION_OFFSET_SHIFT - PAGE_SHIFT);
+
+ if (vma->vm_end < vma->vm_start)
+ return -EINVAL;
+ if (!(vma->vm_flags & VM_SHARED))
+ return -EINVAL;
+ if (index >= ring_dev->num_regions)
+ return -EINVAL;
+ if (vma->vm_start & ~PAGE_MASK)
+ return -EINVAL;
+ if (vma->vm_end & ~PAGE_MASK)
+ return -EINVAL;
+
+ region = &ring_dev->regions[index];
+
+ if (!(region->flags & PKA_RING_REGION_FLAG_MMAP))
+ return -EINVAL;
+
+ if (!(region->flags & PKA_RING_REGION_FLAG_READ)
+ && (vma->vm_flags & VM_READ))
+ return -EINVAL;
+
+ if (!(region->flags & PKA_RING_REGION_FLAG_WRITE)
+ && (vma->vm_flags & VM_WRITE))
+ return -EINVAL;
+
+ vma->vm_private_data = ring_dev;
+
+ if (region->type & PKA_RING_RES_TYPE_CNTRS ||
+ region->type & PKA_RING_RES_TYPE_MEM)
+ return pka_drv_ring_mmap_region(ring_dev->regions[index], vma);
+
+ if (region->type & PKA_RING_RES_TYPE_WORDS)
+ /*
+ * Currently user space is not allowed to access this
+ * region.
+ */
+ return -EINVAL;
+
+ return -EINVAL;
+}
+
+static long pka_drv_ring_ioctl(void *device_data,
+ unsigned int cmd, unsigned long arg)
+{
+ struct pka_ring_device *ring_dev = device_data;
+
+ int error = -ENOTTY;
+
+ if (cmd == PKA_RING_GET_REGION_INFO) {
+ pka_dev_region_info_t info;
+
+ info.mem_index = PKA_RING_REGION_MEM_IDX;
+ info.mem_offset = ring_dev->regions[info.mem_index].off;
+ info.mem_size = ring_dev->regions[info.mem_index].size;
+
+ info.reg_index = PKA_RING_REGION_CNTRS_IDX;
+ info.reg_offset = ring_dev->regions[info.reg_index].off;
+ info.reg_size = ring_dev->regions[info.reg_index].size;
+
+ return copy_to_user((void __user *)arg, &info, sizeof(info)) ?
+ -EFAULT : 0;
+
+ } else if (cmd == PKA_GET_RING_INFO) {
+ pka_dev_hw_ring_info_t *this_ring_info;
+ pka_dev_hw_ring_info_t hw_ring_info;
+
+ this_ring_info = ring_dev->ring->ring_info;
+
+ hw_ring_info.cmmd_base = this_ring_info->cmmd_base;
+ hw_ring_info.rslt_base = this_ring_info->rslt_base;
+ hw_ring_info.size = this_ring_info->size;
+ hw_ring_info.host_desc_size = this_ring_info->host_desc_size;
+ hw_ring_info.in_order = this_ring_info->in_order;
+ hw_ring_info.cmmd_rd_ptr = this_ring_info->cmmd_rd_ptr;
+ hw_ring_info.rslt_wr_ptr = this_ring_info->rslt_wr_ptr;
+ hw_ring_info.cmmd_rd_stats = this_ring_info->cmmd_rd_ptr;
+ hw_ring_info.rslt_wr_stats = this_ring_info->rslt_wr_stats;
+
+ return copy_to_user((void __user *)arg, &hw_ring_info,
+ sizeof(hw_ring_info)) ? -EFAULT : 0;
+ } else if (cmd == PKA_CLEAR_RING_COUNTERS) {
+ return pka_dev_clear_ring_counters(ring_dev->ring);
+ } else if (cmd == PKA_GET_RANDOM_BYTES) {
+ pka_dev_trng_info_t *trng_data;
+ pka_dev_shim_t *shim;
+ bool trng_present;
+ uint32_t byte_cnt;
+ uint32_t *data;
+ int ret;
+
+ ret = -ENOENT;
+ shim = ring_dev->ring->shim;
+ trng_data = (pka_dev_trng_info_t *)arg;
+ /*
+ * We need byte count which is multiple of 4 as
+ * required by pka_dev_trng_read() interface.
+ */
+ byte_cnt = round_up(trng_data->count, 4);
+
+ data = kzalloc(byte_cnt, GFP_KERNEL);
+ if (data == NULL) {
+ PKA_DEBUG(PKA_DRIVER, "failed to allocate memory.\n");
+ return -ENOMEM;
+ }
+
+ trng_present = pka_dev_has_trng(shim);
+ if (!trng_present) {
+ kfree(data);
+ return ret;
+ }
+
+ ret = pka_dev_trng_read(shim, data, byte_cnt);
+ if (ret) {
+ PKA_DEBUG(PKA_DRIVER, "TRNG failed %d\n", ret);
+ kfree(data);
+ return ret;
+ }
+
+ ret = copy_to_user((void __user *)(trng_data->data), data, trng_data->count);
+ kfree(data);
+ return ret ? -EFAULT : 0;
+ }
+
+ return error;
+}
+
+#ifdef CONFIG_PKA_VFIO_IOMMU
+static const struct vfio_device_ops pka_ring_vfio_ops = {
+ .name = PKA_DRIVER_NAME,
+ .open = pka_drv_ring_open,
+ .release = pka_drv_ring_release,
+ .ioctl = pka_drv_ring_ioctl,
+ .mmap = pka_drv_ring_mmap,
+};
+
+static int pka_drv_add_ring_device(struct pka_ring_device *ring_dev)
+{
+ struct device *dev = ring_dev->device;
+ int ret;
+
+ ring_dev->parent_module = THIS_MODULE;
+ ring_dev->flags = VFIO_DEVICE_FLAGS_PLATFORM;
+
+ ring_dev->group = vfio_iommu_group_get(dev);
+ if (!ring_dev->group) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to get IOMMU group for device %d\n",
+ ring_dev->device_id);
+ return -EINVAL;
+ }
+
+ /*
+ * Note that this call aims to add the given child device to a vfio
+ * group. This function creates a new driver data for the device
+ * different from the structure passed as a 3rd argument - i.e.
+ * pka_ring_dev. The struct newly created corresponds to 'vfio_device'
+ * structure which includes a field called 'device_data' that holds
+ * the initialized 'pka_ring_dev'. So to retrieve our private data,
+ * we must call 'dev_get_drvdata()' which returns the 'vfio_device'
+ * struct and access its 'device_data' field. Here one can use
+ * 'pka_platdata' structure instead to be consistent with the parent
+ * devices, and have a common driver data structure which will be used
+ * to manage devices - 'pka_drv_remove()' for instance. Since the VFIO
+ * framework alters the driver data and introduce an indirection, it
+ * is no more relevant to have a common driver data structure. Hence,
+ * we prefer to set the struct 'pka_vfio_dev' instead to avoid
+ * indirection when we have to retrieve this structure during the
+ * open(), mmap(), and ioctl() calls. Since, this structure is used
+ * as driver data here, it will be immediately reachable for these
+ * functions (see first argument passed (void *device_data) passed
+ * to those functions).
+ */
+ ret = vfio_add_group_dev(dev, &pka_ring_vfio_ops, ring_dev);
+ if (ret) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to add group device %d\n",
+ ring_dev->device_id);
+ vfio_iommu_group_put(ring_dev->group, dev);
+ return ret;
+ }
+
+ ring_dev->group_id = iommu_group_id(ring_dev->group);
+
+ PKA_DEBUG(PKA_DRIVER,
+ "ring device %d bus:%p iommu_ops:%p group:%p\n",
+ ring_dev->device_id,
+ dev->bus,
+ dev->bus->iommu_ops,
+ ring_dev->group);
+
+ return 0;
+}
+
+static struct pka_ring_device *pka_drv_del_ring_device(struct device *dev)
+{
+ struct pka_ring_device *ring_dev;
+
+ ring_dev = vfio_del_group_dev(dev);
+ if (ring_dev)
+ vfio_iommu_group_put(dev->iommu_group, dev);
+
+ return ring_dev;
+}
+
+static int pka_drv_init_class(void)
+{
+ return 0;
+}
+
+static void pka_drv_destroy_class(void)
+{
+}
+#else
+static struct pka {
+ struct class *class;
+ struct idr ring_idr;
+ struct mutex ring_lock;
+ struct cdev ring_cdev;
+ dev_t ring_devt;
+} pka;
+
+static int pka_drv_open(struct inode *inode, struct file *filep)
+{
+ struct pka_ring_device *ring_dev;
+ int ret;
+
+ ring_dev = idr_find(&pka.ring_idr, iminor(inode));
+ if (!ring_dev) {
+ PKA_ERROR(PKA_DRIVER,
+ "failed to find idr for device %d\n",
+ ring_dev->device_id);
+ return -ENODEV;
+ }
+
+ ret = pka_drv_ring_open(ring_dev);
+ if (ret)
+ return ret;
+
+ filep->private_data = ring_dev;
+ return 0;
+}
+
+static int pka_drv_release(struct inode *inode, struct file *filep)
+{
+ struct pka_ring_device *ring_dev = filep->private_data;
+
+ filep->private_data = NULL;
+ pka_drv_ring_release(ring_dev);
+
+ return 0;
+}
+
+static int pka_drv_mmap(struct file *filep, struct vm_area_struct *vma)
+{
+ return pka_drv_ring_mmap(filep->private_data, vma);
+}
+
+static long pka_drv_unlocked_ioctl(struct file *filep,
+ unsigned int cmd, unsigned long arg)
+{
+ return pka_drv_ring_ioctl(filep->private_data, cmd, arg);
+}
+
+static const struct file_operations pka_ring_fops = {
+ .owner = THIS_MODULE,
+ .open = pka_drv_open,
+ .release = pka_drv_release,
+ .unlocked_ioctl = pka_drv_unlocked_ioctl,
+ .mmap = pka_drv_mmap,
+};
+
+static int pka_drv_add_ring_device(struct pka_ring_device *ring_dev)
+{
+ struct device *dev = ring_dev->device;
+
+ ring_dev->minor = idr_alloc(&pka.ring_idr,
+ ring_dev, 0, MINORMASK + 1, GFP_KERNEL);
+ if (ring_dev->minor < 0) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to alloc minor to device %d\n",
+ ring_dev->device_id);
+ return ring_dev->minor;
+ }
+
+ dev = device_create(pka.class, NULL,
+ MKDEV(MAJOR(pka.ring_devt), ring_dev->minor),
+ ring_dev, "%d", ring_dev->device_id);
+ if (IS_ERR(dev)) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to create device %d\n",
+ ring_dev->device_id);
+ idr_remove(&pka.ring_idr, ring_dev->minor);
+ return PTR_ERR(dev);
+ }
+
+ PKA_DEBUG(PKA_DRIVER,
+ "ring device %d minor:%d\n",
+ ring_dev->device_id, ring_dev->minor);
+
+ return 0;
+}
+
+static struct pka_ring_device *pka_drv_del_ring_device(struct device *dev)
+{
+ struct platform_device *pdev =
+ container_of(dev, struct platform_device, dev);
+ struct pka_platdata *priv = platform_get_drvdata(pdev);
+ struct pka_info *info = priv->info;
+ struct pka_ring_device *ring_dev = info->priv;
+
+ if (ring_dev) {
+ device_destroy(pka.class, MKDEV(MAJOR(pka.ring_devt),
+ ring_dev->minor));
+ idr_remove(&pka.ring_idr, ring_dev->minor);
+ }
+
+ return ring_dev;
+}
+
+static char *pka_drv_devnode(struct device *dev, umode_t *mode)
+{
+ if (mode != NULL)
+ *mode = PKA_DEVICE_ACCESS_MODE;
+ return kasprintf(GFP_KERNEL, "pka/%s", dev_name(dev));
+}
+
+static int pka_drv_init_class(void)
+{
+ int ret;
+
+ idr_init(&pka.ring_idr);
+ /* /sys/class/pka/$RING */
+ pka.class = class_create(THIS_MODULE, "pka");
+ if (IS_ERR(pka.class))
+ return PTR_ERR(pka.class);
+
+ /* /dev/pka/$RING */
+ pka.class->devnode = pka_drv_devnode;
+
+ ret = alloc_chrdev_region(&pka.ring_devt, 0, MINORMASK, "pka");
+ if (ret)
+ goto err_alloc_chrdev;
+
+ cdev_init(&pka.ring_cdev, &pka_ring_fops);
+ ret = cdev_add(&pka.ring_cdev, pka.ring_devt, MINORMASK);
+ if (ret)
+ goto err_cdev_add;
+
+ return 0;
+
+err_cdev_add:
+ unregister_chrdev_region(pka.ring_devt, MINORMASK);
+err_alloc_chrdev:
+ class_destroy(pka.class);
+ pka.class = NULL;
+ return ret;
+}
+
+static void pka_drv_destroy_class(void)
+{
+ idr_destroy(&pka.ring_idr);
+ cdev_del(&pka.ring_cdev);
+ unregister_chrdev_region(pka.ring_devt, MINORMASK);
+ class_destroy(pka.class);
+ pka.class = NULL;
+}
+#endif
+
+static void pka_drv_get_mem_res(struct pka_device *pka_dev,
+ struct pka_dev_mem_res *mem_res,
+ uint64_t wndw_ram_off_mask)
+{
+ enum pka_mem_res_idx acpi_mem_idx;
+
+ acpi_mem_idx = PKA_ACPI_EIP154_IDX;
+ mem_res->wndw_ram_off_mask = wndw_ram_off_mask;
+
+ /* PKA EIP154 MMIO base address*/
+ mem_res->eip154_base = pka_dev->resource[acpi_mem_idx]->start;
+ mem_res->eip154_size = pka_dev->resource[acpi_mem_idx]->end -
+ mem_res->eip154_base + 1;
+ acpi_mem_idx++;
+
+ /* PKA window ram base address*/
+ mem_res->wndw_ram_base = pka_dev->resource[acpi_mem_idx]->start;
+ mem_res->wndw_ram_size = pka_dev->resource[acpi_mem_idx]->end -
+ mem_res->wndw_ram_base + 1;
+ acpi_mem_idx++;
+
+ /* PKA alternate window ram base address
+ * Note: Here the size of all the alt window ram is same, depicted by
+ * 'alt_wndw_ram_size' variable. All alt window ram resources are read
+ * here even though not all of them are used currently.
+ */
+ mem_res->alt_wndw_ram_0_base = pka_dev->resource[acpi_mem_idx]->start;
+ mem_res->alt_wndw_ram_size = pka_dev->resource[acpi_mem_idx]->end -
+ mem_res->alt_wndw_ram_0_base + 1;
+
+ if (mem_res->alt_wndw_ram_size != PKA_WINDOW_RAM_REGION_SIZE)
+ PKA_ERROR(PKA_DRIVER,
+ "Alternate Window RAM size read from ACPI is incorrect.\n");
+
+ acpi_mem_idx++;
+
+ mem_res->alt_wndw_ram_1_base = pka_dev->resource[acpi_mem_idx]->start;
+ acpi_mem_idx++;
+
+ mem_res->alt_wndw_ram_2_base = pka_dev->resource[acpi_mem_idx]->start;
+ acpi_mem_idx++;
+
+ mem_res->alt_wndw_ram_3_base = pka_dev->resource[acpi_mem_idx]->start;
+ acpi_mem_idx++;
+
+ /* PKA CSR base address*/
+ mem_res->csr_base = pka_dev->resource[acpi_mem_idx]->start;
+ mem_res->csr_size = pka_dev->resource[acpi_mem_idx]->end -
+ mem_res->csr_base + 1;
+}
+
+/*
+ * Note that this function must be serialized because it calls
+ * 'pka_dev_register_shim' which manipulates common counters for
+ * pka devices.
+ */
+static int pka_drv_register_device(struct pka_device *pka_dev,
+ uint64_t wndw_ram_off_mask)
+{
+ uint32_t pka_shim_id;
+ uint8_t pka_shim_fw_id;
+ struct pka_dev_mem_res mem_res;
+
+ /* Register Shim */
+ pka_shim_id = pka_dev->device_id;
+ pka_shim_fw_id = pka_dev->fw_id;
+
+ pka_drv_get_mem_res(pka_dev, &mem_res, wndw_ram_off_mask);
+
+ pka_dev->shim = pka_dev_register_shim(pka_shim_id, pka_shim_fw_id,
+ &mem_res);
+ if (!pka_dev->shim) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to register shim id=%u\n", pka_shim_id);
+ return -EFAULT;
+ }
+
+ return 0;
+}
+
+static int pka_drv_unregister_device(struct pka_device *pka_dev)
+{
+ if (!pka_dev)
+ return -EINVAL;
+
+ if (pka_dev->shim) {
+ PKA_DEBUG(PKA_DRIVER,
+ "unregister device shim %u\n",
+ pka_dev->shim->shim_id);
+ return pka_dev_unregister_shim(pka_dev->shim);
+ }
+
+ return 0;
+}
+
+/*
+ * Note that this function must be serialized because it calls
+ * 'pka_dev_register_ring' which manipulates common counters for
+ * vfio devices.
+ */
+static int pka_drv_register_ring_device(struct pka_ring_device *ring_dev)
+{
+ uint32_t ring_id;
+ uint32_t shim_id;
+
+ ring_id = ring_dev->device_id;
+ shim_id = ring_dev->parent_device_id;
+
+ ring_dev->ring = pka_dev_register_ring(ring_id, shim_id);
+ if (!ring_dev->ring) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to register ring device %u\n", ring_id);
+ return -EFAULT;
+ }
+
+ return 0;
+}
+
+static int pka_drv_unregister_ring_device(struct pka_ring_device *ring_dev)
+{
+ uint32_t ring_id;
+
+ if (!ring_dev)
+ return -EINVAL;
+
+ ring_id = ring_dev->ring->ring_id;
+
+ if (ring_dev->ring) {
+ PKA_DEBUG(PKA_DRIVER, "unregister ring device %u\n", ring_id);
+ return pka_dev_unregister_ring(ring_dev->ring);
+ }
+
+ return 0;
+}
+
+static const struct of_device_id pka_ring_match[] = {
+ { .compatible = PKA_RING_DEVICE_COMPAT },
+ {},
+};
+
+static int pka_drv_rng_read(struct hwrng *rng, void *data, size_t max,
+ bool wait)
+{
+ int ret;
+
+ struct pka_device *pka_dev = container_of(rng, struct pka_device, rng);
+ uint32_t *buffer = data;
+
+ ret = pka_dev_trng_read(pka_dev->shim, buffer, max);
+ if (ret) {
+ PKA_DEBUG(PKA_DRIVER,
+ "%s: failed to read random bytes ret=%d",
+ rng->name, ret);
+ return 0;
+ }
+
+ return max;
+}
+
+static int pka_drv_probe_device(struct pka_info *info)
+{
+ struct pka_device *pka_dev;
+ struct device *dev = info->dev;
+ struct device_node *of_node = dev->of_node;
+ struct platform_device *pdev = to_platform_device(dev);
+ struct hwrng *trng;
+ const struct acpi_device_id *aid;
+ struct pka_drv_plat_info *plat_info;
+ uint64_t wndw_ram_off_mask;
+ int ret;
+ enum pka_mem_res_idx acpi_mem_idx;
+
+ if (!info)
+ return -EINVAL;
+
+ pka_dev = kzalloc(sizeof(*pka_dev), GFP_KERNEL);
+ if (!pka_dev)
+ return -ENOMEM;
+
+ mutex_lock(&pka_drv_lock);
+ pka_device_cnt += 1;
+ if (pka_device_cnt > PKA_DRIVER_DEV_MAX) {
+ PKA_DEBUG(PKA_DRIVER,
+ "cannot support %u devices\n", pka_device_cnt);
+ kfree(pka_dev);
+ mutex_unlock(&pka_drv_lock);
+ return -EPERM;
+ }
+ pka_dev->device_id = pka_device_cnt - 1;
+ mutex_unlock(&pka_drv_lock);
+
+ pka_dev->info = info;
+ pka_dev->device = dev;
+ info->flag = PKA_DRIVER_FLAG_DEVICE;
+ mutex_init(&pka_dev->mutex);
+
+ for (acpi_mem_idx = PKA_ACPI_EIP154_IDX;
+ acpi_mem_idx < PKA_DEVICE_RES_CNT; acpi_mem_idx++) {
+ pka_dev->resource[acpi_mem_idx] =
+ platform_get_resource(pdev, IORESOURCE_MEM, acpi_mem_idx);
+ }
+
+ /* Window ram offset mask is platform dependent */
+ aid = acpi_match_device(pka_drv_acpi_ids, dev);
+ if (!aid)
+ return -ENODEV;
+
+ plat_info = (struct pka_drv_plat_info *)aid->driver_data;
+ if (plat_info->type <= PKA_PLAT_TYPE_BF2) {
+ wndw_ram_off_mask = PKA_WINDOW_RAM_OFFSET_MASK1;
+ } else {
+ PKA_ERROR(PKA_DRIVER, "Invalid platform type: %d\n",
+ (int)plat_info->type);
+ return -EINVAL;
+ }
+
+ /* Set interrupts */
+ ret = platform_get_irq(pdev, 0);
+ pka_dev->irq = ret;
+ if (ret == -ENXIO && of_node) {
+ pka_dev->irq = PKA_IRQ_NONE;
+ } else if (ret < 0) {
+ PKA_ERROR(PKA_DRIVER,
+ "failed to get device %u IRQ\n", pka_dev->device_id);
+ return ret;
+ }
+
+ /* Register IRQ */
+ ret = pka_drv_register_irq(pka_dev);
+ if (ret) {
+ PKA_ERROR(PKA_DRIVER,
+ "failed to register device %u IRQ\n",
+ pka_dev->device_id);
+ return ret;
+ }
+
+ /* Firmware version */
+ pka_dev->fw_id = plat_info->fw_id;
+
+ mutex_lock(&pka_drv_lock);
+ ret = pka_drv_register_device(pka_dev, wndw_ram_off_mask);
+ if (ret) {
+ PKA_DEBUG(PKA_DRIVER, "failed to register shim id=%u\n",
+ pka_dev->device_id);
+ mutex_unlock(&pka_drv_lock);
+ return ret;
+ }
+ mutex_unlock(&pka_drv_lock);
+
+ /* Setup the TRNG, if needed */
+ if (pka_dev_has_trng(pka_dev->shim)) {
+ trng = &pka_dev->rng;
+ trng->name = pdev->name;
+ trng->read = pka_drv_rng_read;
+
+ ret = hwrng_register(&pka_dev->rng);
+ if (ret) {
+ PKA_ERROR(PKA_DRIVER,
+ "failed to register trng\n");
+ return ret;
+ }
+ }
+
+ info->priv = pka_dev;
+
+#ifdef BUG_SW_1127083_FIXED
+ /*
+ * Create platform devices (pka-ring) from current node.
+ * This code is reserverd for DT.
+ */
+ if (of_node) {
+ ret = of_platform_populate(of_node, pka_ring_match,
+ NULL, dev);
+ if (ret) {
+ PKA_ERROR(PKA_DRIVER,
+ "failed to create platform devices\n");
+ return ret;
+ }
+ }
+#endif
+
+ return 0;
+}
+
+static int pka_drv_remove_device(struct platform_device *pdev)
+{
+ struct pka_platdata *priv = platform_get_drvdata(pdev);
+ struct pka_info *info = priv->info;
+ struct pka_device *pka_dev = (struct pka_device *)info->priv;
+
+ if (!pka_dev) {
+ PKA_ERROR(PKA_DRIVER, "failed to unregister device\n");
+ return -EINVAL;
+ }
+
+ if (pka_dev_has_trng(pka_dev->shim))
+ hwrng_unregister(&pka_dev->rng);
+
+ if (pka_drv_unregister_device(pka_dev))
+ PKA_ERROR(PKA_DRIVER, "failed to unregister device\n");
+
+ return 0;
+}
+
+static int pka_drv_probe_ring_device(struct pka_info *info)
+{
+ struct pka_ring_device *ring_dev;
+ struct device *dev = info->dev;
+
+ int ret;
+
+ if (!info)
+ return -EINVAL;
+
+ ring_dev = kzalloc(sizeof(*ring_dev), GFP_KERNEL);
+ if (!ring_dev)
+ return -ENOMEM;
+
+ mutex_lock(&pka_drv_lock);
+ pka_ring_device_cnt += 1;
+ if (pka_ring_device_cnt > PKA_DRIVER_RING_DEV_MAX) {
+ PKA_DEBUG(PKA_DRIVER, "cannot support %u ring devices\n",
+ pka_ring_device_cnt);
+ kfree(ring_dev);
+ mutex_unlock(&pka_drv_lock);
+ return -EPERM;
+ }
+ ring_dev->device_id = pka_ring_device_cnt - 1;
+ ring_dev->parent_device_id = pka_device_cnt - 1;
+ mutex_unlock(&pka_drv_lock);
+
+ ring_dev->info = info;
+ ring_dev->device = dev;
+ info->flag = PKA_DRIVER_FLAG_RING_DEVICE;
+ mutex_init(&ring_dev->mutex);
+
+ ret = pka_drv_add_ring_device(ring_dev);
+ if (ret) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to add ring device %u\n",
+ ring_dev->device_id);
+ kfree(ring_dev);
+ return ret;
+ }
+
+ mutex_lock(&pka_drv_lock);
+ /* Register ring device */
+ ret = pka_drv_register_ring_device(ring_dev);
+ if (ret) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to register ring device %u\n",
+ ring_dev->device_id);
+ mutex_unlock(&pka_drv_lock);
+ goto err_register_ring;
+ }
+ mutex_unlock(&pka_drv_lock);
+
+ info->priv = ring_dev;
+
+ return 0;
+
+ err_register_ring:
+ pka_drv_del_ring_device(dev);
+ kfree(ring_dev);
+ return ret;
+}
+
+static int pka_drv_remove_ring_device(struct platform_device *pdev)
+{
+ struct pka_ring_device *ring_dev;
+ struct device *dev = &pdev->dev;
+ int ret;
+
+ ring_dev = pka_drv_del_ring_device(dev);
+ if (ring_dev) {
+ ret = pka_drv_unregister_ring_device(ring_dev);
+ if (ret) {
+ PKA_ERROR(PKA_DRIVER,
+ "failed to unregister vfio device\n");
+ return ret;
+ }
+ kfree(ring_dev);
+ }
+
+ return 0;
+}
+
+static int pka_drv_of_probe(struct platform_device *pdev,
+ struct pka_info *info)
+{
+#ifdef BUG_SW_1127083_FIXED
+ struct device *dev = &pdev->dev;
+
+ int error;
+
+ error = device_property_read_string(dev, "compatible", &info->compat);
+ if (error) {
+ PKA_DEBUG(PKA_DRIVER, "cannot retrieve compat for %s\n",
+ pdev->name);
+ return -EINVAL;
+ }
+
+ if (!strcmp(info->compat, pka_ring_compat)) {
+ PKA_PRINT(PKA_DRIVER, "probe ring device %s\n",
+ pdev->name);
+ error = pka_drv_probe_ring_device(info);
+ if (error) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to register ring device compat=%s\n",
+ info->compat);
+ return error;
+ }
+
+ } else if (!strcmp(info->compat, pka_compat)) {
+ PKA_PRINT(PKA_DRIVER, "probe device %s\n", pdev->name);
+ error = pka_drv_probe_device(info);
+ if (error) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to register device compat=%s\n",
+ info->compat);
+ return error;
+ }
+ }
+
+ return 0;
+#endif
+ return -EPERM;
+}
+
+static int pka_drv_acpi_probe(struct platform_device *pdev,
+ struct pka_info *info)
+{
+ struct acpi_device *adev;
+ struct device *dev = &pdev->dev;
+
+ int error;
+
+ if (acpi_disabled)
+ return -ENOENT;
+
+ adev = ACPI_COMPANION(dev);
+ if (!adev) {
+ PKA_DEBUG(PKA_DRIVER,
+ "ACPI companion device not found for %s\n",
+ pdev->name);
+ return -ENODEV;
+ }
+
+ info->acpihid = acpi_device_hid(adev);
+ if (WARN_ON(!info->acpihid))
+ return -EINVAL;
+
+ if (!strcmp(info->acpihid, pka_ring_acpihid_bf1)
+ || !strcmp(info->acpihid, pka_ring_acpihid_bf2)) {
+ error = pka_drv_probe_ring_device(info);
+ if (error) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to register ring device %s\n",
+ pdev->name);
+ return error;
+ }
+ PKA_DEBUG(PKA_DRIVER, "ring device %s probed\n",
+ pdev->name);
+
+ } else if (!strcmp(info->acpihid, pka_acpihid_bf1)
+ || !strcmp(info->acpihid, pka_acpihid_bf2)) {
+ error = pka_drv_probe_device(info);
+ if (error) {
+ PKA_DEBUG(PKA_DRIVER,
+ "failed to register device %s\n",
+ pdev->name);
+ return error;
+ }
+ PKA_PRINT(PKA_DRIVER, "device %s probed\n", pdev->name);
+ }
+
+ return 0;
+}
+
+static int pka_drv_probe(struct platform_device *pdev)
+{
+ struct pka_platdata *priv;
+ struct pka_info *info;
+ struct device *dev = &pdev->dev;
+
+ int ret;
+
+ priv = kzalloc(sizeof(*priv), GFP_KERNEL);
+ if (!priv)
+ return -ENOMEM;
+
+ spin_lock_init(&priv->lock);
+ priv->pdev = pdev;
+ /* interrupt is disabled to begin with */
+ priv->irq_flags = 0;
+
+ info = kzalloc(sizeof(*info), GFP_KERNEL);
+ if (!info)
+ return -ENOMEM;
+
+ info->name = pdev->name;
+ info->version = PKA_DRIVER_VERSION;
+ info->module = THIS_MODULE;
+ info->dev = dev;
+
+ priv->info = info;
+
+ platform_set_drvdata(pdev, priv);
+
+ /*
+ * There can be two kernel build combinations. One build where
+ * ACPI is not selected and another one with the ACPI.
+ *
+ * In the first case, 'pka_drv_acpi_probe' will return since
+ * acpi_disabled is 1. DT user will not see any kind of messages
+ * from ACPI.
+ *
+ * In the second case, both DT and ACPI is compiled in but the
+ * system is booting with any of these combinations.
+ *
+ * If the firmware is DT type, then acpi_disabled is 1. The ACPI
+ * probe routine terminates immediately without any messages.
+ *
+ * If the firmware is ACPI type, then acpi_disabled is 0. All other
+ * checks are valid checks. We cannot claim that this system is DT.
+ */
+ ret = pka_drv_acpi_probe(pdev, info);
+ if (ret)
+ ret = pka_drv_of_probe(pdev, info);
+
+ if (ret) {
+ PKA_DEBUG(PKA_DRIVER, "unknown device\n");
+ return ret;
+ }
+
+ return 0;
+}
+
+static int pka_drv_remove(struct platform_device *pdev)
+{
+ struct device *dev = &pdev->dev;
+
+ /*
+ * Little hack here:
+ * The issue here is that the driver data structure which holds our
+ * initialized private data cannot be used when the 'pdev' arguments
+ * points to child device -i.e. vfio device. Indeed, during the probe
+ * function we set an initialized structure called 'priv' as driver
+ * data for all platform devices including parents devices and child
+ * devices. This driver data is unique to each device - see call to
+ * 'platform_set_drvdata()'. However, when we add the child device to
+ * a vfio group through 'vfio_add_group_dev()' call, this function
+ * creates a new driver data for the device - i.e. a 'vfio_device'
+ * structure which includes a field called 'device_data' to hold the
+ * aforementionned initialized private data. So, to retrieve our
+ * private data, we must call 'dev_get_drvdata()' which returns the
+ * 'vfio_device' struct and access its 'device_data' field. However,
+ * this cannot be done before determining if the 'pdev' is associated
+ * with a child device or a parent device.
+ * In order to deal with that we propose this little hack which uses
+ * the iommu_group to distinguich between parent and child devices.
+ * For now, let's say it is a customized solution that works for our
+ * case. Indeed, in the current design, the private data holds some
+ * infos that defines the type of the device. The intuitive way to do
+ * that is as following:
+ *
+ * struct pka_platdata *priv = platform_get_drvdata(pdev);
+ * struct pka_info *info = priv->info;
+ *
+ * if (info->flag == PKA_DRIVER_FLAG_RING_DEVICE)
+ * return pka_drv_remove_ring_device(info);
+ * if (info->flag == PKA_DRIVER_FLAG_DEVICE)
+ * return pka_drv_remove_ring_device(info);
+ *
+ * Since the returned private data of child devices -i.e vfio devices
+ * corresponds to 'vfio_device' structure, we cannot use it to
+ * differentiate between parent and child devices. This alternative
+ * solution is used instead.
+ */
+ if (dev->iommu_group) {
+ PKA_PRINT(PKA_DRIVER, "remove ring device %s\n",
+ pdev->name);
+ return pka_drv_remove_ring_device(pdev);
+ }
+
+ PKA_PRINT(PKA_DRIVER, "remove device %s\n", pdev->name);
+ return pka_drv_remove_device(pdev);
+}
+
+static const struct of_device_id pka_drv_match[] = {
+ { .compatible = PKA_DEVICE_COMPAT },
+ { .compatible = PKA_RING_DEVICE_COMPAT },
+ {}
+};
+
+MODULE_DEVICE_TABLE(of, pka_drv_match);
+
+MODULE_DEVICE_TABLE(acpi, pka_drv_acpi_ids);
+
+static struct platform_driver pka_drv = {
+ .driver = {
+ .name = PKA_DRIVER_NAME,
+ .of_match_table = of_match_ptr(pka_drv_match),
+ .acpi_match_table = ACPI_PTR(pka_drv_acpi_ids),
+ },
+ .probe = pka_drv_probe,
+ .remove = pka_drv_remove,
+};
+
+/* Initialize the module - Register the pka platform driver */
+static int __init pka_drv_register(void)
+{
+ int ret;
+
+ ret = pka_drv_init_class();
+ if (ret) {
+ PKA_ERROR(PKA_DRIVER, "failed to create class\n");
+ return ret;
+ }
+
+ ret = platform_driver_register(&pka_drv);
+ if (ret) {
+ PKA_ERROR(PKA_DRIVER, "failed to register platform driver\n");
+ return ret;
+ }
+
+ PKA_PRINT(PKA_DRIVER, "version: " PKA_DRIVER_VERSION "\n");
+
+ return 0;
+}
+
+/* Cleanup the module - unregister the pka platform driver */
+static void __exit pka_drv_unregister(void)
+{
+ platform_driver_unregister(&pka_drv);
+ pka_drv_destroy_class();
+}
+
+module_init(pka_drv_register);
+module_exit(pka_drv_unregister);
+
+MODULE_DESCRIPTION(PKA_DRIVER_DESCRIPTION);
+MODULE_VERSION(PKA_DRIVER_VERSION);
+MODULE_LICENSE("Dual BSD/GPL");
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_firmware.h b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_firmware.h
new file mode 100644
index 000000000..29ea27ce0
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_firmware.h
@@ -0,0 +1,4823 @@
+//
+// BSD LICENSE
+//
+// Copyright(c) 2016 Mellanox Technologies, Ltd. All rights reserved.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in
+// the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Mellanox Technologies nor the names of its
+// contributors may be used to endorse or promote products derived
+// from this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+
+#ifndef __DRIVERS_MICA_PKA_FW_H__
+#define __DRIVERS_MICA_PKA_FW_H__
+
+#include <linux/types.h>
+
+//
+// Program binaries
+//
+
+// Align to PKA_BUFFER_RAM_SIZE. This is greater than the actual buffer
+// length so that the image is zero padded.
+static const uint32_t fw0_farm_img_data_buf[2048] =
+{
+ 0x137001C9, 0x692040FA, 0x55502301, 0x328C0200,
+ 0x5E7000C9, 0x3D7000C8, 0x3670001D, 0x5370001F,
+ 0x746A4010, 0x046B4014, 0x3C621FF8, 0x4B631FF4,
+ 0x2A684000, 0x5A694004, 0x4F601FF6, 0x3F611FF2,
+ 0x5A6A4008, 0x2A6B400C, 0x19621FFA, 0x6D631FF0,
+ 0x0F684034, 0x7070001E, 0x5D34003F, 0x08601FFE,
+ 0x0328000B, 0x52C40047, 0x69240027, 0x04880000,
+ 0x76800047, 0x3380002E, 0x36800047, 0x7A800039,
+ 0xB6800047, 0xDF80003B, 0xD7800027, 0x9B800035,
+ 0xDC80003D, 0xB980003F, 0xB5800041, 0xF36A4018,
+ 0xDA621FFC, 0x9997017D, 0xA4300002, 0xD9D00061,
+ 0xBC30FFFE, 0xFC800056, 0xF36A4018, 0x9A621FFC,
+ 0xD59701CC, 0xA4300002, 0x99D00061, 0xFC30FFFE,
+ 0x99800062, 0xD097026C, 0xD38C0400, 0x8B614018,
+ 0xBC800056, 0xFF97039F, 0xFC800056, 0x9A97039D,
+ 0xFC800056, 0x9D9703A3, 0xBC800056, 0xF89703A1,
+ 0xBC800056, 0xDC970367, 0xFC800056, 0x9D200003,
+ 0xFC800056, 0xB7200023, 0xBC800056, 0xFD7000C8,
+ 0xD2200021, 0xBA8C5000, 0x9B80006F, 0xF5707FC8,
+ 0x84702084, 0xF670001D, 0xDB200000, 0xB6010000,
+ 0xCF220001, 0xB197007F, 0xA0684084, 0xD3340020,
+ 0xA7CC0052, 0xFC20000F, 0xF18C0100, 0xA4300002,
+ 0x99D00061, 0xED601FFC, 0xD5681FF0, 0x926A4014,
+ 0xF6010000, 0xB18C0100, 0x9260400C, 0xF197007F,
+ 0x34681FFC, 0x7C30FFFE, 0x616A1FF6, 0x336B1FF8,
+ 0x44624000, 0x3B634010, 0x076A1FF2, 0x526B1FF4,
+ 0x62624004, 0x1D634014, 0x006A1FFA, 0x7A230000,
+ 0x03624008, 0x7A8C5000, 0x5A63401C, 0x086440C9,
+ 0x5B800003, 0x3B6B1FE4, 0x118B4000, 0x7F8C0480,
+ 0x17BC004B, 0x6D61401C, 0x518B4000, 0x36010000,
+ 0x3C30FFFE, 0x66500000, 0x66500000, 0x26500000,
+ 0x66500000, 0x24300002, 0x102A0002, 0x65614000,
+ 0xAD624010, 0xF4604008, 0xEE218808, 0x93800073,
+ 0xE5631FEC, 0x8B6B4000, 0x846A1FF4, 0xF3604000,
+ 0xC3614004, 0x95634008, 0xAD624010, 0xCB624014,
+ 0xBB218001, 0xD0970073, 0xFA068000, 0x8C6B4008,
+ 0xE6691FF2, 0x92634000, 0x83614004, 0xF4604008,
+ 0xAD624010, 0xD6218200, 0xD0970073, 0xBC6B1FEC,
+ 0x918B4000, 0xE2631FE4, 0xF0681FF2, 0xB56040A0,
+ 0xE5691FF4, 0xB3604000, 0xB4604008, 0xCC614010,
+ 0x138C0400, 0x6470081C, 0x5270881D, 0x20F000A3,
+ 0x7C30FFFE, 0x33490000, 0x34310001, 0x5D200003,
+ 0x48D40071, 0x0931FFFF, 0x146540B4, 0x706B1FFE,
+ 0x216A1FF6, 0x7E33FFFF, 0x56D000BA, 0x336B1FF8,
+ 0x44624000, 0x03624008, 0x3B634010, 0x7F8C0480,
+ 0x17BC004B, 0x5E70011F, 0x6470081C, 0x1270881D,
+ 0x08F000B8, 0x538000BC, 0x7F8C0480, 0x17BC004B,
+ 0x6C6840A0, 0x30694024, 0x2F090000, 0x7FC8017A,
+ 0x23024000, 0x6E2E0001, 0x4B624014, 0x2F31FFFB,
+ 0x47684028, 0x1370001F, 0x3734001F, 0x57184000,
+ 0x592C0001, 0x17020000, 0x24240008, 0x6934FFE0,
+ 0x04300005, 0x65691FF4, 0x506040A2, 0x366040A6,
+ 0x592C0001, 0x2F090000, 0x10C400DF, 0x7A6940A0,
+ 0x0E050000, 0x722DFFFF, 0x6A31FFFE, 0x30510000,
+ 0x30510000, 0x61691FFA, 0x4E050000, 0x322DFFFF,
+ 0x6A31FFFE, 0x30510000, 0x30510000, 0x592C0001,
+ 0x8434FFFE, 0xC4601FEC, 0xF526000C, 0xB0621FEA,
+ 0xD126005F, 0xBA200060, 0xBA230000, 0xCB0B2000,
+ 0xF22DFFFF, 0x816140AA, 0x8F2D0001, 0xEA072000,
+ 0xBF6B1FEA, 0xD4004000, 0xFA30FFFD, 0xAF0AC000,
+ 0xFA230000, 0xA6631FEA, 0x8B0B2000, 0xFA20000C,
+ 0xBA230000, 0xF4290007, 0xF9C400F9, 0x95250007,
+ 0x9B8000FA, 0xED210007, 0xCD084000, 0xB61B4000,
+ 0xF9634088, 0x986940AA, 0xBA30FFFD, 0xCF2D0001,
+ 0xAA072000, 0xF22A0008, 0xD5621FE8, 0xB5008000,
+ 0xEE2E0001, 0xA934FFE0, 0x84300005, 0xD92C0001,
+ 0xF46B1FF0, 0x8B691FEC, 0xA1601FEE, 0xCD074000,
+ 0x92634000, 0xDD33FFFE, 0xC7530000, 0x87530000,
+ 0xC7530000, 0x87530000, 0x85330002, 0xD5634008,
+ 0xB9070000, 0xE52B0003, 0xE4280004, 0x8FC00130,
+ 0x992C0001, 0xDA604010, 0xFF8C0480, 0x97BC004B,
+ 0xDE70011F, 0x9570001C, 0x9270881D, 0xE3F0011F,
+ 0x07691FFE, 0x66684024, 0x4931FFFF, 0x1BD0012F,
+ 0x40691FF6, 0x02140000, 0x3ED00177, 0x4D084000,
+ 0x51694028, 0x2135001F, 0x3930FFFB, 0x57184000,
+ 0x3BC80174, 0x592C0001, 0x40601FE2, 0x1370001F,
+ 0x75008000, 0x3E3CFFFF, 0x18218000, 0x6C110000,
+ 0x1D33FFFE, 0x50340010, 0x57C8013B, 0x0B41C000,
+ 0x27270002, 0x47530000, 0x5180013D, 0x07530000,
+ 0x4B41C000, 0x38681FEE, 0x3A6940A0, 0x5A604010,
+ 0x0B6B4000, 0x7904C000, 0x592C0001, 0x0434FFFE,
+ 0x43614004, 0x34604008, 0x2268401C, 0x7F8C0480,
+ 0x57BC004B, 0x1E70011F, 0x1570001C, 0x6D70821D,
+ 0x07F0014C, 0x7E340008, 0x73C8015E, 0x07691FFE,
+ 0x66684024, 0x0931FFFF, 0x30D0015E, 0x40691FF6,
+ 0x02140000, 0x7ED00177, 0x4D084000, 0x11694028,
+ 0x3930FFFB, 0x6135001F, 0x57184000, 0x3BC80174,
+ 0x592C0001, 0x00601FE2, 0x1370001F, 0x6D691FE8,
+ 0x9F20000E, 0xF4310001, 0xC931FFFF, 0xB4D00166,
+ 0xE42CFFFF, 0x94800162, 0xBC694000, 0xC62207FA,
+ 0xCC6B4008, 0xA46140A8, 0xB26340A4, 0xE36240AC,
+ 0xB16040AE, 0xD77000B2, 0xFF8C0480, 0x97BC004B,
+ 0xF8700484, 0x9CE00171, 0xB8200001, 0xF6800071,
+ 0xBF200009, 0xD370001F, 0xF6800071, 0x9E200005,
+ 0x9370001F, 0xF6800071, 0xFB200007, 0x9370001F,
+ 0xF3C80071, 0x84631FE0, 0xBA230000, 0xE9631FFE,
+ 0x3F970099, 0x433C0001, 0x7CC80185, 0x033C0001,
+ 0x558001CA, 0x37681FFA, 0x136040A4, 0x5D8C0180,
+ 0x57BC004B, 0x1A700184, 0x39E0018A, 0x7D6940A8,
+ 0x096840A2, 0x65614000, 0x592C0001, 0x346B1FF0,
+ 0x5A604010, 0x15634008, 0x1D8C0180, 0x57BC004B,
+ 0x1570001C, 0x5270881D, 0x62691FFC, 0x322DFFFF,
+ 0x17C801AE, 0x54004000, 0x4034FFF0, 0x1A20000B,
+ 0x68CC01CA, 0x2A6A1FEC, 0x0100C000, 0x4D048000,
+ 0x936340A8, 0xF26340A4, 0xFF8C0480, 0x97BC004B,
+ 0xDA700184, 0xB4E001A5, 0xB26040A8, 0xCD048000,
+ 0xDD8C0180, 0x97BC004B, 0x99700284, 0xF0E001AB,
+ 0xB22DFFFF, 0xE8CC01A6, 0xD5681FF0, 0x8B691FEC,
+ 0xCE050000, 0xA16A1FF6, 0xB86B1FE2, 0xF26040A8,
+ 0x856140A4, 0xE36240AC, 0xF4681FFC, 0x862B0002,
+ 0xA42CFFFF, 0xD06340AE, 0xF96040B2, 0x968C5080,
+ 0xD7BC004B, 0xB8700484, 0x9CE001BE, 0xFE201FE8,
+ 0x85500001, 0xE4300002, 0xD36040A4, 0x9B200000,
+ 0xF66040A6, 0x9D8C0180, 0x97BC004B, 0xDA700184,
+ 0xD7E001C8, 0xB8200001, 0x9D6B1FE0, 0xD18B4000,
+ 0x87631FE6, 0xE6691FF2, 0xC06A1FFA, 0x83614004,
+ 0xE5691FF4, 0xB3621FDA, 0xAA614014, 0xD4004000,
+ 0x86240002, 0xC434FFFE, 0xE1601FD8, 0xBA054000,
+ 0xA26A1FF0, 0xCC614010, 0xC4624000, 0xAF060000,
+ 0xEF060000, 0xB1260002, 0x83624008, 0xD6218200,
+ 0x10970073, 0x516B1FF2, 0x6F060000, 0x39070000,
+ 0x74634004, 0x03624008, 0x10970073, 0x57020000,
+ 0x7B694008, 0x15681FF0, 0x3A098000, 0x7A068000,
+ 0x3197007F, 0x78681FD8, 0x476A1FF2, 0x00691FF6,
+ 0x736B1FF8, 0x2F060000, 0x21270001, 0x6537FFFE,
+ 0x2F05C000, 0x746B1FF0, 0x59611FF6, 0x3904C000,
+ 0x1E621FF2, 0x6E601FFA, 0x4C601FF0, 0x138C0400,
+ 0x5997017D, 0x01030000, 0x223F0001, 0x6DCC026A,
+ 0xB18C0100, 0xCF6A1FD8, 0xC3691FF0, 0x94004000,
+ 0xFA098000, 0x8D048000, 0xB197007F, 0xF6010000,
+ 0xEA684000, 0xBA098000, 0xBA068000, 0xF197007F,
+ 0xB36B1FF8, 0xC0691FF6, 0xE1270001, 0xA537FFFE,
+ 0xCE09C000, 0x996B1FD8, 0x876A1FF2, 0xD9611FF6,
+ 0xAF0AC000, 0xDE621FF2, 0xD38C0400, 0x9997017D,
+ 0xBC6B1FDA, 0xCF6A1FD8, 0xC3691FF0, 0x8F631FFA,
+ 0xFA098000, 0x9A611FF0, 0x81030000, 0xE23F0001,
+ 0x2DCC026A, 0x718C0100, 0x54004000, 0x0D048000,
+ 0x5260400C, 0x0D048000, 0x06240002, 0x66691FF2,
+ 0x446A1FF4, 0x3C30FFFE, 0x26500000, 0x66500000,
+ 0x24300002, 0x7197007F, 0x4B624014, 0x2A6B400C,
+ 0x77260001, 0x03691FF0, 0x21280001, 0x6D624010,
+ 0x34604008, 0x43614004, 0x52634000, 0x162A0001,
+ 0x1B058000, 0x6A31FFFE, 0x70510000, 0x30510000,
+ 0x6C078000, 0x1D33FFFE, 0x07530000, 0x47530000,
+ 0x3D218002, 0x50970073, 0x71260002, 0x2D624010,
+ 0x61691FFA, 0x1A6A4008, 0x03614004, 0x43624008,
+ 0x7B218001, 0x10970073, 0x30681FF2, 0x7C694000,
+ 0x04624000, 0x55604004, 0x526B1FF4, 0x22614008,
+ 0x5807C000, 0x27270002, 0x3B634010, 0x56218200,
+ 0x10970073, 0x7B694008, 0x43624008, 0x196B1FD8,
+ 0x25614000, 0x79070000, 0x73681FF4, 0x34634004,
+ 0x5A604010, 0x3B218001, 0x10970073, 0x62624004,
+ 0xA26A1FF0, 0xD8040000, 0xC4624000, 0x83624008,
+ 0xFC604014, 0xB6218018, 0x90970073, 0xE562400C,
+ 0xD38C0400, 0xB8200001, 0x9E6B1FE6, 0xD18B4000,
+ 0xA2631FE4, 0xD5681FF0, 0xD260400C, 0x84691FF8,
+ 0xF4611FDE, 0x846A1FF4, 0xB0621FDC, 0xFA0A4000,
+ 0x820E4000, 0xC5D40277, 0xE3024000, 0x92260003,
+ 0xB336FFFE, 0xC0601FE2, 0xCD048000, 0xA5601FE0,
+ 0xCD048000, 0xBA068000, 0xBB621FF0, 0xCD048000,
+ 0x25601FD6, 0x4B68400C, 0x76970077, 0x226A1FF0,
+ 0x4B68400C, 0x0D048000, 0x36970077, 0x656A1FF8,
+ 0x59681FE2, 0x346B1FF0, 0x3904C000, 0x40691FF6,
+ 0x3197007F, 0x538C0400, 0x476B4024, 0x22631FD2,
+ 0x4D378000, 0x23CC035A, 0x3C681FE0, 0x746B1FF0,
+ 0x3904C000, 0x66691FF2, 0x446A1FF4, 0x3197007F,
+ 0x19681FE2, 0x7C30FFFE, 0x45500001, 0x3C681FE0,
+ 0x66691FF2, 0x3197007F, 0x3D201FD8, 0x66500000,
+ 0xA6500000, 0xE6691FF2, 0xEA31FFFE, 0x87494000,
+ 0xF4310001, 0x80D4035D, 0x8931FFFF, 0xDB200000,
+ 0xC0601FD4, 0x99230001, 0x8F220001, 0xC100C000,
+ 0x97148000, 0xDCC802B2, 0xD9681FD4, 0x8D048000,
+ 0xC0601FD4, 0x8D074000, 0xBA054000, 0xFA068000,
+ 0xA9CC02AB, 0xD9681FE2, 0xF46B1FF0, 0xB904C000,
+ 0x8D210000, 0xCC6A1FDE, 0xDF970361, 0xBC30FFFE,
+ 0xE5480000, 0x8D388000, 0xA2300001, 0xD7D002C2,
+ 0x96250001, 0xF88002BE, 0xF63D0000, 0x94C802F4,
+ 0xD38C0400, 0x8B614018, 0x93218040, 0xD0970073,
+ 0xD9681FD4, 0x8F691FE2, 0xAA31FFFE, 0xC7494000,
+ 0xAA072000, 0xEE210001, 0xE56B4018, 0x9F3FFFFF,
+ 0xE1270001, 0x8D11C000, 0xB22DFFFF, 0xC1164000,
+ 0x996B1FD8, 0xD38C0400, 0xF0694024, 0x95611FD2,
+ 0xBAC802EC, 0xEF1F8000, 0xDEC802E5, 0x96621FD8,
+ 0xF0681FF2, 0x862107F6, 0xBC970360, 0xCF220001,
+ 0x0B624014, 0x7C681FD6, 0x74604008, 0x3B218001,
+ 0x50970073, 0x2A691FD6, 0x19681FE2, 0x446A1FF4,
+ 0x77260001, 0x1F970361, 0x31218010, 0x50970073,
+ 0x19681FE2, 0x4D210000, 0x446A1FF4, 0x37260001,
+ 0x5F970361, 0x13218040, 0x10970073, 0x798002B5,
+ 0x3C681FE0, 0x746B1FF0, 0x7904C000, 0x15604004,
+ 0x19681FE2, 0x7904C000, 0x73604000, 0x0C6A1FDE,
+ 0x7F6B1FDC, 0x1D634014, 0x2F0AC000, 0x570EC000,
+ 0x05D40302, 0x7602C000, 0x6D624010, 0x37218400,
+ 0x50970073, 0x0C691FD2, 0x2F1C4000, 0x44CC030F,
+ 0x6A31FFFE, 0x11484000, 0x033C0001, 0x492D0002,
+ 0x07494000, 0x57184000, 0x79C80350, 0x138C0400,
+ 0x40684020, 0x22300001, 0x18D0035A, 0x64300002,
+ 0x33D0031D, 0x6A684000, 0x5A694004, 0x15604004,
+ 0x25614000, 0x43684010, 0x73694014, 0x3C604014,
+ 0x4C614010, 0x0B6B4000, 0x15634008, 0x47631FD0,
+ 0xB2218020, 0xD0970073, 0xF1D00326, 0xBC681FE0,
+ 0xCF691FE2, 0xB3800328, 0x99681FE2, 0xEA691FE0,
+ 0xC46A1FF4, 0xB7260001, 0x9F970361, 0xD38C0400,
+ 0x916A4024, 0xF2218020, 0xD0970073, 0xBF681FD0,
+ 0xCE0A0000, 0xB7260001, 0xAA691FE0, 0xF46B1FF0,
+ 0xAF05C000, 0xCD1D0000, 0xE2CC033D, 0x99681FE2,
+ 0xAA691FE0, 0xE5601FE0, 0xD6611FE2, 0xBB681FDE,
+ 0xC7601FDC, 0x95621FDE, 0x99681FE2, 0xE6691FF2,
+ 0xBC970360, 0xF46A4010, 0xCD048000, 0xBC30FFFE,
+ 0xD38C0400, 0x844B0000, 0xA6500000, 0xE6500000,
+ 0xC13F0000, 0xBCC802B5, 0xB1218010, 0xD0970073,
+ 0xA22CFFFC, 0xD38C0400, 0xE6500000, 0xB98002B5,
+ 0xCF691FE2, 0xBC681FE0, 0x846A1FF4, 0xF197007F,
+ 0x8B624014, 0xF8200001, 0xCD210000, 0xAA6B400C,
+ 0xAD631FF0, 0xF6800071, 0xD2200017, 0xAD210007,
+ 0xDC800357, 0x9D200003, 0x8321001F, 0xDC800357,
+ 0x046A1FF4, 0x6D624010, 0x4B624014, 0x33604000,
+ 0x43614004, 0x34604008, 0x118B4000, 0x47631FE6,
+ 0x56681FF6, 0x04691FF8, 0x046A1FF4, 0x6E601FCC,
+ 0x3B611FCA, 0x7C621FF8, 0x52260003, 0x3336FFFE,
+ 0x7C621FCE, 0x346B1FF0, 0x2C078000, 0x6C078000,
+ 0x2E631FF6, 0x6C078000, 0x6D631FF0, 0x1097026C,
+ 0x033C0001, 0x72C8037C, 0x433C0001, 0x3980039A,
+ 0x55681FF0, 0x256A1FCE, 0x2C088000, 0x76970077,
+ 0x83691FF0, 0xE56A1FCE, 0xF5034000, 0x94004000,
+ 0xEC078000, 0x92634000, 0xAC088000, 0xEC088000,
+ 0xD4970084, 0x83691FF0, 0xA56A1FCE, 0xD4004000,
+ 0xAC088000, 0xFC30FFFE, 0xC5500001, 0xA7280002,
+ 0xE4300002, 0xAC088000, 0xAC088000, 0xCC601FF0,
+ 0x94970084, 0xE1691FCC, 0xC36A1FCA, 0x99611FF6,
+ 0xBC621FF8, 0xF8200001, 0xD38C0400, 0x9E6B1FE6,
+ 0xD18B4000, 0xAC220000, 0xBE8003A4, 0xD8224000,
+ 0x3E8003A4, 0x79228000, 0x7E8003A4, 0x0D22C000,
+ 0x7F621FFE, 0x07631FE6, 0x3F970099, 0x526B1FF4,
+ 0x44270003, 0x2537FFFE, 0x22631FBE, 0x76010000,
+ 0x033C0001, 0x718C0100, 0x67CC04E2, 0x3E6A40A2,
+ 0x6B6840A8, 0x37260001, 0x1A970658, 0x70681FF2,
+ 0x046A1FF4, 0x5A970658, 0x77260001, 0x3336FFFE,
+ 0x276240A2, 0x416240A6, 0x7D6940A8, 0x2D6A1FBE,
+ 0x70611FBC, 0x13201FC0, 0x13230010, 0x5B058000,
+ 0x2A410000, 0x5F2C0002, 0x452FFFFF, 0x2BCC03BF,
+ 0x56681FC0, 0x2E32FFFC, 0x36970077, 0x7B970638,
+ 0x4F691FD4, 0x30681FF2, 0x0F220001, 0x7197061F,
+ 0x306B1FFE, 0x7E33FFFF, 0x74D0052F, 0x3B6B1FBE,
+ 0x66691FF2, 0x0B6A1FD6, 0x2F05C000, 0x7797062A,
+ 0x00691FC0, 0x4F220001, 0x7E97063D, 0x2D691FDE,
+ 0x0A220004, 0x7E97063D, 0x6A6A1FDA, 0x21691FFA,
+ 0x7797062A, 0x2E691FD8, 0x3B6B1FBE, 0x70681FF2,
+ 0x89220002, 0xF904C000, 0xF904C000, 0xB197061F,
+ 0xD2970628, 0xB06B1FFE, 0xA1691FFA, 0xE31BC000,
+ 0xCAD403EF, 0xBB6B1FBE, 0xA26A1FC6, 0xEF05C000,
+ 0xAF05C000, 0xF797062A, 0xDF8003F2, 0x80691FC0,
+ 0xD5681FC6, 0xB0970614, 0x8B691FDA, 0xF0681FC4,
+ 0xA26A1FC6, 0xD46040AC, 0xE46140A8, 0xA46240A4,
+ 0xBA8C5000, 0xD4700384, 0xFA970605, 0x8D21889C,
+ 0xC5614092, 0xBA8C5000, 0xB1700080, 0xCF691FE2,
+ 0xB597064B, 0xE9204096, 0xC0502A27, 0xA15030A7,
+ 0xE9204096, 0xAA504A52, 0x995024A5, 0xD1970642,
+ 0xEF502E27, 0xBF502084, 0xB7970646, 0xC450292F,
+ 0x91970642, 0xE76B4080, 0xF2370020, 0xA2CC0444,
+ 0xE9503548, 0xA1501CE4, 0xB7970646, 0xF85024A9,
+ 0x91970642, 0xE150A148, 0xC55035A4, 0xB7970646,
+ 0x94502530, 0xD1970642, 0xC7502929, 0x8C5035B3,
+ 0xF7970646, 0xBF502108, 0x91970642, 0xF55025A9,
+ 0x2E502CA6, 0x77970646, 0x4A50288A, 0x11970642,
+ 0x7150B4EB, 0x0C509525, 0x37970646, 0x7B501086,
+ 0x51970642, 0x27502D67, 0x215035AD, 0x77970646,
+ 0x2350198F, 0x51970642, 0x676B4080, 0x00631FEE,
+ 0x715098C4, 0x1E509DB1, 0x37970646, 0x4A50316C,
+ 0x11970642, 0x40509148, 0x4F502CC6, 0x37970646,
+ 0x20503590, 0x51970642, 0x7A5099AB, 0x01194000,
+ 0x5CC80447, 0x3597064B, 0x2D204098, 0x615030A7,
+ 0x37970646, 0x595024A5, 0x51970642, 0x35800408,
+ 0x7A8C5000, 0x34200013, 0x398004E3, 0x7A8C5000,
+ 0x716A4080, 0x3B681FDE, 0x24360020, 0x4ECC04F2,
+ 0x2D6A1FBE, 0x76970077, 0x7B970638, 0x0F220001,
+ 0x6D691FDE, 0x3E97063D, 0x0C691FD2, 0x7B6B1FBE,
+ 0x37681FFA, 0x4F220001, 0x7904C000, 0x3197061F,
+ 0x12970628, 0x7B6B1FBE, 0x66691FF2, 0x086A1FD0,
+ 0x6F05C000, 0x2F05C000, 0x3797062A, 0x6E691FD8,
+ 0xBB6B1FBE, 0xF0681FF2, 0xCF220001, 0xB904C000,
+ 0xF904C000, 0xB197061F, 0x92970628, 0xD8700090,
+ 0xFA970605, 0xBA8C5000, 0xA9204096, 0xEA504A52,
+ 0x815029E5, 0xE9204096, 0xEA504A52, 0xBC502491,
+ 0xD1970642, 0x8150292A, 0xB95020B1, 0xF7970646,
+ 0x9D501264, 0xD1970642, 0xC0502D04, 0xBD5040B0,
+ 0xB7970646, 0xD25024E5, 0xD1970642, 0x8B50A088,
+ 0xDC504130, 0xB7970646, 0xAC502D4B, 0xD1970642,
+ 0x2A504A52, 0x45502924, 0x77970646, 0x27502CEB,
+ 0x51970642, 0x24502E0B, 0x3D5011AA, 0x77970646,
+ 0x7F502108, 0x11970642, 0x2A504A52, 0x45502E6B,
+ 0x37970646, 0x555020C8, 0x51970642, 0x3250AD0B,
+ 0x66502925, 0x11970642, 0x03501E52, 0x5550166B,
+ 0x37970646, 0x4C5019AA, 0x51970642, 0x2A504A52,
+ 0x115020C6, 0x77970646, 0x595024A5, 0x11970642,
+ 0x6A504A52, 0x01502D0F, 0x37970646, 0x4E502884,
+ 0x91970642, 0xCA50296A, 0xD3502188, 0x91970642,
+ 0xE650A509, 0xA4502944, 0x91970642, 0xEA504A52,
+ 0xD95024C9, 0x91970642, 0xAD50A549, 0xD5502144,
+ 0xB7970646, 0xD1502669, 0xD1970642, 0x95681FC6,
+ 0xFA8C5000, 0xA76B4080, 0xBC30FFFE, 0xDF370008,
+ 0x80CC04B7, 0xF320001B, 0xF98004E3, 0x85500001,
+ 0xB06B1FFE, 0xED204098, 0xE31BC000, 0x8DD404C4,
+ 0xFF5010E4, 0xAD204098, 0xB35014E5, 0xF7970646,
+ 0xAB5018E6, 0xD1970642, 0xF18C0100, 0xB180051F,
+ 0xEB5018E6, 0xB46B1FF0, 0x96681FF6, 0xC4691FF8,
+ 0xCC631FCA, 0xAE601FCC, 0x9D611FCE, 0xF0681FC4,
+ 0xA5691FF4, 0xF46B1FC6, 0xCF2D0001, 0x9D611FF8,
+ 0xED631FF0, 0x8F601FF6, 0xBA8C5000, 0xD097026C,
+ 0x956B1FCA, 0xC06A1FCC, 0xC4691FCE, 0xAD631FF0,
+ 0xB8621FF6, 0xDD611FF8, 0xD38C0400, 0x833C0001,
+ 0xE7CC04E2, 0x80691FC0, 0xBA97065F, 0xE5691FC2,
+ 0x3A97065F, 0x7180051F, 0x433C0001, 0x3423001F,
+ 0x44601FEC, 0x00631FEE, 0x2D6A1FBE, 0x47691FFE,
+ 0x55681FF0, 0x01194000, 0x14038000, 0x43D404ED,
+ 0x3A068000, 0x4E06C000, 0x76970077, 0x1D681FEC,
+ 0x596B1FEE, 0x1480052B, 0x0F6A1FEE, 0x4E6B4090,
+ 0x33320005, 0x4D1EC000, 0x6D360001, 0x12C804FB,
+ 0x1920000D, 0x5A230007, 0x598004E4, 0x2D6A1FBE,
+ 0x55681FF0, 0x07691FFE, 0x14038000, 0x7A068000,
+ 0x01194000, 0x47D40503, 0x4E06C000, 0x36970077,
+ 0x61691FFA, 0x15681FF0, 0x046A1FF4, 0x55970616,
+ 0x6D6A1FBE, 0x166B1FFA, 0x15681FF0, 0x6C078000,
+ 0x34634004, 0x4D048000, 0x74604008, 0x26691FF2,
+ 0x446A1FF4, 0x25614000, 0x0B624014, 0x72218020,
+ 0x266A1FFE, 0x50970073, 0x411A8000, 0x0FD40529,
+ 0x3B6B1FBE, 0x55681FF0, 0x5807C000, 0x3904C000,
+ 0x7C30FFFE, 0x05500001, 0x31800529, 0x6D6A1FBE,
+ 0x80691FC0, 0xD1681FFE, 0xD4038000, 0xA3180000,
+ 0xE8D40526, 0xBA068000, 0x8E06C000, 0xD5681FF0,
+ 0xD5970616, 0xBA230000, 0xB8200001, 0xD38C0400,
+ 0xBC634018, 0xDE6B1FE6, 0xD18B4000, 0xAD691FDE,
+ 0xCF220001, 0xBE97063D, 0xA16A1FC0, 0xE1691FFA,
+ 0xB797062A, 0xFB6B1FBE, 0xE1691FFA, 0x8F6A1FD8,
+ 0xAF05C000, 0xF797062A, 0xC76A1FC4, 0x80691FF6,
+ 0xF797062A, 0xBB6B1FBE, 0x80691FF6, 0xEA6A1FDA,
+ 0xAF05C000, 0xF797062A, 0xD1681FFE, 0xA3180000,
+ 0xD3D0054C, 0xAD691FDE, 0xB3681FC2, 0xF6970617,
+ 0xED691FDE, 0x95681FC6, 0xB6970617, 0xDA800558,
+ 0xBB6B1FBE, 0xE1691FFA, 0xC46A1FC2, 0xAF05C000,
+ 0xEF05C000, 0xB797062A, 0xBB6B1FBE, 0xC0691FF6,
+ 0xA26A1FC6, 0xEF05C000, 0xEF05C000, 0xB797062A,
+ 0x98700090, 0xFA970605, 0xFA8C5000, 0xB1700080,
+ 0xE9204096, 0xAA504A52, 0xB15024E4, 0xE9204096,
+ 0x2A504A52, 0x425030A6, 0x51970642, 0x1450B12C,
+ 0x515020F0, 0x37970646, 0x085028B1, 0x51970642,
+ 0x7E50A90A, 0x3E50AD8C, 0x11970642, 0x5050456B,
+ 0x2850BD4A, 0x77970646, 0x676B4080, 0x00631FEE,
+ 0x71700080, 0x0E50352B, 0x11970642, 0x596B1FEE,
+ 0x316A4080, 0x63330006, 0x6BD4057A, 0x35320006,
+ 0x35D005B1, 0x518004F8, 0x6A504A52, 0x0B502D8B,
+ 0x77970646, 0x37502531, 0x11970642, 0x7C50252B,
+ 0xB950210B, 0xF7970646, 0xED5018E5, 0x91970642,
+ 0xEA504A52, 0x99503CCF, 0xB7970646, 0xD1502669,
+ 0xD1970642, 0x8F50A52F, 0x835018CB, 0xD1970642,
+ 0xAA504A52, 0xD2503E69, 0xF7970646, 0x9250112C,
+ 0xD1970642, 0xBF50B5ED, 0x8950326C, 0xD1970642,
+ 0xAA504A52, 0xC15035AA, 0xD1970642, 0xB250B50D,
+ 0x92502533, 0xD1970642, 0xC3501E52, 0x9650166D,
+ 0xD1970642, 0xBB970638, 0xBB6B1FBE, 0xE6691FF2,
+ 0x0B6A1FD6, 0x6F05C000, 0x7797062A, 0x3B6B1FBE,
+ 0x66691FF2, 0x086A1FD0, 0x2F05C000, 0x6F05C000,
+ 0x7797062A, 0x3A970605, 0x3A8C5000, 0x69204096,
+ 0x2A504A52, 0x515020C6, 0x69204096, 0x2A504A52,
+ 0x5580049A, 0x3B970638, 0x3B6B1FBE, 0x66691FF2,
+ 0x0B6A1FD6, 0x6F05C000, 0x7797062A, 0x08691FDC,
+ 0x1D681FDA, 0x70970614, 0x4B691FDA, 0x09220002,
+ 0x7E97063D, 0x08691FDC, 0x15681FC6, 0x76970617,
+ 0x03691FC6, 0x6A220003, 0x7E97063D, 0x3A970605,
+ 0x7A8C5000, 0x31700080, 0x29204096, 0x6A504A52,
+ 0x7F502084, 0x29204096, 0x2A504A52, 0x6C503611,
+ 0x11970642, 0x6A504A52, 0x46502D07, 0x37970646,
+ 0x6C5034AD, 0x11970642, 0x2A504A52, 0x595024A5,
+ 0x37970646, 0x665029B0, 0x51970642, 0x27503144,
+ 0x1A50252F, 0x77970646, 0x4150194A, 0x11970642,
+ 0x745010C8, 0x0750318C, 0x37970646, 0x695028D1,
+ 0x91970642, 0xD2502569, 0xEC5019AD, 0xB7970646,
+ 0xDD501264, 0x91970642, 0x9F50B08C, 0xE8502D29,
+ 0xF7970646, 0xAD5019A6, 0x91970642, 0xEA504A52,
+ 0xB550166C, 0xF7970646, 0xDE502191, 0x91970642,
+ 0xF250AD0B, 0xAD502953, 0x91970642, 0xEA504A52,
+ 0xA950326B, 0xF7970646, 0xDE5011AB, 0x91970642,
+ 0x9950B585, 0xD2502533, 0xD1970642, 0xAA504A52,
+ 0xC75035A9, 0x91970642, 0xB950B54D, 0xC5502E6B,
+ 0x11970642, 0x43501E52, 0x5650166D, 0x11970642,
+ 0x7880059D, 0x2D6A1FBE, 0x00691FC0, 0x4B624014,
+ 0x4B32FFFE, 0x3A098000, 0x25614000, 0x456140A4,
+ 0x0F691FD4, 0x696A1FDC, 0x62614008, 0x25691FF4,
+ 0x62624004, 0x0F2D0001, 0x0C614010, 0x518B4000,
+ 0x046A1FF4, 0x6E2E0001, 0x6D624010, 0x25614000,
+ 0x34604008, 0x538C0400, 0x5570001C, 0x1270881D,
+ 0x5B058000, 0x0D048000, 0x118B4000, 0x73604000,
+ 0xB3681FF4, 0xE2614008, 0xDA604010, 0x938C0400,
+ 0xEA624018, 0x97020000, 0xB4218080, 0xD3800073,
+ 0xED684008, 0x99800634, 0xA5631FEC, 0xE5614000,
+ 0x83624008, 0xF5008000, 0xE9218800, 0x90970073,
+ 0xC46A1FF4, 0x9A970658, 0xAD684008, 0xFC6B1FEC,
+ 0xB26040A8, 0xFA8C5000, 0xDA700184, 0x918B4000,
+ 0x846A1FF4, 0xE9691FBC, 0xED624010, 0x856140A4,
+ 0xD18B4000, 0x94004000, 0xAA31FFFE, 0xD38C0400,
+ 0xBF424000, 0xD9800634, 0xD68C5080, 0x97BC004B,
+ 0xE9204096, 0x918B4000, 0x968C5080, 0xD7BC004B,
+ 0xE9204096, 0xAA504A52, 0x918B4000, 0xD6681FF6,
+ 0xB22DFFFF, 0xE3024000, 0xF736FFF0, 0xB0320003,
+ 0xFC30FFFE, 0xAF060000, 0x874A8000, 0xD4004000,
+ 0x9E34000F, 0xCD120000, 0xC1624090, 0x918B4000,
+ 0x8D048000, 0xFC30FFFE, 0xE6500000, 0xA6500000,
+ 0xE6500000, 0xA6500000, 0x918B4000, 0xE26A1FC6,
+ 0x246140A8, 0x646240A4, 0x718C0100, 0x1A700184,
+ 0x476A1FF2, 0x22624004, 0x046A1FF4, 0x4B624014,
+ 0x65614000, 0x22614008, 0x318C0100, 0x50694080,
+ 0x0C350001, 0x47CC066F, 0x518B4000, 0x2E2E0001,
+ 0x6D624010, 0x32218020, 0x13800073, 0x0079084F
+};
+
+static const uint32_t fw0_boot_img_data_buf[] =
+{
+ 0x3F200503, 0x6E210001, 0x6A710249, 0x38200001,
+ 0x5460B41C, 0x1397008C, 0x0D210000, 0x4931FFFF,
+ 0x6D390001, 0x242CFFFF, 0x00CC0007, 0x736AB1F8,
+ 0x2361B140, 0x6F3A0000, 0x4FCC0013, 0x1F200777,
+ 0x5860B438, 0x1F60B45C, 0x14800017, 0x5D200333,
+ 0x1860B438, 0x5F60B45C, 0x7E60B43C, 0x0520FFFF,
+ 0x3660B420, 0x4D210000, 0x6F68B420, 0x0561B422,
+ 0x4934FEFE, 0x22300001, 0x3660B420, 0x4661B424,
+ 0xA361B426, 0xE761B428, 0xC261B42A, 0x8161B42C,
+ 0xE461B42E, 0xAF61B434, 0x8A61B436, 0xD397008C,
+ 0xCE21A0CA, 0xB9228000, 0xBF424000, 0xE12D0100,
+ 0xA42CFFFF, 0xE8CC002A, 0xCB710449, 0x83B80032,
+ 0xD8224000, 0x98800033, 0xAC220000, 0xC3210045,
+ 0x8661B424, 0xFA230000, 0xF663B42C, 0x9397008C,
+ 0xA9232000, 0xC662B428, 0xD863B434, 0x9269B1F8,
+ 0xCE390000, 0xABCC0040, 0x89210777, 0xF5800041,
+ 0x8B210333, 0xF38C0078, 0xD6BC0076, 0x8E61B438,
+ 0xE42CFFFF, 0x87CC0039, 0x85710649, 0xD397008C,
+ 0xEB21A0C8, 0xAC220000, 0xBF424000, 0xC92D0002,
+ 0xBF424000, 0xCC2D00FE, 0xE42CFFFF, 0x89CC004A,
+ 0xC468B1F8, 0x8D223000, 0x98380000, 0xC0CC005D,
+ 0x96711049, 0xE5B8005A, 0xEF204000, 0xBF222000,
+ 0x91230071, 0xD2800078, 0xDB200000, 0x91230071,
+ 0xD2800078, 0xB7712049, 0x82B80063, 0xF9214000,
+ 0x3A230000, 0x7F222000, 0x79800065, 0x0D210000,
+ 0x7A230000, 0x0C20B424, 0x2C500011, 0x45500001,
+ 0x6850C400, 0x05500001, 0x0161B42C, 0x5363B42E,
+ 0x0E62B434, 0x7C230333, 0x738C0078, 0x16BC0076,
+ 0x7963B438, 0x1B200000, 0x3560B140, 0x69710149,
+ 0x3C8C0000, 0x73800074, 0x7971FF49, 0x33800074,
+ 0x15320001, 0x45367FFF, 0x75C8008B, 0x322A0008,
+ 0x4DC00087, 0x26500000, 0x26500000, 0x66500000,
+ 0xA6500000, 0xE6500000, 0xE6500000, 0xA6500000,
+ 0xE6500000, 0xB5C8008B, 0x9480007B, 0xD3260008,
+ 0xE6500000, 0x932EFFFF, 0x8BCC0088, 0xD18B4000,
+ 0x8468B1F8, 0xDE34000F, 0xDBC80093, 0xA028000A,
+ 0xFAC40093, 0x8124000A, 0x918B4000, 0xF920000A,
+ 0x918B4000, 0xE0000000, 0xE0000000, 0xA0000000
+};
+
+static const uint32_t fw0_master_img_data_buf[] =
+{
+ 0x3F200503, 0x6E210001, 0x5E605FF4, 0x2D615FF6,
+ 0x5B200000, 0x3260B148, 0x0D205FE0, 0x5C215FE8,
+ 0x7D230008, 0x2F090000, 0x23C000F3, 0x78200001,
+ 0x1460B41C, 0x719700B0, 0x539700BA, 0x0E208000,
+ 0x7560B140, 0x20000000, 0x20000000, 0x60000000,
+ 0x25685FFE, 0x5269B1F8, 0x626B5FFA, 0x353C4600,
+ 0x2CCC0012, 0x793B0000, 0x48D4001D, 0x1B3700FF,
+ 0x5763B47A, 0x1D200333, 0x1860B438, 0x5F60B45C,
+ 0xBE60B43C, 0xFC230003, 0xF722B400, 0x8520FFFF,
+ 0xE9408000, 0x8D210000, 0xB0488000, 0xF1260002,
+ 0xFF418000, 0x8934FEFE, 0xA2300001, 0xD02A0002,
+ 0xA9408000, 0xFE260020, 0xC52FFFFF, 0x8CCC0023,
+ 0xDB200000, 0x9F60B406, 0xB660B416, 0xF560B426,
+ 0x9C60B436, 0xD460B446, 0xFD60B456, 0xA16B5FFC,
+ 0x80210100, 0xE2222F00, 0xF4370080, 0x9FC8003E,
+ 0xCD210000, 0x8D223000, 0x8C20B424, 0xEC500011,
+ 0x85500001, 0xE850C400, 0xC5500001, 0xAA410000,
+ 0xDF2C0002, 0xA6500000, 0x8E62B434, 0xC8205E90,
+ 0xE6220164, 0xAF970F80, 0x9269B1F8, 0xEA220333,
+ 0x9B200000, 0xF38C0078, 0xD1BC00EB, 0xAF62B438,
+ 0xD060B424, 0xB560B426, 0xB9610102, 0xC835000F,
+ 0x9C610100, 0xC568B400, 0xF969B420, 0x99605FCA,
+ 0xA9615FCE, 0xFA3400FF, 0xD6380200, 0x9A605FCC,
+ 0xF235FF00, 0xAB390002, 0x84615FD0, 0xC1970F0D,
+ 0x38200001, 0x57605EA0, 0x502001A0, 0x2B60010C,
+ 0x7A203000, 0x0E60010E, 0x38200001, 0x7260B148,
+ 0x58695EA0, 0x39228000, 0x14004000, 0x433C0001,
+ 0x26CC006F, 0x4262B140, 0x50800075, 0x14004000,
+ 0x463C0004, 0x2DCC0075, 0x2C68B140, 0x543C4000,
+ 0x3560B140, 0x4835000F, 0x4931FFFF, 0x002D0079,
+ 0x26894000, 0x528C1D78, 0x5F800098, 0x378C1D7A,
+ 0x5F800098, 0x3E8C1DF8, 0x1F800098, 0x5B8C1DFA,
+ 0x9F800098, 0xF48C1D7C, 0xDF800098, 0x918C1D7E,
+ 0xDF800098, 0x988C1DFC, 0x9F800098, 0xFD8C1DFE,
+ 0xDF800098, 0xB18C1D79, 0x9F800098, 0xD48C1D7B,
+ 0x9F800098, 0xDD8C1DF9, 0xDF800098, 0xB88C1DFB,
+ 0xDF800098, 0x978C1D7D, 0x9F800098, 0xF28C1D7F,
+ 0x9F800098, 0xFB8C1DFD, 0xDF800098, 0x9E8C1DFF,
+ 0x95B000E9, 0xC8BC0BF6, 0xFDD80CC3, 0x90A00BF7,
+ 0xEBA40C1D, 0xA5A80C38, 0x8CF80EFB, 0xD3E80CE1,
+ 0x17E00107, 0x796A5EA0, 0x7F2300A6, 0x2B360002,
+ 0x5DC800A6, 0x38AC0E86, 0x38215EA2, 0x63220014,
+ 0x44970F9D, 0x3EC80068, 0x30884000, 0x58380000,
+ 0x36C80101, 0x78215EA2, 0x63220014, 0x27800FC0,
+ 0x5B200000, 0x3360B000, 0x3460B008, 0x4F220001,
+ 0x2B2D0008, 0x6D62B010, 0x7B60B01C, 0x08228800,
+ 0x0C62B01C, 0x518B4000, 0x4468B1F8, 0x36635E96,
+ 0x5E34000F, 0x01030000, 0x012B000A, 0x45C000C1,
+ 0x3920000A, 0x41030000, 0x4D210000, 0x0931FFFF,
+ 0x6D390001, 0x242CFFFF, 0x01CC00C3, 0x6361B140,
+ 0x79228000, 0x36010000, 0x10310008, 0x4D39A0CA,
+ 0x3F424000, 0x6C220000, 0x7F424000, 0x06220020,
+ 0x7C2DFFBA, 0x3F424000, 0x2C220000, 0x582DFF7C,
+ 0x3F424000, 0x6B2D0008, 0x7F424000, 0x0F220001,
+ 0x2B2D0008, 0x7F424000, 0x6C220000, 0x0D2D000C,
+ 0x7F424000, 0x08228800, 0x3F424000, 0x43220400,
+ 0xA462B144, 0xD7020000, 0xE13A0200, 0xA462B144,
+ 0xD92C0001, 0x852FFFFF, 0x80CC00C8, 0xEF6B5E96,
+ 0xD18B4000, 0x8222008D, 0x988000FC, 0xE4220089,
+ 0x988000FC, 0xC6220083, 0xD88000FC, 0x85220085,
+ 0xD88000FC, 0xA9220005, 0x988000FC, 0xE0220087,
+ 0x988000FC, 0xCC220007, 0xD88000FC, 0xA6220011,
+ 0x988000FC, 0xC122008B, 0xD88000FC, 0xAD22000B,
+ 0xEA625FF2, 0x99635FF0, 0xB1320008, 0xC562B148,
+ 0xB3D00102, 0xD18B4000, 0xF8200001, 0xB19700B0,
+ 0xD39700BA, 0xBC8C0000, 0x95800105, 0xF9695F20,
+ 0xFE20011B, 0x8E35C000, 0x91C8010E, 0xC9685F24,
+ 0x823D4000, 0xC5CC00A1, 0xDF2300A1, 0xB96A5EA0,
+ 0xE1210080, 0xB336FFFE, 0xA0625EA0, 0xFB655F21,
+ 0x9A8000AB, 0xF9695F20, 0xC9685F24, 0x8E35C000,
+ 0x973DC000, 0xF2C8010F, 0xD18B4000, 0xA9970F20,
+ 0xFBC801BB, 0x90605F24, 0x80685FFC, 0xCD210000,
+ 0x24615F2E, 0x7F340003, 0x5F2C012D, 0x30884000,
+ 0x5B200000, 0x3160B122, 0x30800131, 0x4A6BB124,
+ 0x5C695F22, 0x1B200000, 0x3B370001, 0x4ECC0137,
+ 0x3C65B123, 0x70800131, 0x5C800124, 0x1A800127,
+ 0x7B9700FB, 0x2868B122, 0x3D69B124, 0x7734001F,
+ 0x34310001, 0x6C110000, 0x62D401B1, 0x216B5FFC,
+ 0x0E645F20, 0x4537FF00, 0x67330008, 0x180B0000,
+ 0x4EC001AE, 0x3E6A5F24, 0x3F215F26, 0x462E0040,
+ 0x29408000, 0x7930FFFB, 0x4E2C4000, 0x0F970FDD,
+ 0x7A695F26, 0x1B2C000C, 0x29350003, 0x49CC01AA,
+ 0x7F215F26, 0x1122FFFE, 0x21970FF3, 0x5F695F24,
+ 0x1C2C0004, 0x524A0000, 0x422D0042, 0x3F424000,
+ 0x6E2E0001, 0x0B420000, 0x26971027, 0x64970C53,
+ 0x2C685F26, 0x7E695F28, 0x5B60B408, 0x2861B40A,
+ 0x09685F24, 0x5221B40E, 0x7D60B40C, 0x30510000,
+ 0x52200021, 0x3A60B404, 0x10200040, 0x5360B414,
+ 0x91200164, 0xC7210152, 0xFF2300A6, 0xA9800C7A,
+ 0xEF685F20, 0xB86A5FE8, 0xBA3400FF, 0xD3605F22,
+ 0xEE2E0001, 0xA1625FE8, 0x81030000, 0xF930FFFB,
+ 0xA72C4010, 0xD24A0000, 0xDC2C0004, 0xB3490000,
+ 0xD63B0400, 0x8F2D0001, 0xBA0A4000, 0xF9C40175,
+ 0x8D210000, 0xEA410000, 0xC9685F24, 0xB563B120,
+ 0xBE2C0038, 0xE6500000, 0xE6500000, 0xA6500000,
+ 0xE6500000, 0x802CFFF6, 0x924A0000, 0xE22CFFCA,
+ 0x0A6B5F2E, 0x5B368000, 0x63CC018A, 0x393B0000,
+ 0x50C801A6, 0x392F003C, 0x1D40C000, 0x46685F30,
+ 0x50605F24, 0x158001A6, 0x32605F2E, 0x793B0000,
+ 0x26CC018F, 0x5F605F30, 0x76800191, 0x392F003C,
+ 0x5D40C000, 0x39695F20, 0x2B68B124, 0x4F220001,
+ 0x3A230000, 0x6C3500FF, 0x6C0B4000, 0x2C12C000,
+ 0x17148000, 0x4FCC019F, 0x5A9700F7, 0x11230191,
+ 0x71635F24, 0x10200040, 0x198001B4, 0x69970F20,
+ 0x9EC801B9, 0xD0605F24, 0xEF685F20, 0xBE6A5F24,
+ 0xFA3400FF, 0x9780013E, 0xBA215FDA, 0xE4970F39,
+ 0xDE2301B3, 0xB78001C0, 0xAF685F20, 0xFF9700F5,
+ 0xBA3400FF, 0xF18001AF, 0xFB9700FB, 0xB7380400,
+ 0xD460B120, 0x89685F24, 0x86970F33, 0xDB200000,
+ 0xB96A5EA0, 0xED645F21, 0xCC3A0001, 0xA0625EA0,
+ 0x988000A6, 0xD523019F, 0xDE8001BC, 0x9F23011B,
+ 0xF1635F24, 0xBC2000C0, 0xAD645F21, 0xD88000A6,
+ 0xB5695F32, 0xCE208000, 0xD4150000, 0xB7C801C5,
+ 0xD18B4000, 0xBA605F32, 0xB62001C8, 0xDA8000AB,
+ 0xCC685FD8, 0x9F215FD8, 0x98380000, 0xDAC801ED,
+ 0xA0970F5B, 0xF9605F34, 0xF6010000, 0x9F2C0034,
+ 0xE5480000, 0x9E6A5FEC, 0x81030000, 0xDE34000F,
+ 0xAE2E0001, 0xC7625FEC, 0xEC220000, 0x8A625F3A,
+ 0xBA62013E, 0xC6330004, 0xFF37000F, 0x9A2F01DD,
+ 0xD18B4000, 0xB48003B5, 0x9B80053F, 0xF08006DD,
+ 0x138006EA, 0x53800200, 0x53800200, 0x13800200,
+ 0x53800200, 0x13800200, 0x13800200, 0x53800200,
+ 0x53800200, 0x13800200, 0x13800200, 0x4B800BC6,
+ 0x13800200, 0x79605F34, 0x7A605F32, 0x188000A6,
+ 0x682200C1, 0x15800203, 0x2C2200A3, 0x55800203,
+ 0x2722008F, 0x55800203, 0x45220085, 0x15800203,
+ 0x0B2200C0, 0x55800203, 0x6A2200A0, 0x15800203,
+ 0x492200A1, 0x15800203, 0x23220081, 0x55800203,
+ 0xA0220087, 0xD5800203, 0xEC220000, 0xA3685F32,
+ 0xEF625F38, 0xB3230208, 0x8B341000, 0xE8CC02A0,
+ 0xFB97035E, 0xA0685F34, 0xB66A5F38, 0xDA230218,
+ 0xBC2C0035, 0xF3460000, 0xF6695F34, 0x9D800273,
+ 0xE860013C, 0xB5635F46, 0xBB97035E, 0xF9200215,
+ 0x9C605F36, 0xDE970393, 0xC9CC0263, 0x90970236,
+ 0x856A010C, 0xFA680110, 0xFE2A01A0, 0xB5C801C8,
+ 0xD8380000, 0x8DCC01C8, 0x94620110, 0xE7970C63,
+ 0x0D6A0110, 0x4C20B424, 0x6C500011, 0x05500001,
+ 0x6850C400, 0x05500001, 0x2D5001A0, 0x66500000,
+ 0x4E62B434, 0x0821022C, 0x172301C8, 0x6B940C7D,
+ 0x3E6B0112, 0x672201A0, 0x5C62010C, 0x1B200000,
+ 0x4D6A0110, 0x06600112, 0x23600110, 0x793B0000,
+ 0x0ACC0385, 0x588000A6, 0x79635F38, 0x201A4000,
+ 0x0262B140, 0x6F6B5EA0, 0x57020000, 0x1F3B0004,
+ 0x76635EA0, 0x0D388000, 0x3A605F32, 0x75008000,
+ 0x07300003, 0x75605F4A, 0x75008000, 0x3F30FFF8,
+ 0x4F384001, 0x36605F4C, 0x2832FFFF, 0x5D2E0D06,
+ 0x5D23024A, 0x078A4000, 0x13605F4E, 0x456A010C,
+ 0x102001A0, 0x4D210000, 0x4E0A0000, 0x26970DE4,
+ 0x6B970E02, 0x026B5F32, 0x0A685F4E, 0x7F37000F,
+ 0x343B0100, 0x576A5F34, 0x7263B144, 0x0B420000,
+ 0x1B695F46, 0x5F2C0002, 0x6A410000, 0x136A5F3A,
+ 0x5F2C0002, 0x0B420000, 0x31695F3C, 0x606B5F38,
+ 0x9F2C0002, 0xEA410000, 0xD18B4000, 0xBA20C000,
+ 0xFA605F32, 0xAE970C74, 0xA7220040, 0xCC20B424,
+ 0xEC500011, 0xA0500003, 0xA850C400, 0xC5500001,
+ 0x87500180, 0xE6500000, 0xCE62B434, 0x9E2000A6,
+ 0xC82100A6, 0xBF2300A6, 0x89800C7D, 0xD4635E9C,
+ 0xAD6B5FEE, 0xC5615E98, 0xEC2D0036, 0x91484000,
+ 0xB82F0001, 0xF4635FEE, 0xC0349FFF, 0x88404000,
+ 0xEC348000, 0xB9C80286, 0x912DFFFE, 0xE64A4000,
+ 0x2B2D0008, 0x51484000, 0x41625E9A, 0x30510000,
+ 0x58380000, 0x32C8029C, 0x10605E9E, 0x4A685E98,
+ 0x79215FDC, 0x2A970F4A, 0x21970E86, 0x49685E9E,
+ 0x0D6B5E9C, 0x58380000, 0x6BCC0290, 0x118B4000,
+ 0x586A5E9A, 0x1F215FD8, 0x1336FF00, 0x70D00297,
+ 0x2A970F4A, 0x4D6B5E9C, 0x778001C0, 0x31320008,
+ 0x3C2C0035, 0x73460000, 0x5F695E9E, 0x3D800274,
+ 0x7C9700F3, 0x3C209000, 0x3A605F32, 0x4480101D,
+ 0x8E208000, 0xFA605F32, 0xE480102C, 0xBD635F36,
+ 0xEC685F4A, 0xB9695F4C, 0x8B32FFFE, 0xCD048000,
+ 0xF0C402AB, 0x8F2D0001, 0xA0615F4C, 0xF5605F4A,
+ 0x93320002, 0xE4685F3A, 0xD88002B9, 0xBD635F36,
+ 0xD8380000, 0xBCD002B3, 0x99970354, 0xE4685F3A,
+ 0x8E390000, 0xDDC802B9, 0xE4300002, 0x88404000,
+ 0xBC30FFFE, 0xF6010000, 0xE72D01A0, 0x9F610106,
+ 0xCB32FFFE, 0x9CC80352, 0x94038000, 0xC3330001,
+ 0xAFD402C2, 0xEB2E0004, 0xD40C8000, 0xBD605F3A,
+ 0xD4038000, 0xBF37000F, 0x95C802C9, 0xF736FFF0,
+ 0xE42E0010, 0xAF6B5F40, 0xAC625F3E, 0xCD0B8000,
+ 0x94C402CE, 0xE0625F40, 0xDC6A5F42, 0x9B200000,
+ 0xE93600C0, 0xB5320006, 0x9BC802D6, 0xF12C0040,
+ 0x932EFFFF, 0xF88002D2, 0xEC600104, 0x85970CA6,
+ 0x9E2000A6, 0xE1970CAF, 0xEC970CB6, 0xA7970C63,
+ 0xE3690104, 0xB5680104, 0xAF2D0030, 0xE64A4000,
+ 0x092D0002, 0x704B4000, 0x493EFFFF, 0x0D1EC000,
+ 0x6CCC0322, 0x1A21B424, 0x18510041, 0x7160B428,
+ 0x4A2D0004, 0x30510000, 0x3851C010, 0x53510001,
+ 0x28220038, 0x4E62B434, 0x4C2102DB, 0x3F2300A6,
+ 0x6B940C7D, 0x3920003C, 0x3C60B348, 0x64970C53,
+ 0x27970C63, 0x50680106, 0x7B21B428, 0x356A5F3E,
+ 0x2A6B5FD0, 0x4251E000, 0x53510001, 0x1760B42C,
+ 0x492D0002, 0x30510000, 0x12200311, 0x5763B420,
+ 0x1060B424, 0x4E62B434, 0x6C685F4A, 0x39695F4C,
+ 0x5B60B408, 0x2861B40A, 0x226B5FCC, 0x7721B40C,
+ 0x4251E000, 0x13510001, 0x2B201061, 0x7D63B400,
+ 0x3A60B404, 0x6462B414, 0x5D200003, 0x3E605F50,
+ 0x7020031B, 0x21210325, 0x0A970C7D, 0x7F2300A6,
+ 0x0B940C7A, 0x67685F50, 0x4434FFFE, 0x3E605F50,
+ 0x18380000, 0x71C80320, 0x588000A6, 0x27685F50,
+ 0x4234FFFD, 0x3E605F50, 0x18380000, 0x65CC00A6,
+ 0xA46B5F36, 0xEE800CBD, 0xEA970C83, 0xB62301F2,
+ 0xEE800CBD, 0xBB2302DB, 0xA9800C83, 0xFD635F36,
+ 0xD8380000, 0xB3D0032B, 0x99970354, 0xE4685F3A,
+ 0x8E390000, 0xFBC80331, 0xE4300002, 0x88404000,
+ 0xFC30FFFE, 0xB6010000, 0xA72D01A0, 0xDF610106,
+ 0x8B32FFFE, 0xDCC80352, 0xEF6B5F40, 0xAC625F3E,
+ 0x8D0B8000, 0xF8C4033B, 0xE0625F40, 0x94038000,
+ 0xE6330003, 0x84D4033F, 0xAB2E0004, 0xD40C8000,
+ 0xBD605F3A, 0xE4970C53, 0xEC685F4A, 0xB9695F4C,
+ 0xDB60B408, 0xA861B40A, 0x90680106, 0xF56A5F3E,
+ 0xD221B40E, 0xB0510000, 0xBD60B40C, 0xD2200021,
+ 0xBA60B404, 0xE462B414, 0xC5685F36, 0xA6210341,
+ 0xFF2300A6, 0xA9800C7A, 0xA46B5F36, 0xF88000FB,
+ 0xB5635E90, 0xC16B5F34, 0xE00CC000, 0x844B0000,
+ 0x9F2C0002, 0xE5480000, 0xD4635F4A, 0xAC6B5E90,
+ 0xF6605F4C, 0x918B4000, 0xB96A5F40, 0xDB200000,
+ 0x17605F40, 0x6F3A0000, 0x7ECC0C95, 0x118B4000,
+ 0x4520FFFF, 0x2C2D0036, 0x264A4000, 0x772DFFFA,
+ 0x45625F42, 0x1D34003F, 0x17148000, 0x6CCC01F2,
+ 0x118B4000, 0x664A4000, 0x492D0002, 0x273607FC,
+ 0x57C801F4, 0x13320002, 0x2C088000, 0x4EC001F4,
+ 0x35008000, 0x62300001, 0x6FD40378, 0x2E2E0001,
+ 0x1F30FFFF, 0x518B4000, 0x76635E96, 0x33200102,
+ 0x7E97036D, 0x09600130, 0x06625F44, 0x73200102,
+ 0xBE97036D, 0xEF6B5E96, 0xEF600134, 0xA3625F46,
+ 0xD18B4000, 0xA469010C, 0x9768010E, 0xFD3D01A0,
+ 0xE6CC0390, 0x862E01A0, 0x9C62010C, 0xD8380000,
+ 0x90C8038F, 0xEC088000, 0xE8C001F0, 0x918B4000,
+ 0xD4620110, 0xA7630112, 0x988000A6, 0xD3680100,
+ 0xB6635E96, 0xDB6AB140, 0xEE210001, 0xBA230000,
+ 0xA1280001, 0xD80B0000, 0xCD11C000, 0x94038000,
+ 0xD7174000, 0xBEC803A1, 0xB4310001, 0xE1280001,
+ 0x3EC4039B, 0x6F6B5E96, 0x518B4000, 0x36635E96,
+ 0x6C220000, 0x05625E94, 0x0D6BB140, 0x45690100,
+ 0x78200001, 0x3602C000, 0x35160000, 0x5C6A5E94,
+ 0x02CC03AF, 0x6E2E0001, 0x45625E94, 0x1F30FFFF,
+ 0x722DFFFF, 0x01CC03A9, 0x2F6B5E96, 0x5C6A5E94,
+ 0x118B4000, 0x64625F4E, 0x512C03B8, 0x30884000,
+ 0x13800200, 0x7E8003C8, 0x5C800442, 0x3C800445,
+ 0x56800465, 0x1D800486, 0x3E8004EB, 0x7B8004EE,
+ 0x1B800509, 0x5E80050C, 0x7780052A, 0x13800200,
+ 0x53800200, 0x13800200, 0x13800200, 0x53800200,
+ 0x54230018, 0x0963013C, 0x1A970364, 0x7797037A,
+ 0x276A0130, 0x41030000, 0x4D0B8000, 0x2FC003D1,
+ 0x57020000, 0x106B013C, 0x28685F44, 0x5B695F46,
+ 0x32370020, 0x4DCC03D7, 0x6E2E0001, 0x09625F3C,
+ 0x360E0000, 0x420E4000, 0x4B32FFFE, 0x34970385,
+ 0x5797029D, 0x1B200000, 0x2A210120, 0x5F6A5F44,
+ 0x97970327, 0xDC200008, 0xCC210124, 0xBA6A5F46,
+ 0xD7970327, 0x969702A0, 0xA4685F3A, 0xE4210010,
+ 0xE4300002, 0xA7600128, 0xBA610104, 0xFB97035E,
+ 0xA6970CCB, 0xD0680130, 0xE0690134, 0x8E6A0120,
+ 0xFE6B0124, 0x9A60B010, 0xAA61B014, 0xFE680128,
+ 0x8E69012C, 0xEB2E0068, 0xC462B000, 0xBD2F0068,
+ 0xB463B004, 0xE06A0138, 0xDC2C0068, 0xB460B008,
+ 0xCA2D0068, 0x8461B00C, 0xAA62B018, 0xF168013C,
+ 0xBF2300A6, 0xCD388000, 0xFB60B01C, 0xAF940CD0,
+ 0xCA685F4E, 0x976A5F34, 0x98380000, 0xF5C8040D,
+ 0xF0884000, 0x8E208000, 0xA9408000, 0xDB200000,
+ 0xBF800419, 0xE4685F3A, 0xF069B024, 0xA02E0028,
+ 0xCE390000, 0x90D00409, 0xA4300002, 0xDC2C0068,
+ 0xAF090000, 0xEA31FFFE, 0xC768B028, 0xBF418000,
+ 0xB734001F, 0xE82E0002, 0xE9408000, 0xB5008000,
+ 0xDF2C0002, 0xA6500000, 0xA6500000, 0xC9970CD8,
+ 0x106A5F3C, 0x60685F34, 0x4B32FFFE, 0x33C80202,
+ 0x546B0104, 0x32695F3A, 0x09625F3C, 0x60625F40,
+ 0x600CC000, 0x272D01A0, 0x3A610104, 0x73490000,
+ 0x1F2C0002, 0x65480000, 0x63615F4A, 0x36605F4C,
+ 0x64970C53, 0x2C685F4A, 0x39695F4C, 0x7D60B40C,
+ 0x0E61B40E, 0x75680104, 0x4D210000, 0x2861B40A,
+ 0x1B60B408, 0x506A5F3C, 0x54200081, 0x3A60B404,
+ 0x6462B414, 0x21210430, 0x3F2300A6, 0x4B940C7A,
+ 0x11230202, 0x7880035E, 0x57230028, 0x0963013C,
+ 0x5B8003CA, 0x1A970364, 0x33200102, 0x7E97036D,
+ 0x49600130, 0x06625F44, 0x192C0001, 0x7E605F3C,
+ 0x2E32FFFC, 0x6B2E0004, 0x74970385, 0x1797029D,
+ 0x5B200000, 0x2A210120, 0x1F6A5F44, 0x57970327,
+ 0x1F6A5F44, 0x5C200008, 0x4C210124, 0x17970327,
+ 0x1F6A5F44, 0x72200010, 0x6D210128, 0x17970327,
+ 0x569702A0, 0x24685F3A, 0x23210018, 0x64300002,
+ 0x8160012C, 0xFA610104, 0xD823000A, 0x8963013C,
+ 0xD28003EB, 0x9A970364, 0xB797037A, 0xE8685F44,
+ 0xF60E0000, 0x8B32FFFE, 0xB4970385, 0xD797029D,
+ 0x9B200000, 0xEA210120, 0xDF6A5F44, 0x97970327,
+ 0xFA6A5F46, 0x9C200008, 0x8C210124, 0xD7970327,
+ 0x969702A0, 0xE4685F3A, 0xE76A0130, 0x976B0134,
+ 0xA4300002, 0xE7600128, 0xD70EC000, 0x8B32FFFE,
+ 0xC9625F3C, 0xAA208009, 0xB9970210, 0xC1970D7E,
+ 0x1F680148, 0x61970E49, 0x4D210000, 0x316A5F5C,
+ 0x72200010, 0x2F800E66, 0x03208100, 0x6860013C,
+ 0x5A970364, 0x3797037A, 0x316B0130, 0x7E695F44,
+ 0x180B0000, 0x4EC001F4, 0x4434FFFE, 0x17C801F4,
+ 0x420E4000, 0x0B32FFFE, 0x34970385, 0x5797029D,
+ 0x1B200000, 0x6A210120, 0x5F6A5F44, 0x17970327,
+ 0x3A6A5F46, 0x5C200008, 0x4C210124, 0x17970327,
+ 0x569702A0, 0x016A0134, 0x09690124, 0x532EFFFF,
+ 0x820D8000, 0xEA31FFFE, 0xE72D01A0, 0xA64A4000,
+ 0xC92D0002, 0x87494000, 0xB168013C, 0xE01A4000,
+ 0xD3C801FA, 0xB2695F3A, 0x816A0134, 0xF2310002,
+ 0xB1610128, 0xF4340100, 0xFAC804BA, 0xB16B0130,
+ 0xF5008000, 0x8D0B8000, 0xB82F0001, 0xEE2E0001,
+ 0xA2300001, 0xFBD004B7, 0xEE2E0001, 0x820D8000,
+ 0x9761012C, 0xD70EC000, 0xCB32FFFE, 0x89625F3C,
+ 0xF168013C, 0xB9970210, 0x81970D7E, 0xC669015C,
+ 0xB968014C, 0xE2350100, 0xDCC804E4, 0xA1970E49,
+ 0xD1520000, 0xAB2E0004, 0xA3690168, 0xDF680148,
+ 0xCE390000, 0x91D004CD, 0xAF090000, 0xEA31FFFE,
+ 0x918004CE, 0xD8218000, 0xC2685F52, 0x952EFFFC,
+ 0xFF418000, 0xAA381000, 0x9B605F52, 0xC797101D,
+ 0xA06A0154, 0xD068015C, 0xCD210000, 0x8B32FFFE,
+ 0xB4340100, 0xF2200010, 0xFCC804E3, 0x8F970E67,
+ 0xDF680148, 0xAF69014C, 0xB16A5F5C, 0xEF090000,
+ 0x2A31FFFE, 0x7A0A4000, 0x75200018, 0x2F800E66,
+ 0x576A5F58, 0x202E0028, 0x11520000, 0x51520000,
+ 0x51520000, 0x11520000, 0x168004C6, 0x40208200,
+ 0x2860013C, 0x59800488, 0x70200088, 0x2860013C,
+ 0x5A970364, 0x21361F00, 0x31320008, 0x79620138,
+ 0x33200102, 0x7E97036D, 0x49600130, 0x366B0138,
+ 0x06625F44, 0x793B0000, 0x506B013C, 0x29CC04FD,
+ 0x7F800500, 0x13370040, 0x02CC0500, 0x592C0001,
+ 0x3E605F3C, 0x760E0000, 0x4B32FFFE, 0x34970385,
+ 0x5B200000, 0x2A210120, 0x1F6A5F44, 0x772303E6,
+ 0x54800327, 0x17200048, 0x2860013C, 0x568004F0,
+ 0x1A970364, 0x73200102, 0x7E97036D, 0x09600130,
+ 0x46625F44, 0x0D32FFFD, 0x34970385, 0x5797029D,
+ 0x1B200000, 0x6A210120, 0x5F6A5F44, 0x17970327,
+ 0x1F6A5F44, 0x5C200008, 0x4C210124, 0x17970327,
+ 0x569702A0, 0x36200522, 0x13605F4E, 0x55230400,
+ 0x8963013C, 0xD28003EB, 0xD669B020, 0xA02E0028,
+ 0xD1520000, 0x91520000, 0x91520000, 0xFF418000,
+ 0xD1230202, 0x8A800CD8, 0x9A970364, 0xD52001FF,
+ 0xBE97036D, 0xC9600130, 0xFE605F3C, 0x97020000,
+ 0xC6625F44, 0x8B32FFFE, 0xB4970385, 0xDB200000,
+ 0xAA210120, 0xDF6A5F44, 0xD7970327, 0x9B200000,
+ 0xBD605F3A, 0xE7600128, 0xE4210010, 0xBA610104,
+ 0xCC230808, 0x8963013C, 0x928003EB, 0xC1030000,
+ 0xA637FFF8, 0xEECC0200, 0xF52C0544, 0xB0884000,
+ 0xD580054C, 0xBC800593, 0x9A800604, 0xD3800200,
+ 0xD780061D, 0xB380064E, 0x93800200, 0xD3800200,
+ 0x8320FFFC, 0xF9970365, 0xE1361F00, 0xB2C801F6,
+ 0xF1320008, 0xB9620138, 0xBF2A0011, 0xD3C401F6,
+ 0xB797037A, 0xE2300001, 0xDCD00558, 0xA82E0002,
+ 0xB2347FFF, 0xD7C801F4, 0xD7680138, 0xA3625F46,
+ 0xF6010000, 0x92290003, 0xBAC40560, 0xDD200003,
+ 0x3C2C0003, 0x63018000, 0x6A072000, 0x393B0000,
+ 0x4ECC01F8, 0x3E695F44, 0x242E0010, 0x420E4000,
+ 0x442A0800, 0x3A6A5F46, 0x17C401F8, 0x6832FFFF,
+ 0x020E4000, 0x4B32FFFE, 0x74970385, 0x1797029D,
+ 0x5B200000, 0x2A210120, 0x0A6B5F42, 0x5F6A5F44,
+ 0x03330001, 0x76D00578, 0x74230579, 0x14800327,
+ 0x319702AF, 0x4A6B5F42, 0x5C200008, 0x0C210124,
+ 0x7A6A5F46, 0x05330002, 0x36D00581, 0x51230582,
+ 0x94800327, 0xF19702AF, 0xC56B5F3A, 0xBA6A5F46,
+ 0xED210128, 0xB5635F46, 0xB2200010, 0xD7970327,
+ 0xD69702A0, 0xAC6B5F46, 0xBE680128, 0xC16A0134,
+ 0x8160012C, 0xCB32FFFE, 0xDC635F3A, 0x89625F3C,
+ 0xE920E000, 0xBE2305FD, 0xBA800210, 0xE520FFF8,
+ 0xB9970365, 0xE1361F00, 0xF2C801F6, 0xB1320008,
+ 0xB9620138, 0xFF2A0011, 0xD3C401F6, 0x92200082,
+ 0xFE97036D, 0x89600130, 0x86625F44, 0xD2200082,
+ 0x3E97036D, 0x6F600134, 0x62300001, 0x3AD005A5,
+ 0x682E0002, 0x32347FFF, 0x17C801F4, 0x57680138,
+ 0x63625F46, 0x36010000, 0x12290003, 0x5FC405AD,
+ 0x1D200003, 0x792C0006, 0x63018000, 0x2A072000,
+ 0x793B0000, 0x0ECC01F8, 0x3E695F44, 0x76680134,
+ 0x242E0010, 0x4931FFFF, 0x420E4000, 0x042A0800,
+ 0x17C401F8, 0x57020000, 0x4B32FFFE, 0x360E0000,
+ 0x420E4000, 0x082E0005, 0x0B32FFFE, 0x74970385,
+ 0x1797029D, 0x5B200000, 0x6A210120, 0x0A6B5F42,
+ 0x5F6A5F44, 0x03330001, 0x3CD005CA, 0x6832FFFF,
+ 0x7D2305CD, 0x14800327, 0x319702AF, 0x5F6A5F44,
+ 0x109702A3, 0x4A6B5F42, 0x5C200008, 0x0C210124,
+ 0x7A6A5F46, 0x05330002, 0x34D005D6, 0x6832FFFF,
+ 0x322305D9, 0x54800327, 0x719702AF, 0x3A6A5F46,
+ 0x109702A3, 0x49690124, 0x7A6A5F46, 0x2A31FFFE,
+ 0x672D01A0, 0x11484000, 0x0B32FFFE, 0x420D8000,
+ 0xB04B4000, 0xDA340001, 0xF5C801FE, 0xBB370001,
+ 0xF5C801FE, 0x816A0134, 0xB2200010, 0xCA6B5F42,
+ 0xED210128, 0xA6330003, 0xB6D005ED, 0xD12305EE,
+ 0x94800327, 0xF19702AF, 0xE4685F3A, 0x816A0134,
+ 0xD3605F4E, 0xB6200028, 0x8B21012C, 0xE832FFFF,
+ 0x97970327, 0xD69702A0, 0xCA685F4E, 0x816A0134,
+ 0xBD605F3A, 0xFC209000, 0xCD32FFFD, 0x89625F3C,
+ 0xF9970210, 0x81970D7E, 0xB968014C, 0xE1970E49,
+ 0x0D210000, 0x716A5F5C, 0x75200018, 0x2F800E66,
+ 0x5A970364, 0x3797037A, 0x096B5F44, 0x570EC000,
+ 0x4B32FFFE, 0x34970385, 0x1797029D, 0x5B200000,
+ 0x2A210120, 0x5F6A5F44, 0x57970327, 0x1C200008,
+ 0x4C210124, 0x3A6A5F46, 0x17970327, 0x569702A0,
+ 0x056B5F3A, 0x416A0134, 0x45330002, 0x2063012C,
+ 0x0B32FFFE, 0x49625F3C, 0x5B20F000, 0x3E2305FD,
+ 0x7A800210, 0x0620FFF9, 0x39970365, 0x45625F42,
+ 0x892D0002, 0xF5200018, 0xFE97036D, 0xAF600134,
+ 0xC434FFFE, 0x97C801F4, 0xA82E0002, 0xE3625F46,
+ 0xF420013C, 0xB3508000, 0x85500001, 0xF1290002,
+ 0x91484000, 0xD4038000, 0xCD32FFFD, 0x970EC000,
+ 0xFF340003, 0x90605F48, 0x8B32FFFE, 0xF4970385,
+ 0x9797029D, 0xFA6A5F46, 0xE86B5F48, 0xB5008000,
+ 0xA832FFFF, 0xFB370001, 0xDBC8063C, 0xB60E0000,
+ 0xEA210120, 0x9B200000, 0x97970327, 0xE86B5F48,
+ 0xBA6A5F46, 0xFB370001, 0xCCCC0675, 0x96230675,
+ 0xE4685F3A, 0x9701C000, 0xB12C01A0, 0xC5500001,
+ 0xCB32FFFE, 0x902A0002, 0xAF970F80, 0xC92801A0,
+ 0xBD605F3A, 0xE6894000, 0xE520FFF8, 0xB9970365,
+ 0xC5625F42, 0xB5200018, 0xBE97036D, 0xC9600130,
+ 0x86625F44, 0xF5200018, 0xFE97036D, 0xAF600134,
+ 0x8434FFFE, 0xD7C801F4, 0xE82E0002, 0xA3625F46,
+ 0xF420013C, 0x81509000, 0x85500001, 0xF1290002,
+ 0x11484000, 0x7E695F44, 0x5C340002, 0x10605F48,
+ 0x6832FFFF, 0x14038000, 0x170EC000, 0x570EC000,
+ 0x420E4000, 0x0B32FFFE, 0x34970385, 0x5797029D,
+ 0x1B200000, 0x6A210120, 0x4A6B5F42, 0x1F6A5F44,
+ 0x43330001, 0x14D00674, 0x16230675, 0x54800327,
+ 0x319702AF, 0x4A6B5F42, 0x7A6A5F46, 0x1C200008,
+ 0x05330002, 0x56D00680, 0x63018000, 0x2832FFFF,
+ 0x420E4000, 0x0C210124, 0x34230686, 0x54800327,
+ 0x8C210124, 0xF19702AF, 0xFA6A5F46, 0x909702A3,
+ 0xFA6A5F46, 0x909702A3, 0x8A6B5F42, 0xFA6A5F46,
+ 0xED210128, 0xA6330003, 0xBED006AD, 0xE86B5F48,
+ 0xB5008000, 0xE832FFFF, 0xFB370001, 0x9FC80691,
+ 0xF60E0000, 0xB2200010, 0x97970327, 0xE86B5F48,
+ 0xBA6A5F46, 0xFB370001, 0xEDCC06B6, 0xA769013C,
+ 0xA0685F34, 0xFA6A5F46, 0xD13D9000, 0x86CC06AB,
+ 0xD72C0028, 0x844B0000, 0x9F2C0002, 0xF3490000,
+ 0x1F2C0002, 0x761B4000, 0x73490000, 0x1F2C0002,
+ 0x761B4000, 0x33490000, 0x36200028, 0x761B4000,
+ 0x7EC806AB, 0x372306B6, 0x14800327, 0x772306B6,
+ 0x11800644, 0x72200010, 0x719702AF, 0x3A6A5F46,
+ 0x509702A3, 0x286B5F48, 0x3A6A5F46, 0x7B370001,
+ 0x1CC80697, 0x509702A3, 0x569702A0, 0x3E6A5F48,
+ 0x24685F3A, 0x6B360002, 0x5EC806C0, 0x3A6A5F46,
+ 0x60690134, 0x2832FFFF, 0x020E4000, 0x4B32FFFE,
+ 0x09625F3C, 0x64300002, 0x4160012C, 0x3168013C,
+ 0x79970210, 0x36695F58, 0x0A2D0032, 0x51484000,
+ 0x5C340002, 0x0CCC06D6, 0x206A0154, 0x5D20A000,
+ 0x14038000, 0x43330001, 0x4CD406D0, 0x2E2E0001,
+ 0x682E0002, 0x3E33FFFF, 0x170EC000, 0x4B32FFFE,
+ 0x28625F5C, 0x4E970D6A, 0x41970D7E, 0x3968014C,
+ 0x21970E49, 0x4D210000, 0x716A5F5C, 0x35200018,
+ 0x6F800E66, 0x01030000, 0x2637FFF8, 0x6ECC0200,
+ 0xB32C06E2, 0xF0884000, 0xF38006ED, 0x978007A7,
+ 0xE38009AE, 0xAE800A87, 0x93800200, 0xD78007A7,
+ 0xD3800200, 0xAE800A87, 0x98380000, 0xEECC0200,
+ 0x8D800BC5, 0xC320FFFC, 0xF9970365, 0x892D0002,
+ 0xF5200018, 0xBE97036D, 0x89600130, 0xEF600134,
+ 0x8434FFFE, 0xD7C801F4, 0xE82E0002, 0xB1290002,
+ 0x91484000, 0xE3625F46, 0xDA340001, 0x90605F48,
+ 0xF5008000, 0xBA30FFFD, 0xB60E0000, 0xF60E0000,
+ 0x8B32FFFE, 0xF4970385, 0xD797029D, 0x9B200000,
+ 0xEA210120, 0x8A6B5F42, 0xBA6A5F46, 0xC3330001,
+ 0xF6D0070B, 0xB723070C, 0x94800327, 0xF19702AF,
+ 0xA897097D, 0xFA6A5F46, 0xF6200028, 0x8D210000,
+ 0xD7970327, 0x969702A0, 0x8D685F46, 0xDB695F46,
+ 0xBA30FFFD, 0xF50C4000, 0xE0600120, 0xAA31FFFE,
+ 0x90610124, 0xC16A0134, 0xFC30FFFE, 0xB12C01A0,
+ 0xE832FFFF, 0x8D210000, 0x844B0000, 0xDF2C0002,
+ 0x1419C000, 0x532EFFFF, 0x61CC071E, 0x1235FFFE,
+ 0x50C801FC, 0x26970CCB, 0x20690134, 0x4E6A0120,
+ 0x7E6B0124, 0x21208400, 0x2B2E0068, 0x7D2F0068,
+ 0x0C61B010, 0x4462B000, 0x7463B004, 0x3B60B01C,
+ 0x7F2300A6, 0x2F940CD0, 0x1669B020, 0x72310002,
+ 0x14D00737, 0x49970CD8, 0x558001FC, 0x09970CD8,
+ 0x0D685F46, 0x6C220000, 0x46600124, 0x36010000,
+ 0x6A31FFFE, 0x170D0000, 0x31610128, 0x630D4000,
+ 0x170D0000, 0x5761012C, 0x49625F3C, 0x38200001,
+ 0x4D60013E, 0x3C209000, 0x39970210, 0x5D20A000,
+ 0x4E970D6A, 0x14680164, 0x286A0148, 0x58380000,
+ 0x20D00E47, 0x6F69014C, 0x630E8000, 0x17610140,
+ 0x71620148, 0x3A098000, 0x3661014C, 0x6A31FFFE,
+ 0x31610144, 0x40208200, 0x4D970D6C, 0x35680168,
+ 0x0E6A014C, 0x58380000, 0x60D00E47, 0x09690148,
+ 0x71620148, 0x3A098000, 0x17610140, 0x7A098000,
+ 0x8B32FFFE, 0xC20D8000, 0xF661014C, 0x9B20F000,
+ 0xCD970D6C, 0x9F680148, 0x8E690140, 0xEC220000,
+ 0xD0620144, 0xA060014C, 0x970D0000, 0xD7610140,
+ 0x9930FFFC, 0xC6600148, 0xED208001, 0x8D970D6C,
+ 0xE86A0148, 0xB968014C, 0xB66B0154, 0xF6620140,
+ 0xB6010000, 0xFA30FFFD, 0xE7600144, 0xA2300001,
+ 0x8E0A0000, 0xC20D8000, 0xD0610148, 0x810FC000,
+ 0xC9630150, 0xA7208010, 0x8D970D6C, 0xD4680164,
+ 0x0E690140, 0x58380000, 0x60D00E47, 0x286A0148,
+ 0x7968014C, 0x106B0150, 0x10610148, 0x76620140,
+ 0x782F0001, 0x09630150, 0x0E0A0000, 0x50620144,
+ 0x2D208001, 0x4D970D6C, 0x466A0150, 0x366B0154,
+ 0x7968014C, 0x09690148, 0x170EC000, 0x5F620150,
+ 0x096A0144, 0x57610140, 0x4E0A0000, 0x31620148,
+ 0x200F0000, 0x5D33FFFE, 0x7E635F5C, 0x3C30FFFE,
+ 0x67600144, 0x00208200, 0x0D970D6C, 0x41970D7E,
+ 0xA3690168, 0xF16A5F5C, 0xCE390000, 0xA0D00E47,
+ 0xE8970E5E, 0xB5200018, 0xAF800E66, 0xE020FFFD,
+ 0xF9970365, 0x892D0002, 0xB5200018, 0xFE97036D,
+ 0x89600130, 0xEF600134, 0xC434FFFE, 0x97C801F4,
+ 0xE82E0002, 0xB1290002, 0x91484000, 0xE3625F46,
+ 0x9C340002, 0xD0605F48, 0xF5008000, 0xA3018000,
+ 0xBC30FFFE, 0xCD32FFFD, 0xF60E0000, 0x820E4000,
+ 0xCB32FFFE, 0xB4970385, 0x9797029D, 0xE897097D,
+ 0xBA6A5F46, 0xF6200028, 0xCD210000, 0xA832FFFF,
+ 0xD7970327, 0x9B200000, 0xBA6A5F46, 0xCD210000,
+ 0xE832FFFF, 0x97970327, 0x969702A0, 0xFA6A5F46,
+ 0x92970644, 0xDB695F46, 0xCD685F46, 0xAC31FFFD,
+ 0xF6610120, 0xB4310001, 0xAF090000, 0xD0610124,
+ 0xA6970CCB, 0xE0690134, 0xCE6A0120, 0x8C61B010,
+ 0xAB2E0068, 0xC462B000, 0xC362B008, 0xB8208808,
+ 0xFB60B01C, 0xBF2300A6, 0xAF940CD0, 0xF069B024,
+ 0x0E390000, 0x62D00889, 0x49690124, 0x21208400,
+ 0x4A2D0068, 0x0361B004, 0x3B60B01C, 0x7F2300A6,
+ 0x6F940CD0, 0x1669B020, 0x32310002, 0x5AD40889,
+ 0x1B695F46, 0x4E6A0120, 0x78208808, 0x020E4000,
+ 0x57620120, 0x2B2E0068, 0x0462B000, 0x4362B008,
+ 0x3B60B01C, 0x7F2300A6, 0x6F940CD0, 0x3069B024,
+ 0x0E390000, 0x62D00889, 0x61208400, 0x3B60B01C,
+ 0x7F2300A6, 0x2F940CD0, 0x1669B020, 0x72310002,
+ 0x9AD40889, 0xC9970CD8, 0xCD685F46, 0xAF690120,
+ 0xE7600128, 0xBC30FFFE, 0x970D0000, 0xD761012C,
+ 0xDD9703A3, 0xA8615F3C, 0x9B20F000, 0xD02A0002,
+ 0xA5C4088B, 0xDF695F48, 0xCA350002, 0xBCCC088B,
+ 0xF9970210, 0x83970956, 0xA0970961, 0xE06A0154,
+ 0xB968014C, 0xF96B0140, 0xDF620150, 0x89690148,
+ 0xA7630148, 0xD80B0000, 0xC6630144, 0x9F30FFFF,
+ 0xEF090000, 0x97610140, 0xAD208001, 0xCD970D6C,
+ 0x2A970970, 0x7968014C, 0x6F6A0140, 0x09690148,
+ 0x766B0154, 0x0E0A0000, 0x1762014C, 0x5F30FFFF,
+ 0x570D0000, 0x17610140, 0x22300001, 0x570D0000,
+ 0x10610148, 0x5B200000, 0x67600144, 0x09630150,
+ 0x7C209000, 0x0E970D6A, 0x1F680148, 0x4E690140,
+ 0x0E6A014C, 0x4D084000, 0x6060014C, 0x10610148,
+ 0x36620140, 0x76010000, 0x5F30FFFF, 0x170D0000,
+ 0x7E610150, 0x3F208800, 0x0D970D6C, 0x7968014C,
+ 0x2F6A0140, 0x49690148, 0x766B0154, 0x0E0A0000,
+ 0x5762014C, 0x1F30FFFF, 0x2F090000, 0x57610140,
+ 0x7C30FFFE, 0x0E0A0000, 0x31620148, 0x49630150,
+ 0x3C209000, 0x4E970D6A, 0x7968014C, 0x09690148,
+ 0x6F6A0140, 0x06600148, 0x0D084000, 0x54038000,
+ 0x360E0000, 0x5762014C, 0x64300002, 0x200F0000,
+ 0x20630140, 0x4E208000, 0x4E970D6A, 0x1D20A000,
+ 0x4E970D6A, 0x17680154, 0x0E6A014C, 0x76010000,
+ 0xB4310001, 0xF5D40863, 0xD92C0001, 0x9F2C0002,
+ 0xE060014C, 0xB6620140, 0xB6010000, 0xDF30FFFF,
+ 0xF50C4000, 0xA7600144, 0xB6010000, 0xDF30FFFF,
+ 0x970D0000, 0xD0610148, 0xC0208200, 0x8D970D6C,
+ 0xDF680148, 0x986B014C, 0xA06A0154, 0xC1600140,
+ 0xB6010000, 0xFC30FFFE, 0xDC605F5A, 0x8E09C000,
+ 0xB1610144, 0xCB32FFFE, 0xE8625F5C, 0xA1208400,
+ 0xCD970D6C, 0x81970D7E, 0xA8970E5E, 0xC16B5F58,
+ 0x056A0160, 0x7E2F0034, 0x654BC000, 0x0B420000,
+ 0x7E370004, 0x34CC0D3E, 0x316A5F5C, 0x75200018,
+ 0x6F800E66, 0x09970CD8, 0x168001FA, 0x6860013C,
+ 0x3B97035E, 0x61230939, 0x75635F46, 0x0C200891,
+ 0x5C605F36, 0x1E970393, 0x09CC0263, 0x50970236,
+ 0x2E230897, 0x75635F46, 0x7C800213, 0x1F680148,
+ 0x0E6A014C, 0x4E690140, 0x6060014C, 0x10620144,
+ 0x760E0000, 0x1F30FFFF, 0x2F090000, 0x57610140,
+ 0xB1620148, 0xED208001, 0xCD970D6C, 0xAA970970,
+ 0xC9690148, 0xB968014C, 0xAF6A0140, 0xF66B0154,
+ 0xD7610140, 0x8E0A0000, 0x8E0A0000, 0xD762014C,
+ 0xBC30FFFE, 0xC6600148, 0xDB200000, 0xA7600144,
+ 0xC9630150, 0xBC209000, 0x8E970D6A, 0xF968014C,
+ 0x89690148, 0xEF6A0140, 0xC6600148, 0x8D084000,
+ 0xA4300002, 0xF60E0000, 0xF6620140, 0xA2300001,
+ 0xE060014C, 0xB2200010, 0x94695F52, 0xEC220000,
+ 0xB5190000, 0xCD615F52, 0xD3695F6C, 0xAF238000,
+ 0xDC635F56, 0x91484000, 0x816B5F34, 0xC92D0002,
+ 0xFF424000, 0xBA1F0000, 0xA0C80D47, 0xCB235F7A,
+ 0x9249C000, 0xFE2F0002, 0xCD1D0000, 0xBFCC08D7,
+ 0xD249C000, 0x8E390000, 0x98CC0D47, 0xF2695F56,
+ 0x8E390000, 0xFED408DA, 0xCA625F56, 0x982F0006,
+ 0xAE2E0001, 0xEA8008CC, 0xC2685F52, 0xA36B5F52,
+ 0xDE34000F, 0xBC3700F0, 0xB9CC08E2, 0xCE1C8000,
+ 0x3ACC08E4, 0x628008E6, 0x4E1C8000, 0x1FCC08E6,
+ 0x6E32FFFC, 0x018008E7, 0x0F31FFFC, 0x60198000,
+ 0x6B615F56, 0x236B5F52, 0x31310004, 0x4835000F,
+ 0x3F37000F, 0x4E1F4000, 0x6CC808FC, 0x14004000,
+ 0x63645F52, 0x2931FFF8, 0x19394001, 0x49615F6A,
+ 0x36010000, 0x51310003, 0x6C615F68, 0x1F30FFFF,
+ 0x2A2C0D06, 0x6E2308FB, 0x70884000, 0x1C605F6C,
+ 0x686A0148, 0x2F69014C, 0x18680140, 0x420D8000,
+ 0x2A31FFFE, 0x6B615F60, 0x7E6B0148, 0x0E0A0000,
+ 0x750F8000, 0x0163014C, 0x3C30FFFE, 0x58605F62,
+ 0x4B32FFFE, 0x09625F66, 0x05970C69, 0x5A200051,
+ 0x3160B444, 0x64685F56, 0x456B5F60, 0x1E34000F,
+ 0x47300003, 0x36010000, 0x2434FF00, 0x600CC000,
+ 0x1060B448, 0x6C3500FF, 0x6361B44A, 0x23685F68,
+ 0x206B5F62, 0x506A5F66, 0x76010000, 0x2434FF00,
+ 0x600CC000, 0x3660B44C, 0x2C3500FF, 0x4561B44E,
+ 0xAF62B454, 0xC8200925, 0xD321090A, 0xBF2300A6,
+ 0xEF800C80, 0xAE210001, 0xBA61015E, 0xCE208000,
+ 0xC960015C, 0x89970E08, 0xA36B5F52, 0xC5685F6C,
+ 0xBF37000F, 0xF43B0100, 0xF263B144, 0x9F21085B,
+ 0xDF2C0002, 0xAA410000, 0xA4685F56, 0xC2230D47,
+ 0x9E34000F, 0xE3645F52, 0xC7300003, 0xBA605F68,
+ 0x82800D7E, 0xC3970956, 0xE0970961, 0xB968014C,
+ 0xEF6A0140, 0x89690148, 0xB66B0154, 0xCE0A0000,
+ 0x9762014C, 0xEF6A0140, 0xC9630150, 0x97610140,
+ 0xFC30FFFE, 0x8E0A0000, 0xB1620148, 0xDB200000,
+ 0xE7600144, 0xBC209000, 0x8E970D6A, 0xCE690140,
+ 0x9F680148, 0xE86A0148, 0xD7610140, 0x8D084000,
+ 0xE060014C, 0x9F30FFFF, 0xB60E0000, 0xF1620148,
+ 0x9B200000, 0xC78008BE, 0xDF680148, 0x8E6A014C,
+ 0x8E690140, 0xE060014C, 0xD0620144, 0xAF090000,
+ 0xF60E0000, 0x97610140, 0xB1620148, 0xED208001,
+ 0x0E800D6C, 0x7968014C, 0x49690148, 0x2F6A0140,
+ 0x57610140, 0x360E0000, 0x31620148, 0x57020000,
+ 0x4B32FFFE, 0x0E0A0000, 0x17680154, 0x50620144,
+ 0x010C0000, 0x68600150, 0x40208200, 0x0E800D6C,
+ 0x6F6A0140, 0x09690148, 0x3968014C, 0x71620148,
+ 0x17610140, 0x7C30FFFE, 0x4E0A0000, 0x17680154,
+ 0x10620144, 0x410C0000, 0x68600150, 0x00208200,
+ 0x4E800D6C, 0x32635F4E, 0x0A6B5F42, 0x7A6A5F46,
+ 0x9C200008, 0xCD210000, 0xC5330002, 0xA9D0098A,
+ 0xD4038000, 0x8B32FFFE, 0xBE33FFFF, 0xD70EC000,
+ 0xC6230995, 0x94800327, 0xB19702AF, 0xFA6A5F46,
+ 0x909702A3, 0xFA6A5F46, 0xD09702A3, 0xBA6A5F46,
+ 0xD09702A3, 0xBA6A5F46, 0x909702A3, 0xFA6A5F46,
+ 0x909702A3, 0xDF695F48, 0xFA6A5F46, 0x8C350001,
+ 0xA5C809A8, 0xF6200028, 0xD9970354, 0xAC685F4A,
+ 0xF9695F4C, 0x8B32FFFE, 0x8D048000, 0xE6C409A2,
+ 0x0F2D0001, 0x60615F4C, 0x75605F4A, 0x0520FFFF,
+ 0x4D210000, 0x3A6A5F46, 0x242309A9, 0x54800327,
+ 0x52970644, 0x3A6A5F46, 0x32200010, 0x4D210000,
+ 0x2B6B5F4E, 0x54800327, 0x4320FFFC, 0x39970365,
+ 0x61361F00, 0x32C801F6, 0x31320008, 0x79620138,
+ 0x3F2A0011, 0x53C401F6, 0x7797037A, 0x316B0130,
+ 0x36010000, 0x5235FFFE, 0x57C801F4, 0x1808C000,
+ 0x56C009BE, 0x2FCC01F4, 0x096B5F44, 0x682E0002,
+ 0x23625F46, 0x7E2F0002, 0x50635F44, 0x3E33FFFF,
+ 0x4B32FFFE, 0x170EC000, 0x0B32FFFE, 0x74970385,
+ 0x57680138, 0x3E695F44, 0x01030000, 0x652B0003,
+ 0x26C409CE, 0x5D200003, 0x7C2C0003, 0x2A072000,
+ 0x793B0000, 0x0ECC01F8, 0x1B695F46, 0x642E0010,
+ 0x35034000, 0x6C31FFFD, 0x4E09C000, 0x020E4000,
+ 0x042A0800, 0x57C401F8, 0x5797029D, 0x1B200000,
+ 0x6A210120, 0x0A6B5F42, 0x3A6A5F46, 0x43330001,
+ 0xACD009E3, 0xED2309E4, 0xD4800327, 0xB19702AF,
+ 0xCC970BA4, 0xBA6A5F46, 0xB6200028, 0xCD210000,
+ 0xD7970327, 0x969702A0, 0xBE695F44, 0xCD685F46,
+ 0x8931FFFF, 0xD70D0000, 0xD0610124, 0x9F30FFFF,
+ 0xD70D0000, 0xB6610120, 0xA6970CCB, 0xE0690134,
+ 0x8E6A0120, 0xCC61B010, 0xEB2E0068, 0x8462B000,
+ 0x8362B008, 0xF8208808, 0xFB60B01C, 0xBF2300A6,
+ 0xEF940CD0, 0xB069B024, 0x8E390000, 0xC6D00A0A,
+ 0x09690124, 0x61208400, 0x4A2D0068, 0x0361B004,
+ 0x7B60B01C, 0x3F2300A6, 0x2F940CD0, 0x5669B020,
+ 0x72310002, 0x05D00A0C, 0x09970CD8, 0x558001FC,
+ 0x09970CD8, 0x4D685F46, 0x7E695F44, 0x0E6A0120,
+ 0x46600124, 0x170D0000, 0x31610128, 0x46690130,
+ 0x176B0134, 0x7C30FFFE, 0x760E0000, 0x3662012C,
+ 0x28630130, 0x79610134, 0x6C220000, 0x09625F3C,
+ 0x6920E000, 0x39970210, 0x14680164, 0x67690150,
+ 0x98380000, 0xE0D00E47, 0xF66B0154, 0x896A0144,
+ 0xF968014C, 0x98610154, 0xB82F0001, 0xC9630150,
+ 0xCE690140, 0x9762014C, 0x81600140, 0xD4004000,
+ 0x820D8000, 0xD0610148, 0xE832FFFF, 0xAC088000,
+ 0xE7600144, 0x80208200, 0x8D970D6C, 0xF5680168,
+ 0xB66B0154, 0xD8380000, 0xE0D00E47, 0x8E6A014C,
+ 0x89690148, 0xC9630150, 0xF1620148, 0xBA098000,
+ 0xD7610140, 0x820D8000, 0xA832FFFF, 0xC20D8000,
+ 0xB661014C, 0xDB20F000, 0xCD970D6C, 0x9F680148,
+ 0xEF69014C, 0xAF6A0140, 0xBA230000, 0xC6630144,
+ 0xE060014C, 0x970D0000, 0x90610148, 0xF60E0000,
+ 0xB6620140, 0xED208001, 0xCD970D6C, 0xA86A0148,
+ 0xF968014C, 0x8E690140, 0xB66B0154, 0xF6620140,
+ 0xB60E0000, 0xDF30FFFF, 0xF60E0000, 0xB1620148,
+ 0xAF090000, 0xF1610144, 0xFE33FFFF, 0x89630150,
+ 0xE7208010, 0x8D970D6C, 0x82690164, 0xF968014C,
+ 0x0E390000, 0x60D00E47, 0x4E690140, 0x286A0148,
+ 0x506B0150, 0x10610148, 0x36620140, 0x782F0001,
+ 0x49630150, 0x2F090000, 0x31610144, 0x6D208001,
+ 0x0D970D6C, 0x466A0150, 0x766B0154, 0x3968014C,
+ 0x49690148, 0x170EC000, 0x1F620150, 0x600F0000,
+ 0x1D33FFFE, 0x7E635F5C, 0x5F6B0144, 0x17610140,
+ 0x180B0000, 0x67630148, 0x7C30FFFE, 0x180B0000,
+ 0x46630144, 0x00208200, 0x0D970D6C, 0x41970D7E,
+ 0xA3690168, 0xF16A5F5C, 0xCE390000, 0xA0D00E47,
+ 0xE8970E5E, 0xB5200018, 0xAF800E66, 0xE020FFFD,
+ 0xF9970365, 0xA1361F00, 0xB2C801F6, 0xF1320008,
+ 0xB9620138, 0xFF2A0011, 0xD3C401F6, 0xB797037A,
+ 0xF16B0130, 0xB6010000, 0x9235FFFE, 0xD7C801F4,
+ 0x9808C000, 0xDBC00A97, 0xEFCC01F4, 0x896B5F44,
+ 0xA82E0002, 0xE3625F46, 0xFE2F0002, 0x90635F44,
+ 0xC100C000, 0xBE33FFFF, 0xA00F0000, 0xCB32FFFE,
+ 0x170EC000, 0x4B32FFFE, 0x74970385, 0x17680138,
+ 0x7E695F44, 0x01030000, 0x252B0003, 0x64C40AA9,
+ 0x5D200003, 0x3F2C0005, 0x2A072000, 0x793B0000,
+ 0x0ECC01F8, 0x5B695F46, 0x642E0010, 0x2A31FFFE,
+ 0x420E4000, 0x042A0800, 0x17C401F8, 0x5797029D,
+ 0x1B200000, 0x4D210000, 0x5F6A5F44, 0x17970327,
+ 0x0C970BA4, 0x7A6A5F46, 0x76200028, 0x0D210000,
+ 0x6832FFFF, 0x17970327, 0x169702A0, 0x68685F44,
+ 0x1B695F46, 0x57020000, 0x75034000, 0x1F30FFFF,
+ 0x4931FFFF, 0x140C8000, 0x06600124, 0x750C4000,
+ 0x67600128, 0x200CC000, 0x20600120, 0x66970CCB,
+ 0x20690134, 0x496A0128, 0x5F610130, 0x0C61B010,
+ 0x6B2E0068, 0x0462B000, 0x0362B008, 0x78208808,
+ 0x3B60B01C, 0x7F2300A6, 0x6F940CD0, 0x3069B024,
+ 0x0E390000, 0x73D40ADC, 0x49970CD8, 0x168001FA,
+ 0x49690124, 0x21208400, 0x0A2D0068, 0x4361B004,
+ 0xBB60B01C, 0xFF2300A6, 0xEF940CD0, 0x9669B020,
+ 0xF2310002, 0xB0D40ADA, 0x8E6A0120, 0xF8208808,
+ 0xEB2E0068, 0x8462B000, 0x8362B008, 0xFB60B01C,
+ 0xBF2300A6, 0xEF940CD0, 0xF069B024, 0x8E390000,
+ 0xC8D00ADA, 0xA1208400, 0xBB60B01C, 0xFF2300A6,
+ 0xAF940CD0, 0xD669B020, 0xF2310002, 0xB0D40ADA,
+ 0x89970CD8, 0xCD685F46, 0xEF690120, 0xA7600128,
+ 0xD70D0000, 0x9761012C, 0xAC220000, 0xC9625F3C,
+ 0x9B20F000, 0xF9970210, 0xDF680148, 0x8E6A014C,
+ 0xCE690140, 0xA060014C, 0x90620144, 0xEF090000,
+ 0xD7610140, 0xB60E0000, 0xB1620148, 0xED208001,
+ 0x8D970D6C, 0xF968014C, 0xC9690148, 0xAF6A0140,
+ 0xD7610140, 0xA3018000, 0x970D0000, 0xD0610148,
+ 0x9F30FFFF, 0xCE0A0000, 0xD7680154, 0x90620144,
+ 0x810C0000, 0xE8600150, 0xC0208200, 0x8D970D6C,
+ 0xE06A0154, 0xB968014C, 0xB96B0140, 0xDF620150,
+ 0x09690148, 0x67630148, 0x580B0000, 0x06630144,
+ 0x5F30FFFF, 0x2F090000, 0x17610140, 0x6D208001,
+ 0x4D970D6C, 0x3968014C, 0x2F6A0140, 0x49690148,
+ 0x31620148, 0x4E0A0000, 0x57680154, 0x10620144,
+ 0x57610140, 0x010C0000, 0x28600150, 0x40208200,
+ 0x0D970D6C, 0x7968014C, 0x766B0154, 0x09690148,
+ 0x2F6A0140, 0x49630150, 0x57610140, 0x36695F58,
+ 0x4E0A0000, 0x1762014C, 0x2F2D0030, 0x664A4000,
+ 0x2F2D0006, 0x47494000, 0x673607FC, 0x13320002,
+ 0x79620154, 0x14038000, 0x03330001, 0x7ED40B49,
+ 0x6E2E0001, 0x282E0002, 0x10620144, 0x6832FFFF,
+ 0x31620148, 0x40351F00, 0x50310008, 0x39610158,
+ 0x6920E000, 0x0D970D6C, 0x3E680144, 0x4E6A014C,
+ 0x0E690140, 0x506B0150, 0x760E0000, 0x1762014C,
+ 0x0100C000, 0x43330001, 0x52D40B5C, 0x192C0001,
+ 0x5F2C0002, 0x1F30FFFF, 0x170D0000, 0x57610140,
+ 0x8D210000, 0xD0610148, 0xE920E000, 0x8D970D6C,
+ 0xD06B0150, 0x97680154, 0x8E6A014C, 0xC163014C,
+ 0xE8600150, 0x8E600154, 0x81030000, 0xC3330001,
+ 0xB4D40B6E, 0xD92C0001, 0xDF2C0002, 0x90620144,
+ 0xCE0A0000, 0xB6620140, 0x9F30FFFF, 0xF60E0000,
+ 0xB1620148, 0xED208001, 0xCD970D6C, 0x89690148,
+ 0x896A0144, 0xD06B0150, 0xD7610140, 0xB1620148,
+ 0xC100C000, 0xBE33FFFF, 0x89630150, 0xCE600154,
+ 0x01030000, 0x43330001, 0x5BD40B84, 0x192C0001,
+ 0x5F2C0002, 0x27600144, 0x00208200, 0x4D970D6C,
+ 0x68690144, 0x286A0148, 0x3968014C, 0x766B0154,
+ 0x36620140, 0x49630150, 0x4E600154, 0x01030000,
+ 0x43330001, 0x12D40B93, 0x192C0001, 0x5F2C0002,
+ 0x2060014C, 0x7A0A4000, 0x71620148, 0x3C30FFFE,
+ 0x0E0A0000, 0x50620144, 0x40208200, 0x0D970D6C,
+ 0x49690148, 0x206A0154, 0x186B014C, 0x57610140,
+ 0x9F620150, 0xFE33FFFF, 0xCE09C000, 0xA3800878,
+ 0xF2635F4E, 0x8A6B5F42, 0x9C200008, 0xCD210000,
+ 0xDF6A5F44, 0x85330002, 0x86D00BB0, 0xEC6B5F46,
+ 0xA832FFFF, 0xD70EC000, 0xEF230BC0, 0x94800327,
+ 0xF19702AF, 0x9F6A5F44, 0x909702A3, 0xDF6A5F44,
+ 0xAC685F4A, 0xF9695F4C, 0xCB32FFFE, 0x8D048000,
+ 0xA5C40BBB, 0xCF2D0001, 0xE0615F4C, 0xB5605F4A,
+ 0xFA6A5F46, 0x8520FFFF, 0x8D210000, 0xF19702AF,
+ 0xBA6A5F46, 0xF2200010, 0xCD210000, 0xAB6B5F4E,
+ 0xD4800327, 0x93800200, 0x81030000, 0xC637FFFF,
+ 0xEECC0200, 0xAE2C0BCB, 0xB0884000, 0xE9800BCC,
+ 0x9A970364, 0xDF20000E, 0xFE97036D, 0xA43C000E,
+ 0xEFCC01F4, 0x952001FF, 0xBE97036D, 0xFE605F3C,
+ 0xBF340003, 0xEFCC01F4, 0xC92E000E, 0x8B32FFFE,
+ 0xB4970385, 0xD797029D, 0xE822000E, 0x9B200000,
+ 0xCD210000, 0x97970327, 0xA0685F34, 0xC92101D8,
+ 0x1F610106, 0x7D2C0008, 0x73490000, 0x1F2C0002,
+ 0x65480000, 0x23615F4A, 0x36605F4C, 0x67685F3C,
+ 0x58695F40, 0x3C30FFFE, 0x1B605F3E, 0x6F090000,
+ 0x02C40BEE, 0x57605F40, 0x502001A0, 0x2A230BF3,
+ 0x6C600104, 0x3D635F36, 0x3D8002D7, 0x72200010,
+ 0x2C600104, 0x58800420, 0x529700EB, 0x2A220003,
+ 0x2F62B438, 0x56695FCA, 0x42685EDE, 0x2C220000,
+ 0x4A61B400, 0x2862B406, 0x18380000, 0x7CC8009C,
+ 0x15340080, 0x43C80C05, 0x6F200C16, 0x27230C06,
+ 0x5A8000AB, 0x1B605EDE, 0x24685EEC, 0x5E23009C,
+ 0x6C220000, 0x0A625EEC, 0x14695EDE, 0x5B6A5EF0,
+ 0x18380000, 0x7AC800F3, 0x60198000, 0x176A5F02,
+ 0x60198000, 0x396A5EA0, 0x1CD000AB, 0x5E36FDFF,
+ 0x20625EA0, 0x5A8000AB, 0x51215EDE, 0x2F220006,
+ 0x04970F9D, 0x77215EEC, 0x70510000, 0x30510000,
+ 0x70884000, 0x2F220030, 0x2F62B438, 0x70695FCE,
+ 0xAC685EF0, 0xEC220000, 0xE061B420, 0x8262B426,
+ 0xD8380000, 0x9FC8009D, 0x95340080, 0xEDC80C2B,
+ 0xE5200C31, 0xAF230C2C, 0x9A8000AB, 0xF5605EF0,
+ 0xA8685EFE, 0xFD23009D, 0xEC220000, 0x86625EFE,
+ 0xE1800C0A, 0xBF215EF0, 0xAF220006, 0xC4970F9D,
+ 0xBB215EFE, 0xF0510000, 0xF0510000, 0xB0884000,
+ 0xAF220300, 0xEF62B438, 0xF0695FCE, 0xA0685F02,
+ 0xEC220000, 0x8161B440, 0xA362B446, 0xD8380000,
+ 0x99C8009E, 0xD5340080, 0xCEC80C46, 0xAF200C4C,
+ 0xCF230C47, 0x9A8000AB, 0xB9605F02, 0xEC685F10,
+ 0xFB23009E, 0xAC220000, 0x82625F10, 0xE1800C0A,
+ 0xB3215F02, 0xEF220006, 0xC4970F9D, 0xBF215F10,
+ 0xF0510000, 0xB0510000, 0xB0884000, 0xC2685EDE,
+ 0x91215EDE, 0xD8380000, 0xC0D00C5F, 0xA1205EEC,
+ 0xA5518000, 0xE6500000, 0xD8695EA0, 0xA6500000,
+ 0xC0390200, 0x81615EA0, 0x918B4000, 0xC100C000,
+ 0x2F220006, 0x7F2300A6, 0x67800FC0, 0x2C685EF0,
+ 0x7F215EF0, 0x18380000, 0x00D00C5F, 0x6D205EFE,
+ 0x66800C58, 0x20685F02, 0x33215F02, 0x58380000,
+ 0x00D00C5F, 0x69205F10, 0x66800C58, 0x02685EDE,
+ 0x51215EDE, 0x18380000, 0x3FD40C57, 0x588000A6,
+ 0x2C685EF0, 0x7F215EF0, 0x58380000, 0x1ED000A6,
+ 0x2D205EFE, 0x66800C58, 0x7D605EEC, 0x0E615EEE,
+ 0x518B4000, 0x31605EFE, 0x0A615F00, 0x518B4000,
+ 0xB5605F10, 0xC6615F12, 0xD18B4000, 0xAC685EF0,
+ 0xCD210000, 0x98380000, 0xA5C80C94, 0xEF61B434,
+ 0xD16A5FCE, 0xA361B426, 0x8162B420, 0xD5340080,
+ 0x85C80C93, 0xD4635E9C, 0xFF215EF0, 0xAF220006,
+ 0xC4970F9D, 0x8D6B5E9C, 0x9A8000AB, 0xE3615EF0,
+ 0x918B4000, 0xD7620116, 0xC7200C98, 0x9A8000AB,
+ 0x86970C6F, 0xCE6A0116, 0xE620B404, 0xAC500011,
+ 0xE0500003, 0xA850C400, 0x85500001, 0xC7500180,
+ 0x26500000, 0x6462B414, 0x5E2000A6, 0x082100A6,
+ 0x7F2300A6, 0x29800C7A, 0x20690102, 0x5B200000,
+ 0x45350020, 0x14C801F2, 0x18218000, 0x6F615ED4,
+ 0x3D605EDA, 0x7E605EDC, 0x518B4000, 0x36695ED4,
+ 0x58380000, 0x3AC800F3, 0x0E390000, 0x49D400EF,
+ 0x3D605EDA, 0x518B4000, 0x76695ED4, 0x18380000,
+ 0x3AC800F3, 0x4E390000, 0x49D400EF, 0x3E605EDC,
+ 0x518B4000, 0x20685ED4, 0x33215ED4, 0x58380000,
+ 0x24D400F1, 0x70510000, 0x518B4000, 0x18695ECC,
+ 0x63685ED2, 0x0E390000, 0x27D4009B, 0x58380000,
+ 0x5CC8009B, 0x3E23009B, 0x1A8000AB, 0x5D215ECC,
+ 0x25518000, 0x5B200000, 0x7A605ED2, 0x118B4000,
+ 0x58695ECC, 0x3A605ED2, 0x0E390000, 0x58695EA0,
+ 0x09D400EF, 0x49390008, 0x41615EA0, 0x118B4000,
+ 0x396A5EA0, 0x4E685ECC, 0x5D215ECC, 0x1736FFF7,
+ 0x60625EA0, 0x18380000, 0x24D400F1, 0x70510000,
+ 0x918B4000, 0xC2685F52, 0xD8218000, 0xB6144000,
+ 0xE6CC00A0, 0x8D615F52, 0xBC2300A0, 0xEC200CE9,
+ 0xDA8000AB, 0xB4200400, 0x9360B144, 0xC3210200,
+ 0x8A68B144, 0xDE34000F, 0xF5190000, 0x8561B144,
+ 0xE3645F52, 0xB6010000, 0x90310008, 0xE839A0C8,
+ 0xB04B4000, 0xE72D002C, 0xC7494000, 0x97020000,
+ 0x83330001, 0xD0377F00, 0xC963010A, 0xB0320003,
+ 0xCD625F68, 0x97020000, 0x8832FFF8, 0xF83A4001,
+ 0xA8625F6A, 0xD7020000, 0xE832FFFF, 0x9D2E0D06,
+ 0xE2230D1A, 0x878A4000, 0xAA205F7A, 0xD18B4000,
+ 0xC9205F82, 0x918B4000, 0x8E205F8A, 0xD18B4000,
+ 0xA0205F92, 0xD18B4000, 0xE7205F9A, 0x918B4000,
+ 0xE3205FA2, 0x918B4000, 0xA4205FAA, 0xD18B4000,
+ 0x8A205FB2, 0xD18B4000, 0xCD205FBA, 0x918B4000,
+ 0x82205FC2, 0xD18B4000, 0xDC605F6C, 0xB3490000,
+ 0xDF2C0002, 0x844B0000, 0x9F2C0002, 0xD24A0000,
+ 0x1F2C0002, 0x65480000, 0x6F615F58, 0x1C635F56,
+ 0x6B625F5A, 0x1F605F5C, 0x27970E26, 0x716A5F5C,
+ 0x536B010C, 0x2F3A0000, 0x0BC80D36, 0x6C213000,
+ 0x3A098000, 0x6C0B4000, 0x5861010E, 0x32C00D31,
+ 0x7ECC0E45, 0x05685F5A, 0x29230D36, 0x79635F54,
+ 0x026B5F68, 0x66800E2B, 0x6769010A, 0x056B5F56,
+ 0x10310008, 0x4AC80D67, 0x576A5F58, 0x22390080,
+ 0x4B2E0035, 0x07458000, 0x01970D7E, 0x42685F52,
+ 0x24230D43, 0x4B341000, 0x59CC102C, 0x1D2000A0,
+ 0x40645F53, 0x36695F58, 0x1E970273, 0x4169010E,
+ 0x4D223000, 0x3A0A4000, 0x2CC80D63, 0x54680108,
+ 0x32620114, 0x58380000, 0x69C80D50, 0x00970C95,
+ 0x45970C69, 0x0169010E, 0x2D20B444, 0x6C500011,
+ 0x05500001, 0x6850C400, 0x45500001, 0x3135FFFF,
+ 0x2A410000, 0x6B6A0114, 0x5F2C0002, 0x26500000,
+ 0x6F62B454, 0x0A200D61, 0x1C210D61, 0x7F2300A6,
+ 0xAF800C80, 0xFA203000, 0xCE60010E, 0x8D210000,
+ 0xDB610108, 0x8D615F52, 0x988000A6, 0xEC220000,
+ 0xDB62015E, 0x918B4000, 0xAE210001, 0xFA61015E,
+ 0x8960015C, 0xDC635F56, 0xC9970E08, 0xA36B5F52,
+ 0xC5685F6C, 0xBF37000F, 0xB43B0100, 0xF263B144,
+ 0xB2695F56, 0xDF2C0002, 0xEA410000, 0x93695F5A,
+ 0x9F2C0002, 0xEA410000, 0xD0695F5C, 0x9F2C0002,
+ 0xEA410000, 0xA5800D47, 0x82685F52, 0xFA69B140,
+ 0x3C30FFFE, 0x53D0038F, 0x79635F54, 0x24300002,
+ 0x41030000, 0x1E34000F, 0x3E3CFFFF, 0x79228000,
+ 0x4D120000, 0x181D8000, 0x2361B140, 0x796A5EA0,
+ 0x38CC0D8F, 0x7636FFFB, 0x60625EA0, 0x2A3B2000,
+ 0x63685F32, 0x3A635F52, 0x0D344000, 0x6AC80D99,
+ 0x05685F36, 0x599700AB, 0x41685F54, 0x3F2300A6,
+ 0x1A8000AB, 0x42685F52, 0x7A69B140, 0x2F238000,
+ 0x5E34000F, 0x17020000, 0x093EFFFF, 0x4E138000,
+ 0x9419C000, 0xE361B140, 0xFF30FFF8, 0x9438A084,
+ 0xCC500020, 0xBD680118, 0x97695F54, 0xC218C000,
+ 0xE4600118, 0xBA1CC000, 0xB8CC0DE3, 0xF161011E,
+ 0xA3685F68, 0xE363011C, 0xC160011A, 0x85970C69,
+ 0xF96B011A, 0xAD20B444, 0x8E500041, 0xC5500001,
+ 0x87500180, 0xE6500000, 0xF602C000, 0x9336FF00,
+ 0x8162B44C, 0xDB3700FF, 0xF263B44E, 0xBF222000,
+ 0xEF62B454, 0x9F6B011E, 0x9B200000, 0xE760011E,
+ 0xB93B0000, 0xD2CC0DC3, 0xFF2300A6, 0xAC200DC6,
+ 0xFA210DC6, 0xAF800C80, 0x9B68011C, 0xFA69B140,
+ 0xCA6A0118, 0x8D1D0000, 0xA361B140, 0xEC1E0000,
+ 0x93620118, 0xE2C80DDF, 0xDB200000, 0xAE210001,
+ 0xD4038000, 0x97174000, 0xBECC0DD6, 0xD92C0001,
+ 0x8931FFFF, 0xC0800DD0, 0xD461011C, 0x87300003,
+ 0xB5695F32, 0xC160011A, 0xDB354000, 0xAAC80DAF,
+ 0xE9200DAF, 0xA46B5F36, 0x9A8000AB, 0xE3685F32,
+ 0x13695F36, 0x4D344000, 0x5DC800A6, 0x26894000,
+ 0x6F3A0000, 0x10C8038F, 0x3D635F36, 0x4D6B5F4A,
+ 0x6C600104, 0x1F610106, 0x2C625F3E, 0x71635F48,
+ 0x27970C63, 0x75680104, 0x676A0106, 0x286B5F48,
+ 0x7160B428, 0x1E21B42A, 0x30510000, 0x4100C000,
+ 0x2434FF00, 0x541A0000, 0x6062B42C, 0x1B3700FF,
+ 0x1363B42E, 0x756A5F3E, 0x73200041, 0x1060B424,
+ 0x4E62B434, 0x32210DEC, 0x3F2300A6, 0x6B940C7D,
+ 0xA46B5F36, 0xD18B4000, 0xFD635F36, 0xBC200120,
+ 0xCD210000, 0x86220020, 0x8E6B5F4C, 0xC4800DE8,
+ 0xF9635F54, 0xA76B5F6A, 0x9D200140, 0xCD210000,
+ 0x86220020, 0xFD605F60, 0xCE615F62, 0x89625F66,
+ 0xDB635F5E, 0x85970C69, 0xA4685F60, 0xF66A5F62,
+ 0x826B5F5E, 0xD060B448, 0xFF21B44A, 0xB0510000,
+ 0x8100C000, 0xE434FF00, 0xD41A0000, 0x8162B44C,
+ 0xDB3700FF, 0xB263B44E, 0x906A5F66, 0xF3200041,
+ 0x3160B444, 0x6F62B454, 0x46200E43, 0x17210E11,
+ 0x7F2300A6, 0x2F800C80, 0x39635F54, 0x5B200000,
+ 0x4B210140, 0x2722002C, 0x276B5F6A, 0x7D605F60,
+ 0x0E615F62, 0x49625F66, 0x5B635F5E, 0x05970C69,
+ 0x546A5F5E, 0x24685F60, 0x17695F62, 0x54038000,
+ 0x0537FF00, 0x4218C000, 0x5060B448, 0x0D3600FF,
+ 0x0262B44A, 0x6061B44C, 0x5B200000, 0x1360B44E,
+ 0x506A5F66, 0x11200011, 0x3160B444, 0x6F62B454,
+ 0x10210E2F, 0x7F2300A6, 0x4D940C80, 0x206B5F54,
+ 0x518B4000, 0x25210041, 0x2F800D3A, 0x44210021,
+ 0x6F800D3A, 0x176A5F58, 0x02690164, 0x602E0028,
+ 0x0E390000, 0x4BD00E5A, 0x6F090000, 0x2A31FFFE,
+ 0x75680168, 0x3F418000, 0x3734001F, 0x682E0002,
+ 0x29408000, 0x75008000, 0x5F2C0002, 0x26500000,
+ 0x26500000, 0x518B4000, 0x4E208000, 0x29408000,
+ 0x5B200000, 0x29800E53, 0x20685F58, 0x4D210000,
+ 0x972C0028, 0xE6500000, 0xE6500000, 0xA6500000,
+ 0xEA410000, 0x918B4000, 0xAE230D3E, 0xE73607FC,
+ 0xD0C8038F, 0xB9635F54, 0x816B5F58, 0xC9625F66,
+ 0xA00CC000, 0xC44B0000, 0xDF2C0002, 0xA5480000,
+ 0xF9635F62, 0xB66B010E, 0x9B605F64, 0xF60DC000,
+ 0x9B610108, 0xE4970C53, 0xC1685F62, 0x94695F64,
+ 0xBD60B40C, 0xCE61B40E, 0xD4680108, 0x906A5F66,
+ 0xF421B40A, 0x9B60B408, 0xB0510000, 0xD4200081,
+ 0x3A60B404, 0x6462B414, 0x41685F54, 0x10210E75,
+ 0x7F2300A6, 0x29800C7A, 0x36695F6E, 0x4E208000,
+ 0x54150000, 0x25C80E8B, 0x118B4000, 0x796A5EA0,
+ 0x39605F6E, 0x6D200E91, 0x7536FFFD, 0x20625EA0,
+ 0x5A8000AB, 0x2A685FDC, 0x36695F6E, 0x58380000,
+ 0x0AC80EF4, 0x54605F70, 0x712C0040, 0x33490000,
+ 0x17655F6E, 0x5C65B112, 0x6F31FFFB, 0x312D4010,
+ 0x664A4000, 0x2F6BB110, 0x092D0002, 0x6F0AC000,
+ 0x9BC00EE8, 0xF04B4000, 0xD62DFFF6, 0xB93B0000,
+ 0xF7D40EAD, 0x8D685F70, 0xA02D0012, 0xE64A4000,
+ 0xD42C0042, 0x844B0000, 0xB82DFFEE, 0xEF1F8000,
+ 0x9FCC0EEA, 0xD4004000, 0xFB215F72, 0x8F970FDD,
+ 0xFE695F72, 0xB92C0006, 0xA9350003, 0xDACC0EEF,
+ 0xBB215F72, 0xF422FFFC, 0xE1970FF3, 0x8D685F70,
+ 0xB9215FDC, 0xE0970F5B, 0xE6971027, 0xA4970C53,
+ 0xEC6B5F70, 0xA8685F72, 0xBD695F74, 0xD522B40A,
+ 0xBA63B408, 0xD1520000, 0xFD60B40C, 0x8E61B40E,
+ 0xD4200081, 0xBA60B404, 0x90200040, 0xD360B414,
+ 0xD0210EBA, 0xBF2300A6, 0x8B940C7A, 0xE0685F6E,
+ 0xBC695FEA, 0xFA3400FF, 0xF930FFFB, 0x852C401A,
+ 0xC44B0000, 0x8F2D0001, 0xB82F0001, 0xDD430000,
+ 0x802CFFF6, 0xD24A0000, 0xF92C0006, 0x844B0000,
+ 0xA5615FEA, 0xF82F0001, 0xEF0AC000, 0xA5C40EDD,
+ 0xFA230000, 0x9D430000, 0x976A5F6E, 0xCD685F70,
+ 0x0D3600FF, 0x5D3A1000, 0x4A62B130, 0x06970F33,
+ 0x4E208000, 0x39605F6E, 0x0C230E91, 0x7C800115,
+ 0x66210088, 0x34655F6F, 0x0D685F70, 0x76695F6E,
+ 0x3E2C0038, 0x65480000, 0x4E800E93, 0x3F9700F5,
+ 0x4D685F70, 0x39215FDC, 0x21230EE3, 0x63800F5B,
+ 0x396A5EA0, 0x5E350800, 0x6F615F6E, 0x1DC800A6,
+ 0x0A3A0002, 0x60625EA0, 0x588000A6, 0x2B68B148,
+ 0x62300001, 0x20D00F04, 0x21300007, 0x62D00F09,
+ 0x06300008, 0x7E3CFFFF, 0x4A64B148, 0x3F80009F,
+ 0x7A230000, 0x1363B148, 0x3C635FF2, 0x59635FF0,
+ 0x6D800EFE, 0x07710048, 0x29710149, 0x5471804B,
+ 0x01800F0B, 0x40685FFC, 0x736AB1F8, 0x2434FF00,
+ 0x46300008, 0x192C0001, 0x21361F00, 0x71320008,
+ 0x0E0A0000, 0x41C000F9, 0x7F225E90, 0x3930FFFB,
+ 0x0E2C4000, 0x4E0A0000, 0x63C000F3, 0x37605FD2,
+ 0x43625FD4, 0x122A000F, 0x0EC000ED, 0x518B4000,
+ 0x88685FD6, 0xFB695FD4, 0xD8380000, 0x8FC80F27,
+ 0xF3490000, 0x87615FD6, 0x918B4000, 0xF9290044,
+ 0xD1C00F2F, 0xAE685FD2, 0xA2615FD4, 0xF6010000,
+ 0x812D0044, 0xE1615FD2, 0xD18B4000, 0x9B1C0000,
+ 0xF7605FD2, 0xB4605FD4, 0x918B4000, 0xDE695FD6,
+ 0x98380000, 0xFAC800F3, 0xEA410000, 0x91605FD6,
+ 0x918B4000, 0xCE390000, 0xD7C800ED, 0xA64A4000,
+ 0xD8380000, 0xBAC800F3, 0x88404000, 0xEF3A0000,
+ 0xAEC80F47, 0xDB2C003A, 0xCB420000, 0x892E0038,
+ 0xC32CFFC6, 0xA9408000, 0x918B4000, 0xD12DFFFE,
+ 0xC8404000, 0x918B4000, 0x8E390000, 0xD7C800ED,
+ 0xA64A4000, 0xD8380000, 0xFAC800F3, 0x88404000,
+ 0xEF3A0000, 0xA0C80F58, 0xBE2C0038, 0xCB420000,
+ 0xAC2E003A, 0xC72CFFC8, 0xE9408000, 0x918B4000,
+ 0x892D0002, 0xC8404000, 0xD18B4000, 0x8E390000,
+ 0xD7C800ED, 0x98380000, 0xBAC800F3, 0xF6635E96,
+ 0x1B2C003A, 0x444B0000, 0x472CFFFE, 0x124A0000,
+ 0x793B0000, 0x20C80F6E, 0x2F3A0000, 0x4CC80F7B,
+ 0x5F2F0038, 0x2A42C000, 0x2C2E003A, 0x662FFFC8,
+ 0x08438000, 0x4B800F76, 0x7F424000, 0x2F3A0000,
+ 0x6BC80F74, 0x2C2E003A, 0x08438000, 0x4B800F76,
+ 0x092D0002, 0x7F424000, 0x66500000, 0x26500000,
+ 0x2F6B5E96, 0x662CFFC4, 0x518B4000, 0x092D0002,
+ 0x7F424000, 0x1F2F0038, 0x2A42C000, 0x4B800F76,
+ 0x95320001, 0xC5367FFF, 0xC6C80F93, 0xB22A0008,
+ 0xD7C00F8F, 0xA6500000, 0xA6500000, 0xE6500000,
+ 0xE6500000, 0xA6500000, 0xA6500000, 0xE6500000,
+ 0xA6500000, 0xC6C80F93, 0xEA800F83, 0x93260008,
+ 0xE6500000, 0x932EFFFF, 0xB8CC0F90, 0xD18B4000,
+ 0x93635E94, 0xC4970F9D, 0xCA6B5E94, 0x9A8000AB,
+ 0x93635E94, 0xC4970F9D, 0xC1030000, 0xAB685E94,
+ 0xDA8000AB, 0x91484000, 0xA7615E92, 0xD4605E90,
+ 0x06300008, 0x55D40FBE, 0x76635E96, 0x1634007F,
+ 0x5F30FFFF, 0x092D0002, 0x170D0000, 0x704B4000,
+ 0x62300001, 0x192C0001, 0x1B695E90, 0x6C1E0000,
+ 0x3FCC0FAE, 0x5B200000, 0x63024000, 0x1B368000,
+ 0x4035007F, 0x0D1D0000, 0x3E695E92, 0x4BC80FBC,
+ 0x31320008, 0x541A0000, 0x4F2D0001, 0x07464000,
+ 0x0100C000, 0x6F6B5E96, 0x58380000, 0x118B4000,
+ 0x7F424000, 0x28800FB8, 0x1B1C0000, 0x518B4000,
+ 0x14605E90, 0x51484000, 0x45625E94, 0x06300008,
+ 0x71D40FDB, 0x17020000, 0x06300008, 0x5634007F,
+ 0x6136007F, 0x2C1E0000, 0x17C800ED, 0x5F30FFFF,
+ 0x3A6A5E90, 0x67615E92, 0x492D0002, 0x170D0000,
+ 0x7F424000, 0x1C6A5E94, 0x3E695E92, 0x62300001,
+ 0x192C0001, 0x6C1E0000, 0x74CC0FD8, 0x1B200000,
+ 0x34380080, 0x70444000, 0x518B4000, 0x1B200000,
+ 0x46800FCC, 0x36635E96, 0x044B0000, 0x5F2C0002,
+ 0xA9434000, 0xD24A0000, 0xC92D0002, 0xBF424000,
+ 0xD71B8000, 0x9F2C0002, 0x924A0000, 0xC92D0002,
+ 0xFF424000, 0x971B8000, 0x9F2C0002, 0xD24A0000,
+ 0x892D0002, 0xFF424000, 0xF51AC000, 0xAF6B5E96,
+ 0xDF2C0002, 0x892D0002, 0x918B4000, 0xD4605E90,
+ 0xA7615E92, 0xF6635E96, 0xF3490000, 0x940C8000,
+ 0xA5480000, 0xCE390000, 0xE1C8101A, 0xA1340FFC,
+ 0xCFC81002, 0xAA280041, 0x96C01002, 0xCB240041,
+ 0xAA072000, 0xCF801007, 0xCC31FFFA, 0xA3024000,
+ 0xF436FFC0, 0xB5034000, 0xBC37003F, 0xFE695E92,
+ 0xD1484000, 0x8D048000, 0x88404000, 0xC92D0002,
+ 0x91484000, 0xD604C400, 0xC8404000, 0x80C4101A,
+ 0xC92D0002, 0x91484000, 0xAC220000, 0xE2048400,
+ 0x88404000, 0xC0C4101A, 0xC92D0002, 0x91484000,
+ 0xA2048400, 0xC8404000, 0xEF6B5E96, 0x8D685E90,
+ 0xD18B4000, 0x8A685F14, 0x99215F14, 0xD8380000,
+ 0x05D01023, 0x65518000, 0x518B4000, 0x0100C000,
+ 0x49220002, 0x3F2300A6, 0x27800FC0, 0x4A685F14,
+ 0x5D215F1A, 0x18380000, 0x05D01023, 0x518B4000,
+ 0x0A685F14, 0x59215F14, 0x58380000, 0x24D400F1,
+ 0x55340080, 0x0FC81034, 0x09220002, 0x42800F98,
+ 0x30510000, 0x4E685F1A, 0x54635E9C, 0x18380000,
+ 0x33CC103A, 0x518B4000, 0x5D215F1A, 0x09220002,
+ 0x60970F94, 0x0D6B5E9C, 0x29801035, 0x60000000,
+ 0x20000000
+};
+
+// Align to PKA_BUFFER_RAM_SIZE. This is greater than the actual buffer
+// length so that the image is zero padded.
+static const uint32_t fw1_farm_img_data_buf[2048] =
+{
+ 0x267001C9, 0x132040FA, 0x26502421, 0x032040D0,
+ 0x295046C7, 0x0D500000, 0x258C0200, 0x0F70AAC9,
+ 0x3B7000C8, 0x2D70001D, 0x2670001F, 0x296A4010,
+ 0x086B4014, 0x39621FF8, 0x16631FF4, 0x15684000,
+ 0x34694004, 0x1E601FF6, 0x3F611FF2, 0x346A4008,
+ 0x156B400C, 0x32621FFA, 0x1B631FF0, 0x219700BB,
+ 0x1E684034, 0x2170001E, 0x3A34003F, 0x281A0000,
+ 0x3F621FFE, 0x0628000B, 0x20C4004A, 0x1124002C,
+ 0x21884000, 0x2980004A, 0x30800033, 0x22800048,
+ 0x3480003E, 0x2980004A, 0x2C800040, 0x2C80002C,
+ 0x3980003A, 0x27800042, 0x21800044, 0x2A800046,
+ 0x276A4018, 0x34621FFC, 0x339701D9, 0x09300002,
+ 0x39D00063, 0x3930FFFE, 0x36800059, 0x276A4018,
+ 0x34621FFC, 0x2A97025F, 0x09300002, 0x39D00063,
+ 0x3930FFFE, 0x34800064, 0x2E970327, 0x268C0400,
+ 0x16614018, 0x36800059, 0x2F970733, 0x36800059,
+ 0x2A9706EF, 0x36800059, 0x29970735, 0x36800059,
+ 0x319706F1, 0x36800059, 0x3D970422, 0x36800059,
+ 0x27970767, 0x36800059, 0x3B7000C8, 0x24200021,
+ 0x358C5000, 0x26800073, 0x2B707FC8, 0x08702084,
+ 0x2D70001D, 0x36200000, 0x2D010000, 0x1E220001,
+ 0x2F970085, 0x01684084, 0x26340020, 0x0ECC0055,
+ 0x3920000F, 0x238C0100, 0x09300002, 0x39D00063,
+ 0x1B601FFC, 0x2A681FF0, 0x246A4014, 0x2D010000,
+ 0x2460400C, 0x2F970085, 0x29681FFC, 0x3930FFFE,
+ 0x036A1FF6, 0x276B1FF8, 0x08624000, 0x37634010,
+ 0x0D6A1FFE, 0x3F9700C3, 0x0E6A1FF2, 0x246B1FF4,
+ 0x05624004, 0x3A634014, 0x006A1FFA, 0x35230000,
+ 0x06624008, 0x358C5000, 0x3463401C, 0x106440C9,
+ 0x3C800006, 0x376B1FE4, 0x228B4000, 0x3C6B1FE6,
+ 0x228B4000, 0x3F8C0480, 0x24BC004E, 0x1B61401C,
+ 0x228B4000, 0x2D010000, 0x3930FFFE, 0x0D500000,
+ 0x0D500000, 0x0D500000, 0x0D500000, 0x09300002,
+ 0x202A0002, 0x0B614000, 0x1B624010, 0x29604008,
+ 0x1D218808, 0x23800079, 0x0B631FEC, 0x166B4000,
+ 0x086A1FF4, 0x27604000, 0x06614004, 0x2A634008,
+ 0x1B624010, 0x16624014, 0x37218001, 0x25970079,
+ 0x35068000, 0x186B4008, 0x0D691FF2, 0x24634000,
+ 0x06614004, 0x29604008, 0x1B624010, 0x2A320001,
+ 0x262EFFFF, 0x36058000, 0x1531FFFE, 0x214B4000,
+ 0x20250002, 0x0E494000, 0x2819C000, 0x07CC00A5,
+ 0x16624014, 0x2C218200, 0x25970079, 0x396B1FEC,
+ 0x228B4000, 0x37694008, 0x268C0400, 0x0D684024,
+ 0x04140000, 0x18D400B0, 0x36200000, 0x228B4000,
+ 0x00240001, 0x1A084000, 0x228B4000, 0x13684030,
+ 0x37380001, 0x21604030, 0x228B4000, 0x13684030,
+ 0x0834FFFE, 0x21604030, 0x228B4000, 0x386A40C4,
+ 0x3F694030, 0x1B360001, 0x1732FFF9, 0x18350001,
+ 0x1831FFFA, 0x011A4000, 0x228B4000, 0x07018000,
+ 0x28310006, 0x18350001, 0x0D614030, 0x2C320007,
+ 0x1B360001, 0x0A6240C4, 0x228B4000, 0x29604008,
+ 0x06614004, 0x16624014, 0x37218001, 0x268C0400,
+ 0x1B61401C, 0x2A694010, 0x27604000, 0x36064000,
+ 0x1B624010, 0x228B4000, 0x29604008, 0x06614004,
+ 0x16624014, 0x2D218018, 0x268C0400, 0x1B61401C,
+ 0x296A4010, 0x27604000, 0x2F260001, 0x1B624010,
+ 0x228B4000, 0x29604008, 0x06614004, 0x16624014,
+ 0x2C218200, 0x268C0400, 0x1B61401C, 0x246A4014,
+ 0x27604000, 0x1B624010, 0x228B4000, 0x1C2100FF,
+ 0x288000EE, 0x1A210000, 0x05631FE4, 0x24611FEC,
+ 0x21681FF2, 0x2B6040A0, 0x0B691FF4, 0x27604000,
+ 0x29604008, 0x18614010, 0x268C0400, 0x0970081C,
+ 0x2470881D, 0x01F000F9, 0x3930FFFE, 0x27490000,
+ 0x29310001, 0x3A200003, 0x1DD40075, 0x1231FFFF,
+ 0x286540B4, 0x216B1FFE, 0x036A1FF6, 0x3D33FFFF,
+ 0x3FD00110, 0x276B1FF8, 0x08624000, 0x06624008,
+ 0x37634010, 0x3F8C0480, 0x24BC004E, 0x3C70011F,
+ 0x0970081C, 0x2470881D, 0x13F0010E, 0x38800112,
+ 0x3F8C0480, 0x24BC004E, 0x196840A0, 0x21694024,
+ 0x1F090000, 0x30C801D6, 0x07024000, 0x1D2E0001,
+ 0x16624014, 0x1F31FFFB, 0x0E684028, 0x2670001F,
+ 0x2F34001F, 0x2E184000, 0x322C0001, 0x2E020000,
+ 0x09240008, 0x1334FFE0, 0x08300005, 0x0B691FF4,
+ 0x206040A2, 0x2D6040A6, 0x322C0001, 0x1F090000,
+ 0x25C40135, 0x356940A0, 0x1C050000, 0x252DFFFF,
+ 0x1531FFFE, 0x21510000, 0x21510000, 0x03691FFA,
+ 0x1C050000, 0x252DFFFF, 0x1531FFFE, 0x21510000,
+ 0x21510000, 0x322C0001, 0x16691FEC, 0x0834FFFE,
+ 0x2B3D00FF, 0x19CC013D, 0x27681FF4, 0x0B240003,
+ 0x0834FFFE, 0x08601FEC, 0x2B26000C, 0x21621FEA,
+ 0x2226005F, 0x35200060, 0x35230000, 0x160B2000,
+ 0x252DFFFF, 0x026140AA, 0x1E2D0001, 0x15072000,
+ 0x3F6B1FEA, 0x28004000, 0x3530FFFD, 0x1F0AC000,
+ 0x35230000, 0x0D631FEA, 0x160B2000, 0x3520000C,
+ 0x35230000, 0x29290007, 0x26C40155, 0x2A250007,
+ 0x23800156, 0x1B210007, 0x1A084000, 0x2D1B4000,
+ 0x33634088, 0x306940AA, 0x3530FFFD, 0x1E2D0001,
+ 0x15072000, 0x252A0008, 0x2A621FE8, 0x2B008000,
+ 0x1D2E0001, 0x1334FFE0, 0x08300005, 0x322C0001,
+ 0x296B1FF0, 0x16691FEC, 0x03601FEE, 0x1A074000,
+ 0x24634000, 0x3A33FFFE, 0x0E530000, 0x0E530000,
+ 0x0E530000, 0x0E530000, 0x0A330002, 0x2A634008,
+ 0x33070000, 0x0B2B0003, 0x09280004, 0x02C0018C,
+ 0x322C0001, 0x34604010, 0x3F8C0480, 0x24BC004E,
+ 0x3C70011F, 0x2A70001C, 0x2470881D, 0x09F0017B,
+ 0x0E691FFE, 0x0D684024, 0x1231FFFF, 0x37D0018B,
+ 0x00691FF6, 0x04140000, 0x3CD001D3, 0x1A084000,
+ 0x22694028, 0x0335001F, 0x3330FFFB, 0x2E184000,
+ 0x36C801D0, 0x322C0001, 0x00601FE2, 0x2670001F,
+ 0x2B008000, 0x3D3CFFFF, 0x30218000, 0x19110000,
+ 0x3A33FFFE, 0x20340010, 0x21C80197, 0x1641C000,
+ 0x0F270002, 0x0E530000, 0x23800199, 0x0E530000,
+ 0x1641C000, 0x31681FEE, 0x356940A0, 0x34604010,
+ 0x166B4000, 0x3304C000, 0x322C0001, 0x0834FFFE,
+ 0x06614004, 0x29604008, 0x0568401C, 0x3F8C0480,
+ 0x24BC004E, 0x3C70011F, 0x2A70001C, 0x1B70821D,
+ 0x19F001A8, 0x3D340008, 0x30C801BA, 0x0E691FFE,
+ 0x0D684024, 0x1231FFFF, 0x36D001BA, 0x00691FF6,
+ 0x04140000, 0x3CD001D3, 0x1A084000, 0x22694028,
+ 0x3330FFFB, 0x0335001F, 0x2E184000, 0x36C801D0,
+ 0x322C0001, 0x00601FE2, 0x2670001F, 0x1B691FE8,
+ 0x3E20000E, 0x29310001, 0x1231FFFF, 0x28D001C2,
+ 0x092CFFFF, 0x378001BE, 0x39694000, 0x0C2207FA,
+ 0x186B4008, 0x096140A8, 0x256340A4, 0x076240AC,
+ 0x236040AE, 0x2E7000B2, 0x3F8C0480, 0x24BC004E,
+ 0x31700484, 0x24E001CD, 0x31200001, 0x20800075,
+ 0x3F200009, 0x2670001F, 0x20800075, 0x3C200005,
+ 0x2670001F, 0x20800075, 0x37200007, 0x2670001F,
+ 0x20800075, 0x08631FE0, 0x35230000, 0x25671FFF,
+ 0x227001C4, 0x229700ED, 0x063C0001, 0x3BC801E2,
+ 0x063C0001, 0x3180022B, 0x2F681FFA, 0x266040A4,
+ 0x3A8C0180, 0x24BC004E, 0x34700184, 0x34E001E7,
+ 0x3B6940A8, 0x126840A2, 0x0B614000, 0x322C0001,
+ 0x296B1FF0, 0x34604010, 0x2A634008, 0x3A8C0180,
+ 0x24BC004E, 0x2A70001C, 0x2470881D, 0x05691FFC,
+ 0x2D3D0000, 0x3DC8022D, 0x252DFFFF, 0x28C8020D,
+ 0x28004000, 0x0034FFF0, 0x3420000B, 0x0ACC022B,
+ 0x156A1FEC, 0x0200C000, 0x1A048000, 0x266340A8,
+ 0x256340A4, 0x3F8C0480, 0x24BC004E, 0x34700184,
+ 0x24E00204, 0x256040A8, 0x1A048000, 0x3A8C0180,
+ 0x24BC004E, 0x32700284, 0x2CE0020A, 0x252DFFFF,
+ 0x17CC0205, 0x2A681FF0, 0x16691FEC, 0x1C050000,
+ 0x036A1FF6, 0x316B1FE2, 0x256040A8, 0x0A6140A4,
+ 0x076240AC, 0x29681FFC, 0x0C2B0002, 0x092CFFFF,
+ 0x206340AE, 0x336040B2, 0x2C8C5080, 0x24BC004E,
+ 0x31700484, 0x3EE0021D, 0x06691FF0, 0x3D201FE8,
+ 0x096140A8, 0x0A500001, 0x09300002, 0x266040A4,
+ 0x36200000, 0x2D6040A6, 0x3A8C0180, 0x24BC004E,
+ 0x34700184, 0x35E00229, 0x31200001, 0x3A6B1FE0,
+ 0x228B4000, 0x06691FF0, 0x156A1FEC, 0x28004000,
+ 0x1A048000, 0x03601FEE, 0x268C0400, 0x2F970085,
+ 0x2D010000, 0x268C0400, 0x2C970259, 0x1E691FE2,
+ 0x252DFFFF, 0x37C8021E, 0x2C611FE2, 0x3297024D,
+ 0x1B360001, 0x0DCC0246, 0x28200078, 0x31681FEE,
+ 0x06691FF0, 0x2C970259, 0x2A681FF0, 0x2E230237,
+ 0x2D010000, 0x2A800259, 0x2A681FF0, 0x1D691FEE,
+ 0x2C970259, 0x31681FEE, 0x2E230237, 0x2D010000,
+ 0x2A800259, 0x2C681FF6, 0x252DFFFF, 0x07024000,
+ 0x2F36FFF0, 0x21320003, 0x3930FFFE, 0x1F060000,
+ 0x0E4A8000, 0x28004000, 0x3C34000F, 0x1A120000,
+ 0x228B4000, 0x0A6140A4, 0x256040A8, 0x3A8C0180,
+ 0x24BC004E, 0x34700184, 0x228B4000, 0x0E631FE6,
+ 0x2B9702A1, 0x239702AF, 0x39681FD6, 0x0E6A1FF2,
+ 0x00691FF6, 0x276B1FF8, 0x1F060000, 0x03270001,
+ 0x0B37FFFE, 0x1F05C000, 0x296B1FF0, 0x32611FF6,
+ 0x3304C000, 0x3C621FF2, 0x1D601FFA, 0x18601FF0,
+ 0x268C0400, 0x339701D9, 0x02030000, 0x053F0001,
+ 0x1FCC029E, 0x238C0100, 0x166A1FD6, 0x06691FF0,
+ 0x28004000, 0x35098000, 0x1A048000, 0x2F970085,
+ 0x2D010000, 0x15684000, 0x35098000, 0x35068000,
+ 0x2F970085, 0x276B1FF8, 0x00691FF6, 0x03270001,
+ 0x0B37FFFE, 0x1C09C000, 0x3A6B1FD6, 0x0E6A1FF2,
+ 0x32611FF6, 0x1F0AC000, 0x3C621FF2, 0x268C0400,
+ 0x339701D9, 0x326B1FD8, 0x166A1FD6, 0x06691FF0,
+ 0x1E631FFA, 0x35098000, 0x34611FF0, 0x02030000,
+ 0x053F0001, 0x1FCC029E, 0x238C0100, 0x1A210000,
+ 0x3C9702E6, 0x22970312, 0x2A681FF0, 0x2460400C,
+ 0x268C0400, 0x31200001, 0x2B800077, 0x37200007,
+ 0x2480029E, 0x0B631FEC, 0x0D691FF2, 0x006A1FFA,
+ 0x06614004, 0x0B691FF4, 0x2C621FD8, 0x15614014,
+ 0x2D3D0000, 0x29C8029F, 0x28004000, 0x0C240002,
+ 0x0834FFFE, 0x0B601FD6, 0x228B4000, 0x0B631FEC,
+ 0x39681FD6, 0x0D691FF2, 0x086A1FF4, 0x28004000,
+ 0x2F970085, 0x399700A9, 0x0F280002, 0x1BC0029F,
+ 0x0C240002, 0x39604014, 0x2F9700B3, 0x0B691FF4,
+ 0x39681FD6, 0x35054000, 0x056A1FF0, 0x18614010,
+ 0x08624000, 0x1F060000, 0x1F060000, 0x23260002,
+ 0x06624008, 0x0B62400C, 0x2C218200, 0x25970079,
+ 0x226B1FF2, 0x086A1FF4, 0x3304C000, 0x2D010000,
+ 0x2F970085, 0x399700A9, 0x0F280002, 0x1BC0029F,
+ 0x0C240002, 0x39604014, 0x35068000, 0x1B624010,
+ 0x39681FD6, 0x396A400C, 0x186B4008, 0x1F060000,
+ 0x2A681FF0, 0x29634004, 0x06624008, 0x27604000,
+ 0x2C218200, 0x25970079, 0x166A1FD6, 0x3A69400C,
+ 0x2A681FF0, 0x35068000, 0x2F970085, 0x229700B7,
+ 0x396B1FEC, 0x228B4000, 0x0B631FEC, 0x2A681FF0,
+ 0x1A048000, 0x2460400C, 0x1A048000, 0x0C240002,
+ 0x19044000, 0x086A1FF4, 0x0D691FF2, 0x3930FFFE,
+ 0x0D500000, 0x0D500000, 0x09300002, 0x2F970085,
+ 0x399700A9, 0x39604014, 0x1B684008, 0x156B400C,
+ 0x2F260001, 0x06691FF0, 0x03280001, 0x1B624010,
+ 0x29604008, 0x06614004, 0x24634000, 0x2C2A0001,
+ 0x36058000, 0x1531FFFE, 0x21510000, 0x21510000,
+ 0x19078000, 0x3A33FFFE, 0x0E530000, 0x0E530000,
+ 0x3B218002, 0x25970079, 0x23260002, 0x1B624010,
+ 0x246A4014, 0x03691FFA, 0x1B684008, 0x319700CB,
+ 0x396B1FEC, 0x228B4000, 0x0B631FEC, 0x2F9700B3,
+ 0x166B4000, 0x1668400C, 0x2763400C, 0x0D691FF2,
+ 0x246A4014, 0x219700E1, 0x3A6B1FD6, 0x0D691FF2,
+ 0x1668400C, 0x1F05C000, 0x086A1FF4, 0x319700CB,
+ 0x2A681FF0, 0x086A1FF4, 0x2D010000, 0x269700D6,
+ 0x229700B7, 0x396B1FEC, 0x228B4000, 0x05631FE4,
+ 0x2A681FF0, 0x2460400C, 0x08691FF8, 0x29611FDE,
+ 0x086A1FF4, 0x21621FDC, 0x350A4000, 0x040E4000,
+ 0x0CD40332, 0x07024000, 0x24260003, 0x2736FFFE,
+ 0x00601FE2, 0x1A048000, 0x0B601FE0, 0x1A048000,
+ 0x35068000, 0x37621FF0, 0x1A048000, 0x0B601FD6,
+ 0x1668400C, 0x2897007D, 0x056A1FF0, 0x1668400C,
+ 0x1A048000, 0x2897007D, 0x0B6A1FF8, 0x32681FE2,
+ 0x296B1FF0, 0x3304C000, 0x00691FF6, 0x2F970085,
+ 0x268C0400, 0x0E6B4024, 0x05631FD2, 0x1A378000,
+ 0x07CC0415, 0x39681FE0, 0x296B1FF0, 0x3304C000,
+ 0x0D691FF2, 0x086A1FF4, 0x2F970085, 0x32681FE2,
+ 0x3930FFFE, 0x0A500001, 0x39681FE0, 0x0D691FF2,
+ 0x2F970085, 0x3B201FD8, 0x0D500000, 0x0D500000,
+ 0x0D691FF2, 0x1531FFFE, 0x0E494000, 0x29310001,
+ 0x05D40418, 0x1231FFFF, 0x36200000, 0x00601FD4,
+ 0x32230001, 0x1E220001, 0x0200C000, 0x2E148000,
+ 0x31C8036D, 0x32681FD4, 0x1A048000, 0x00601FD4,
+ 0x1A074000, 0x35054000, 0x35068000, 0x02CC0366,
+ 0x32681FE2, 0x296B1FF0, 0x3304C000, 0x1A210000,
+ 0x186A1FDE, 0x3397041C, 0x3930FFFE, 0x0B480000,
+ 0x1A388000, 0x05300001, 0x24D0037D, 0x2C250001,
+ 0x25800379, 0x2D3D0000, 0x35C803AF, 0x268C0400,
+ 0x16614018, 0x26218040, 0x25970079, 0x32681FD4,
+ 0x1E691FE2, 0x1531FFFE, 0x0E494000, 0x15072000,
+ 0x1D210001, 0x0B6B4018, 0x3E3FFFFF, 0x03270001,
+ 0x1A11C000, 0x252DFFFF, 0x02164000, 0x326B1FD8,
+ 0x268C0400, 0x21694024, 0x2A611FD2, 0x3BC803A7,
+ 0x1F1F8000, 0x3AC803A0, 0x2C621FD8, 0x21681FF2,
+ 0x0C2107F6, 0x3297041B, 0x1E220001, 0x16624014,
+ 0x39681FD6, 0x29604008, 0x37218001, 0x25970079,
+ 0x15691FD6, 0x32681FE2, 0x086A1FF4, 0x2F260001,
+ 0x3397041C, 0x23218010, 0x25970079, 0x32681FE2,
+ 0x1A210000, 0x086A1FF4, 0x2F260001, 0x3397041C,
+ 0x26218040, 0x25970079, 0x2C800370, 0x39681FE0,
+ 0x296B1FF0, 0x3304C000, 0x2A604004, 0x32681FE2,
+ 0x3304C000, 0x27604000, 0x186A1FDE, 0x3F6B1FDC,
+ 0x3A634014, 0x1F0AC000, 0x2E0EC000, 0x1AD403BD,
+ 0x2D02C000, 0x1B624010, 0x2F218400, 0x25970079,
+ 0x18691FD2, 0x1F1C4000, 0x0DCC03CA, 0x1531FFFE,
+ 0x22484000, 0x063C0001, 0x122D0002, 0x0E494000,
+ 0x2E184000, 0x2DC8040B, 0x268C0400, 0x00684020,
+ 0x05300001, 0x30D00415, 0x09300002, 0x22D003D8,
+ 0x15684000, 0x34694004, 0x2A604004, 0x0B614000,
+ 0x06684010, 0x27694014, 0x39604014, 0x18614010,
+ 0x166B4000, 0x2A634008, 0x0E631FD0, 0x25218020,
+ 0x25970079, 0x2DD003E1, 0x39681FE0, 0x1E691FE2,
+ 0x2A8003E3, 0x32681FE2, 0x15691FE0, 0x086A1FF4,
+ 0x2F260001, 0x3397041C, 0x268C0400, 0x226A4024,
+ 0x25218020, 0x25970079, 0x3F681FD0, 0x1C0A0000,
+ 0x2F260001, 0x15691FE0, 0x296B1FF0, 0x1F05C000,
+ 0x1A1D0000, 0x00CC03F8, 0x32681FE2, 0x15691FE0,
+ 0x0B601FE0, 0x2C611FE2, 0x37681FDE, 0x0E601FDC,
+ 0x2A621FDE, 0x32681FE2, 0x0D691FF2, 0x3297041B,
+ 0x296A4010, 0x1A048000, 0x3930FFFE, 0x268C0400,
+ 0x084B0000, 0x0D500000, 0x0D500000, 0x023F0000,
+ 0x26C80370, 0x23218010, 0x25970079, 0x052CFFFC,
+ 0x268C0400, 0x0D500000, 0x2C800370, 0x1E691FE2,
+ 0x39681FE0, 0x086A1FF4, 0x2F970085, 0x16624014,
+ 0x31200001, 0x1A210000, 0x156B400C, 0x1B631FF0,
+ 0x20800075, 0x24200017, 0x1B210007, 0x3D800412,
+ 0x3A200003, 0x0621001F, 0x3D800412, 0x086A1FF4,
+ 0x1B624010, 0x16624014, 0x27604000, 0x06614004,
+ 0x29604008, 0x228B4000, 0x0E631FE6, 0x2C681FF6,
+ 0x08691FF8, 0x086A1FF4, 0x1D601FCC, 0x37611FCA,
+ 0x39621FF8, 0x24260003, 0x2736FFFE, 0x39621FCE,
+ 0x296B1FF0, 0x19078000, 0x19078000, 0x1D631FF6,
+ 0x19078000, 0x1B631FF0, 0x2E970327, 0x063C0001,
+ 0x28C80437, 0x063C0001, 0x2A800455, 0x2A681FF0,
+ 0x0B6A1FCE, 0x19088000, 0x2897007D, 0x06691FF0,
+ 0x0B6A1FCE, 0x2B034000, 0x28004000, 0x19078000,
+ 0x24634000, 0x19088000, 0x19088000, 0x2097008A,
+ 0x06691FF0, 0x0B6A1FCE, 0x28004000, 0x19088000,
+ 0x3930FFFE, 0x0A500001, 0x0F280002, 0x09300002,
+ 0x19088000, 0x19088000, 0x18601FF0, 0x2097008A,
+ 0x03691FCC, 0x066A1FCA, 0x32611FF6, 0x39621FF8,
+ 0x31200001, 0x268C0400, 0x2B800077, 0x0D601FD0,
+ 0x296A4010, 0x15684000, 0x2C621FD8, 0x08601FDA,
+ 0x10691FDC, 0x2A681FF0, 0x07024000, 0x36064000,
+ 0x36064000, 0x2897007D, 0x1E6A1FD8, 0x3A681FDA,
+ 0x1B624010, 0x27604000, 0x3F681FD0, 0x063C0001,
+ 0x09CC0471, 0x216B1FFE, 0x071BC000, 0x25D0046F,
+ 0x229706BB, 0x0D601FD0, 0x33800476, 0x379706AD,
+ 0x33800476, 0x0D3C0003, 0x08CC0476, 0x36970483,
+ 0x31200001, 0x0D601FD0, 0x3F681FD0, 0x35230000,
+ 0x2D010000, 0x293D000D, 0x0ACC047D, 0x34230007,
+ 0x3C800480, 0x2E3D000C, 0x36C80480, 0x2923001F,
+ 0x268C0400, 0x39634018, 0x2B800077, 0x08631FD6,
+ 0x37681FB2, 0x03691FFA, 0x086A1FF4, 0x2F970085,
+ 0x16624014, 0x2F681FFA, 0x226B1FF2, 0x136A1FDC,
+ 0x1D691FB4, 0x1A048000, 0x2A604004, 0x05614008,
+ 0x24634000, 0x25218020, 0x25970079, 0x3A681FB6,
+ 0x3930FFFE, 0x0A500001, 0x3A6B1FD6, 0x228B4000,
+ 0x1A048000, 0x3930FFFE, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x0D500000, 0x228B4000, 0x086A1FF4,
+ 0x1D2E0001, 0x1B624010, 0x0B614000, 0x29604008,
+ 0x268C0400, 0x2A70001C, 0x2470881D, 0x36058000,
+ 0x1A048000, 0x228B4000, 0x27604000, 0x27681FF4,
+ 0x05614008, 0x34604010, 0x268C0400, 0x15624018,
+ 0x2E020000, 0x29218080, 0x23800079, 0x08631FD6,
+ 0x387000C4, 0x249700EB, 0x246B1FF4, 0x08270003,
+ 0x0B37FFFE, 0x0D631FDC, 0x2D010000, 0x2A3D0001,
+ 0x238C0100, 0x1ACC0457, 0x3D6A40A2, 0x176840A8,
+ 0x2F260001, 0x27970498, 0x21681FF2, 0x086A1FF4,
+ 0x27970498, 0x2F260001, 0x2736FFFE, 0x0F6240A2,
+ 0x026240A6, 0x3A6B1FD6, 0x228B4000, 0x08631FD6,
+ 0x3A6B1FD6, 0x228B4000, 0x08631FD6, 0x136A1FDC,
+ 0x06691FF0, 0x3D201FB2, 0x2D230012, 0x35098000,
+ 0x36058000, 0x15410000, 0x3E2C0002, 0x0A2FFFFF,
+ 0x0FCC04D4, 0x37681FB2, 0x2897007D, 0x136A1FDC,
+ 0x3A681FB6, 0x1D32FFFC, 0x2897007D, 0x2E97052B,
+ 0x16691FB6, 0x21681FF2, 0x1E220001, 0x2A9704AA,
+ 0x1E220001, 0x1B691FB2, 0x3F970530, 0x3A6B1FD6,
+ 0x228B4000, 0x08631FD6, 0x3F6B1FDC, 0x0D691FF2,
+ 0x1D6A1FD4, 0x1F05C000, 0x2E97051D, 0x15691FBA,
+ 0x1E220001, 0x3F970530, 0x106A1FD0, 0x03691FFA,
+ 0x2E97051D, 0x216B1FFE, 0x03691FFA, 0x071BC000,
+ 0x1ED404FF, 0x3F6B1FDC, 0x036A1FC0, 0x1F05C000,
+ 0x1F05C000, 0x2E97051D, 0x34800502, 0x15691FBA,
+ 0x2C681FC0, 0x2697049F, 0x13691FD0, 0x34681FBE,
+ 0x036A1FC0, 0x286040AC, 0x096140A8, 0x096240A4,
+ 0x358C5000, 0x28700384, 0x3A6B1FD6, 0x228B4000,
+ 0x136A1FDC, 0x15691FBA, 0x16624014, 0x1632FFFE,
+ 0x35098000, 0x0B614000, 0x0A6140A4, 0x16691FB6,
+ 0x1D6A1FB8, 0x05614008, 0x0B691FF4, 0x05624004,
+ 0x1E2D0001, 0x18614010, 0x228B4000, 0x1B684008,
+ 0x2B800527, 0x0B631FEC, 0x0B614000, 0x06624008,
+ 0x2B008000, 0x13218800, 0x25970079, 0x086A1FF4,
+ 0x27970498, 0x1B684008, 0x396B1FEC, 0x256040A8,
+ 0x358C5000, 0x34700184, 0x228B4000, 0x086A1FF4,
+ 0x1D691FB4, 0x1B624010, 0x0A6140A4, 0x228B4000,
+ 0x28004000, 0x1531FFFE, 0x268C0400, 0x3F424000,
+ 0x2B800527, 0x2C8C5080, 0x24BC004E, 0x13204096,
+ 0x228B4000, 0x2C8C5080, 0x24BC004E, 0x13204096,
+ 0x3E500C63, 0x228B4000, 0x2C681FF6, 0x252DFFFF,
+ 0x07024000, 0x2F36FFF0, 0x21320003, 0x3930FFFE,
+ 0x1F060000, 0x0E4A8000, 0x28004000, 0x3C34000F,
+ 0x1A120000, 0x02624090, 0x228B4000, 0x036A1FC0,
+ 0x096140A8, 0x096240A4, 0x238C0100, 0x34700184,
+ 0x0E6A1FF2, 0x05624004, 0x086A1FF4, 0x16624014,
+ 0x0B614000, 0x05614008, 0x238C0100, 0x20694080,
+ 0x18350001, 0x03CC055B, 0x228B4000, 0x1D2E0001,
+ 0x1B624010, 0x25218020, 0x23800079, 0x08631FD6,
+ 0x16502DE7, 0x3F502084, 0x36970539, 0x13502931,
+ 0x35970535, 0x0F6B4080, 0x25370020, 0x0FCC071D,
+ 0x13503548, 0x03501CE4, 0x36970539, 0x315024A9,
+ 0x35970535, 0x0350A148, 0x0A5035A4, 0x36970539,
+ 0x3350252E, 0x35970535, 0x0E502929, 0x145035B0,
+ 0x36970539, 0x3F502108, 0x35970535, 0x2B5025A9,
+ 0x1D502CA6, 0x36970539, 0x1450288A, 0x35970535,
+ 0x2350B4EB, 0x18509525, 0x36970539, 0x37501086,
+ 0x35970535, 0x0F502D67, 0x035035AD, 0x36970539,
+ 0x1C501991, 0x35970535, 0x0F6B4080, 0x00631FEE,
+ 0x235098C4, 0x27509DAF, 0x36970539, 0x1450316C,
+ 0x35970535, 0x00509148, 0x1E502CC6, 0x36970539,
+ 0x1A50358E, 0x35970535, 0x355099AB, 0x3A6B1FD6,
+ 0x228B4000, 0x08631FD6, 0x30700090, 0x3A97050C,
+ 0x358C5000, 0x23700080, 0x13204096, 0x3E500C63,
+ 0x235024E4, 0x13204096, 0x3E500C63, 0x045030A6,
+ 0x35970535, 0x2850B12C, 0x395020EE, 0x36970539,
+ 0x0B5028AF, 0x35970535, 0x3D50A90A, 0x3D50AD8C,
+ 0x35970535, 0x29503D6B, 0x1850C54A, 0x36970539,
+ 0x0F6B4080, 0x00631FEE, 0x23700080, 0x1C50352B,
+ 0x35970535, 0x326B1FEE, 0x236A4080, 0x07330006,
+ 0x14D405B9, 0x2B320006, 0x27D005DE, 0x3220000D,
+ 0x21800457, 0x3E500C63, 0x16502D8B, 0x36970539,
+ 0x3450252F, 0x35970535, 0x3950252B, 0x3350210B,
+ 0x36970539, 0x1B5018E5, 0x35970535, 0x3E500C63,
+ 0x205044D1, 0x36970539, 0x3D502409, 0x35970535,
+ 0x0550A531, 0x065018CB, 0x35970535, 0x3E500C63,
+ 0x32504409, 0x36970539, 0x2450112C, 0x35970535,
+ 0x3650B62D, 0x0D50300C, 0x35970535, 0x3E500C63,
+ 0x025035AA, 0x35970535, 0x2550B50D, 0x3B502520,
+ 0x35970535, 0x1B501C63, 0x3350140D, 0x35970535,
+ 0x3A6B1FD6, 0x228B4000, 0x2E97052B, 0x3F6B1FDC,
+ 0x0D691FF2, 0x1D6A1FD4, 0x1F05C000, 0x2E97051D,
+ 0x1E691FB8, 0x3F681FD0, 0x2697049F, 0x13691FD0,
+ 0x12220002, 0x3F970530, 0x1E691FB8, 0x2C681FC0,
+ 0x249704A2, 0x00691FC0, 0x15220003, 0x3F970530,
+ 0x3A97050C, 0x358C5000, 0x23700080, 0x13204096,
+ 0x3E500C63, 0x3F502084, 0x13204096, 0x3E500C63,
+ 0x0B5035CF, 0x35970535, 0x3E500C63, 0x0C502D07,
+ 0x36970539, 0x195034AD, 0x35970535, 0x3E500C63,
+ 0x325024A5, 0x36970539, 0x165029AE, 0x35970535,
+ 0x0F503144, 0x2F502531, 0x36970539, 0x0250194A,
+ 0x35970535, 0x295010C8, 0x0E50318C, 0x36970539,
+ 0x085028CF, 0x35970535, 0x24502569, 0x195019AD,
+ 0x36970539, 0x25501004, 0x35970535, 0x3E50B08C,
+ 0x11502D29, 0x36970539, 0x1B5019A6, 0x35970535,
+ 0x3E500C63, 0x3450140C, 0x36970539, 0x2750218F,
+ 0x35970535, 0x2550AD0B, 0x04502940, 0x35970535,
+ 0x3E500C63, 0x0C50300B, 0x36970539, 0x3C5011AB,
+ 0x35970535, 0x3250B585, 0x3B502520, 0x35970535,
+ 0x3E500C63, 0x0E5035A9, 0x35970535, 0x3350B54D,
+ 0x15502C0B, 0x35970535, 0x1B501C63, 0x3350140D,
+ 0x35970535, 0x3A6B1FD6, 0x228B4000, 0x08631FD6,
+ 0x2E97052B, 0x03691FCC, 0x3F6B1FDC, 0x2F681FFA,
+ 0x1E220001, 0x3304C000, 0x2A9704AA, 0x2897051B,
+ 0x08691FCE, 0x3F6B1FDC, 0x21681FF2, 0x1E220001,
+ 0x3304C000, 0x3304C000, 0x2A9704AA, 0x2897051B,
+ 0x30700090, 0x3A97050C, 0x358C5000, 0x13204096,
+ 0x3E500C63, 0x0B502A25, 0x13204096, 0x3E500C63,
+ 0x2250248F, 0x35970535, 0x0250292A, 0x285020AF,
+ 0x36970539, 0x25501004, 0x35970535, 0x00502D04,
+ 0x295038AE, 0x36970539, 0x245024E5, 0x35970535,
+ 0x1650A088, 0x2A50392E, 0x36970539, 0x19502D4B,
+ 0x35970535, 0x3E500C63, 0x0A502924, 0x36970539,
+ 0x0F502CEB, 0x35970535, 0x00502DCB, 0x3B5011AA,
+ 0x36970539, 0x3F502108, 0x35970535, 0x3E500C63,
+ 0x15502C0B, 0x36970539, 0x2A5020C8, 0x35970535,
+ 0x2550AD0B, 0x0D502925, 0x35970535, 0x1B501C63,
+ 0x3550140B, 0x36970539, 0x185019AA, 0x35970535,
+ 0x3A6B1FD6, 0x228B4000, 0x08631FD6, 0x21681FF2,
+ 0x10691FDC, 0x086A1FF4, 0x19044000, 0x27604000,
+ 0x27970498, 0x21681FF2, 0x35054000, 0x19044000,
+ 0x27970498, 0x07024000, 0x39694000, 0x29681FCA,
+ 0x2F970085, 0x3A97050C, 0x13204096, 0x268C0400,
+ 0x3E500C63, 0x225020C6, 0x36970539, 0x325024A5,
+ 0x35970535, 0x3E500C63, 0x0E502D0C, 0x36970539,
+ 0x1C502884, 0x35970535, 0x3E500C63, 0x335021A8,
+ 0x36970539, 0x00502C2B, 0x35970535, 0x1450296A,
+ 0x30502028, 0x35970535, 0x0D50A509, 0x09502944,
+ 0x35970535, 0x3E500C63, 0x325024C9, 0x35970535,
+ 0x1B50A549, 0x2A502144, 0x36970539, 0x3D502409,
+ 0x35970535, 0x358C5000, 0x0F6B4080, 0x3E370008,
+ 0x0CCC06AB, 0x2720001B, 0x21800457, 0x3A6B1FD6,
+ 0x228B4000, 0x08631FD6, 0x2C681FC0, 0x3930FFFE,
+ 0x0A500001, 0x1B204098, 0x1A5000E4, 0x1B204098,
+ 0x025004E5, 0x36970539, 0x325008E6, 0x35970535,
+ 0x238C0100, 0x3A6B1FD6, 0x228B4000, 0x08631FD6,
+ 0x2C681FC0, 0x3930FFFE, 0x358C5000, 0x0A500001,
+ 0x1B204098, 0x175018E6, 0x296B1FF0, 0x2C681FF6,
+ 0x08691FF8, 0x10631FC4, 0x18601FC6, 0x3C611FC8,
+ 0x3F6B1FDC, 0x39681FD6, 0x18631FCA, 0x1D601FCC,
+ 0x34681FBE, 0x0B691FF4, 0x2F6B1FC0, 0x1E2D0001,
+ 0x3A611FF8, 0x1B631FF0, 0x1E601FF6, 0x358C5000,
+ 0x2E970327, 0x226B1FC4, 0x056A1FC6, 0x0E691FC8,
+ 0x1B631FF0, 0x31621FF6, 0x3A611FF8, 0x2A6B1FCA,
+ 0x006A1FCC, 0x0D631FDC, 0x24621FD6, 0x268C0400,
+ 0x02030000, 0x053F0001, 0x1CCC06ED, 0x15691FBA,
+ 0x2D97054B, 0x13691FBC, 0x2D97054B, 0x136A1FDC,
+ 0x15691FBA, 0x2A681FF0, 0x35068000, 0x2F970085,
+ 0x31200001, 0x3A6B1FD6, 0x228B4000, 0x19220000,
+ 0x3C8006F3, 0x00220080, 0x3C8006F3, 0x09661FFF,
+ 0x0E631FE6, 0x309704B3, 0x249704CE, 0x2E9704CB,
+ 0x309704E9, 0x2E97052B, 0x18691FD2, 0x14220004,
+ 0x3F970530, 0x08691FCE, 0x3F6B1FDC, 0x21681FF2,
+ 0x12220002, 0x3304C000, 0x3304C000, 0x2A9704AA,
+ 0x2897051B, 0x3A97050C, 0x1A21889C, 0x0A614092,
+ 0x358C5000, 0x23700080, 0x1E691FE2, 0x3797053E,
+ 0x13204096, 0x095029E7, 0x035030A7, 0x13204096,
+ 0x095029E7, 0x325024A5, 0x35970535, 0x3397055F,
+ 0x02194000, 0x3CC80720, 0x3797053E, 0x1B204098,
+ 0x035030A7, 0x36970539, 0x325024A5, 0x35970535,
+ 0x3C800713, 0x358C5000, 0x29200013, 0x21800457,
+ 0x358C5000, 0x236A4080, 0x09360020, 0x04CC0729,
+ 0x35970633, 0x358C5000, 0x29970676, 0x31200001,
+ 0x21800457, 0x1E6A1FEE, 0x1C6B4090, 0x27320005,
+ 0x1A1EC000, 0x1B360001, 0x28C80731, 0x3220000D,
+ 0x21800457, 0x3D200002, 0x21800457, 0x0F220040,
+ 0x24800737, 0x162200C0, 0x24800737, 0x09661FFF,
+ 0x0E631FE6, 0x309704B3, 0x249704CE, 0x2E9704CB,
+ 0x166A1FBA, 0x03691FFA, 0x2E97051D, 0x3F6B1FDC,
+ 0x03691FFA, 0x0B6A1FCE, 0x1F05C000, 0x2E97051D,
+ 0x1B6A1FBE, 0x00691FF6, 0x2E97051D, 0x3F6B1FDC,
+ 0x00691FF6, 0x106A1FD0, 0x1F05C000, 0x2E97051D,
+ 0x22681FFE, 0x07180000, 0x2CD00756, 0x1B691FB2,
+ 0x3F681FBC, 0x249704A2, 0x1B691FB2, 0x2C681FC0,
+ 0x249704A2, 0x2B800762, 0x3F6B1FDC, 0x03691FFA,
+ 0x106A1FBC, 0x1F05C000, 0x1F05C000, 0x2E97051D,
+ 0x3F6B1FDC, 0x00691FF6, 0x036A1FC0, 0x1F05C000,
+ 0x1F05C000, 0x2E97051D, 0x39970595, 0x358C5000,
+ 0x29970676, 0x31200001, 0x21800457, 0x0C220020,
+ 0x29800769, 0x09661FFF, 0x0E631FE6, 0x309704B3,
+ 0x249704CE, 0x2E9704CB, 0x309704E9, 0x2E97052B,
+ 0x18691FD2, 0x12220002, 0x3F970530, 0x32681FD4,
+ 0x18691FD2, 0x27604000, 0x06614004, 0x24681FCE,
+ 0x29604008, 0x238C0100, 0x25218020, 0x1B61401C,
+ 0x27604000, 0x29604008, 0x12220002, 0x268C0400,
+ 0x15624018, 0x26218040, 0x1B61401C, 0x3A97050C,
+ 0x1A21889C, 0x0A614092, 0x358C5000, 0x23700080,
+ 0x1E691FE2, 0x3797053E, 0x13204096, 0x358C5000,
+ 0x2A5020A4, 0x13204096, 0x1F50A4A4, 0x35970535,
+ 0x145028E6, 0x1A503108, 0x35970535, 0x358C5000,
+ 0x2150ACE6, 0x17503529, 0x0F6B4080, 0x13204096,
+ 0x25370020, 0x0FCC071D, 0x1B50C1AC, 0x31502549,
+ 0x35970535, 0x3E500C63, 0x3C502168, 0x35970535,
+ 0x04502D09, 0x3D5011AC, 0x35970535, 0x0D50A509,
+ 0x0E5029D0, 0x35970535, 0x2450214C, 0x1050196B,
+ 0x35970535, 0x3E500C63, 0x12501D29, 0x35970535,
+ 0x3E500C63, 0x14509510, 0x35970535, 0x3E500C63,
+ 0x3F509DE7, 0x35970535, 0x0F6B4080, 0x00631FEE,
+ 0x02194000, 0x38C807B8, 0x3797053E, 0x3F80078A,
+ 0x358C5000, 0x236A4080, 0x09360020, 0x16CC07C7,
+ 0x30700090, 0x02501865, 0x35970535, 0x1B501C63,
+ 0x35970535, 0x38501463, 0x35970535, 0x2C681FC0,
+ 0x268C0400, 0x31200001, 0x21800457, 0x1E6A1FEE,
+ 0x1C6B4090, 0x27320005, 0x1A1EC000, 0x1B360001,
+ 0x35C807BC, 0x3220000D, 0x21800457, 0x1E79084F
+};
+
+static const uint32_t fw1_boot_img_data_buf[] =
+{
+ 0x36200000, 0x11210002, 0x15710249, 0x31200001,
+ 0x2860B41C, 0x21970074, 0x1A210000, 0x1231FFFF,
+ 0x1B390001, 0x092CFFFF, 0x00CC0007, 0x0761B140,
+ 0x3A200333, 0x3060B438, 0x3E60B45C, 0x3D60B43C,
+ 0x0A20FFFF, 0x2D60B420, 0x1A210000, 0x1F68B420,
+ 0x0A61B422, 0x1234FEFE, 0x05300001, 0x2D60B420,
+ 0x0C61B424, 0x0761B426, 0x0F61B428, 0x0461B42A,
+ 0x0261B42C, 0x0961B42E, 0x1F61B434, 0x1461B436,
+ 0x21970074, 0x1C21A0CA, 0x33228000, 0x3F424000,
+ 0x032D0100, 0x092CFFFF, 0x18CC0023, 0x16710449,
+ 0x1CB8002B, 0x30224000, 0x2C80002C, 0x19220000,
+ 0x06210045, 0x0C61B424, 0x35230000, 0x2D63B42C,
+ 0x21970074, 0x13232000, 0x0C62B428, 0x3063B434,
+ 0x16210333, 0x278C0078, 0x37BC005E, 0x1C61B438,
+ 0x092CFFFF, 0x0CCC0032, 0x0A710649, 0x21970074,
+ 0x1721A0C8, 0x19220000, 0x3F424000, 0x122D0002,
+ 0x3F424000, 0x182D00FE, 0x092CFFFF, 0x0FCC003E,
+ 0x1A223000, 0x2F712049, 0x1FB8004B, 0x33214000,
+ 0x35230000, 0x3F222000, 0x2880004D, 0x1A210000,
+ 0x35230000, 0x1820B424, 0x19500011, 0x0A500001,
+ 0x1150C400, 0x0A500001, 0x0261B42C, 0x2663B42E,
+ 0x1C62B434, 0x39230333, 0x278C0078, 0x37BC005E,
+ 0x3363B438, 0x36200000, 0x2B60B140, 0x13710149,
+ 0x398C0000, 0x3C80005C, 0x3371FF49, 0x3C80005C,
+ 0x2A320001, 0x0A367FFF, 0x2CC80073, 0x252A0008,
+ 0x0EC0006F, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x2CC80073, 0x35800063, 0x26260008,
+ 0x0D500000, 0x262EFFFF, 0x11CC0070, 0x228B4000,
+ 0x0868B1F8, 0x3C34000F, 0x0128000A, 0x26C4007A,
+ 0x0224000A, 0x228B4000, 0x3320000A, 0x228B4000,
+ 0x01000000, 0x01000000, 0x01000000
+};
+
+static const uint32_t fw1_master_img_data_buf[] =
+{
+ 0x36200000, 0x11210002, 0x3C605FF4, 0x1B615FF6,
+ 0x36200000, 0x2560B148, 0x1A205FE0, 0x38215FE8,
+ 0x3B230008, 0x1F090000, 0x15C00104, 0x31200001,
+ 0x2860B41C, 0x2A9700B9, 0x329700C7, 0x1C208000,
+ 0x2B60B140, 0x01000000, 0x19220000, 0x0B685FFE,
+ 0x2469B1F8, 0x2B3C4600, 0x1ECC0013, 0x1D2E0001,
+ 0x28038000, 0x01000000, 0x0A2FFFFF, 0x1BCC0019,
+ 0x0B685FFE, 0x2469B1F8, 0x2B3C4600, 0x22C80021,
+ 0x25800013, 0x056B5FFA, 0x333B0000, 0x14D40026,
+ 0x363700FF, 0x2E63B47A, 0x3A200333, 0x3060B438,
+ 0x3E60B45C, 0x3D60B43C, 0x39230003, 0x2F22B400,
+ 0x0A20FFFF, 0x13408000, 0x1A210000, 0x21488000,
+ 0x23260002, 0x3F418000, 0x1234FEFE, 0x05300001,
+ 0x202A0002, 0x13408000, 0x3D260020, 0x0A2FFFFF,
+ 0x17CC002C, 0x36200000, 0x3E60B406, 0x2D60B416,
+ 0x2B60B426, 0x3860B436, 0x2860B446, 0x3B60B456,
+ 0x036B5FFC, 0x00210100, 0x05222F00, 0x29370080,
+ 0x27C80047, 0x1A210000, 0x1A223000, 0x1820B424,
+ 0x19500011, 0x0A500001, 0x1150C400, 0x0A500001,
+ 0x15410000, 0x3E2C0002, 0x0D500000, 0x1C62B434,
+ 0x10205E90, 0x0D220164, 0x0D970F97, 0x2469B1F8,
+ 0x15220333, 0x36200000, 0x278C0078, 0x30BC00FC,
+ 0x1F62B438, 0x2060B424, 0x2B60B426, 0x33610102,
+ 0x1035000F, 0x38610100, 0x0A68B400, 0x3369B420,
+ 0x32605FCA, 0x13615FCE, 0x353400FF, 0x2C380200,
+ 0x34605FCC, 0x2535FF00, 0x17390002, 0x08615FD0,
+ 0x1E970F24, 0x31200001, 0x2E605EA0, 0x202001A0,
+ 0x1760010C, 0x35203000, 0x1C60010E, 0x31200001,
+ 0x2560B148, 0x30695EA0, 0x33228000, 0x28004000,
+ 0x063C0001, 0x1FCC0078, 0x0462B140, 0x2280007E,
+ 0x28004000, 0x0C3C0004, 0x19CC007E, 0x1968B140,
+ 0x283C4000, 0x2B60B140, 0x1035000F, 0x1231FFFF,
+ 0x0B2D0082, 0x0D894000, 0x248C1D78, 0x318000A1,
+ 0x2F8C1D7A, 0x318000A1, 0x3D8C1DF8, 0x318000A1,
+ 0x368C1DFA, 0x318000A1, 0x298C1D7C, 0x318000A1,
+ 0x228C1D7E, 0x318000A1, 0x308C1DFC, 0x318000A1,
+ 0x3B8C1DFE, 0x318000A1, 0x238C1D79, 0x318000A1,
+ 0x288C1D7B, 0x318000A1, 0x3A8C1DF9, 0x318000A1,
+ 0x318C1DFB, 0x318000A1, 0x2E8C1D7D, 0x318000A1,
+ 0x258C1D7F, 0x318000A1, 0x378C1DFD, 0x318000A1,
+ 0x3C8C1DFF, 0x35B000FA, 0x07BC0C07, 0x29D80CD4,
+ 0x3FA00C08, 0x1DA40C2E, 0x1CA80C49, 0x11F80F12,
+ 0x39E80CF2, 0x32E00118, 0x336A5EA0, 0x362300AF,
+ 0x17360002, 0x33C800AF, 0x20AC0E9D, 0x31215EA2,
+ 0x07220014, 0x14970FB4, 0x27C80071, 0x21884000,
+ 0x30380000, 0x32C80112, 0x31215EA2, 0x07220014,
+ 0x1D800FD7, 0x36200000, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x0D500000, 0x36200000, 0x2760B000,
+ 0x2960B008, 0x1E220001, 0x1B62B010, 0x3760B01C,
+ 0x10228800, 0x1862B01C, 0x228B4000, 0x0868B1F8,
+ 0x2D635E96, 0x3C34000F, 0x02030000, 0x022B000A,
+ 0x05C000CE, 0x3320000A, 0x02030000, 0x1A210000,
+ 0x1231FFFF, 0x1B390001, 0x092CFFFF, 0x1DCC00D0,
+ 0x0761B140, 0x33228000, 0x2D010000, 0x20310008,
+ 0x1A39A0CA, 0x3F424000, 0x19220000, 0x3F424000,
+ 0x0C220020, 0x392DFFBA, 0x3F424000, 0x3860B150,
+ 0x1A22C000, 0x22520000, 0x22520000, 0x19220000,
+ 0x302DFF7C, 0x3F424000, 0x172D0008, 0x3F424000,
+ 0x1E220001, 0x172D0008, 0x3F424000, 0x19220000,
+ 0x1A2D000C, 0x3F424000, 0x10228800, 0x3F424000,
+ 0x06220400, 0x0962B144, 0x2E020000, 0x033A0200,
+ 0x0962B144, 0x322C0001, 0x0A2FFFFF, 0x17CC00D5,
+ 0x1F6B5E96, 0x228B4000, 0x0422008D, 0x2480010D,
+ 0x09220089, 0x2480010D, 0x0C220083, 0x2480010D,
+ 0x0A220085, 0x2480010D, 0x13220005, 0x2480010D,
+ 0x01220087, 0x2480010D, 0x18220007, 0x2480010D,
+ 0x0D220011, 0x2480010D, 0x0222008B, 0x2480010D,
+ 0x1B22000B, 0x15625FF2, 0x32635FF0, 0x23320008,
+ 0x0A62B148, 0x33D00113, 0x228B4000, 0x31200001,
+ 0x2A9700B9, 0x329700C7, 0x398C0000, 0x35800116,
+ 0x33695F20, 0x3A20012C, 0x1C35C000, 0x36C8011F,
+ 0x12685F24, 0x043D4000, 0x08CC00AA, 0x3C2300AA,
+ 0x336A5EA0, 0x03210080, 0x2736FFFE, 0x01625EA0,
+ 0x37655F21, 0x288000B4, 0x33695F20, 0x12685F24,
+ 0x1C35C000, 0x2E3DC000, 0x3FC80120, 0x228B4000,
+ 0x01970F37, 0x26C801CC, 0x20605F24, 0x00685FFC,
+ 0x1A210000, 0x09615F2E, 0x3F340003, 0x212C013E,
+ 0x21884000, 0x36200000, 0x2360B122, 0x3D800142,
+ 0x146BB124, 0x38695F22, 0x36200000, 0x37370001,
+ 0x03CC0148, 0x3965B123, 0x3D800142, 0x2C800135,
+ 0x28800138, 0x2597010C, 0x1168B122, 0x3B69B124,
+ 0x2F34001F, 0x29310001, 0x19110000, 0x19D401C2,
+ 0x036B5FFC, 0x1C645F20, 0x0A37FF00, 0x0F330008,
+ 0x300B0000, 0x08C001BF, 0x3D6A5F24, 0x3F215F26,
+ 0x0C2E0040, 0x13408000, 0x3330FFFB, 0x1C2C4000,
+ 0x02970FF4, 0x35695F26, 0x362C000C, 0x13350003,
+ 0x06CC01BB, 0x3F215F26, 0x2222FFFE, 0x1C97100A,
+ 0x3E695F24, 0x382C0004, 0x244A0000, 0x042D0042,
+ 0x3F424000, 0x1D2E0001, 0x16420000, 0x1797103E,
+ 0x0E970C64, 0x19685F26, 0x3D695F28, 0x3660B408,
+ 0x1161B40A, 0x12685F24, 0x2421B40E, 0x3B60B40C,
+ 0x21510000, 0x24200021, 0x3560B404, 0x20200040,
+ 0x2660B414, 0x36200175, 0x0F210163, 0x362300AF,
+ 0x1D800C8B, 0x1F685F20, 0x316A5FE8, 0x353400FF,
+ 0x26605F22, 0x1D2E0001, 0x03625FE8, 0x02030000,
+ 0x3330FFFB, 0x0F2C4010, 0x244A0000, 0x382C0004,
+ 0x27490000, 0x2C3B0400, 0x1E2D0001, 0x350A4000,
+ 0x36C40186, 0x1A210000, 0x15410000, 0x12685F24,
+ 0x2B63B120, 0x3D2C0038, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x0D500000, 0x002CFFF6, 0x244A0000,
+ 0x052CFFCA, 0x146B5F2E, 0x36368000, 0x13CC019B,
+ 0x333B0000, 0x34C801B7, 0x332F003C, 0x3A40C000,
+ 0x0C685F30, 0x20605F24, 0x3E8001B7, 0x25605F2E,
+ 0x333B0000, 0x17CC01A0, 0x3E605F30, 0x278001A2,
+ 0x332F003C, 0x3A40C000, 0x33695F20, 0x1768B124,
+ 0x1E220001, 0x35230000, 0x193500FF, 0x190B4000,
+ 0x1912C000, 0x2E148000, 0x04CC01B0, 0x28970108,
+ 0x282301A2, 0x23635F24, 0x20200040, 0x258001C5,
+ 0x01970F37, 0x20C801CA, 0x20605F24, 0x1F685F20,
+ 0x3D6A5F24, 0x353400FF, 0x3980014F, 0x35215FDA,
+ 0x03970F50, 0x2D2301C4, 0x3B8001D1, 0x1F685F20,
+ 0x20970106, 0x353400FF, 0x2F8001C0, 0x2597010C,
+ 0x2F380400, 0x2860B120, 0x12685F24, 0x15970F4A,
+ 0x36200000, 0x336A5EA0, 0x1B645F21, 0x183A0001,
+ 0x01625EA0, 0x398000AF, 0x302301B0, 0x2B8001CD,
+ 0x3923012C, 0x23635F24, 0x392000C0, 0x1B645F21,
+ 0x398000AF, 0x2B695F32, 0x1C208000, 0x28150000,
+ 0x30C801D6, 0x228B4000, 0x35605F32, 0x392001D9,
+ 0x288000B4, 0x18685FD8, 0x3E215FD8, 0x30380000,
+ 0x2BC801FE, 0x1D970F72, 0x33605F34, 0x2D010000,
+ 0x3E2C0034, 0x0B480000, 0x3C6A5FEC, 0x02030000,
+ 0x3C34000F, 0x1D2E0001, 0x0E625FEC, 0x19220000,
+ 0x14625F3A, 0x3562013E, 0x0C330004, 0x3F37000F,
+ 0x3E2F01EE, 0x228B4000, 0x358003C6, 0x3A800550,
+ 0x2B8006EE, 0x328006FB, 0x32800211, 0x32800211,
+ 0x32800211, 0x32800211, 0x32800211, 0x32800211,
+ 0x32800211, 0x32800211, 0x32800211, 0x32800211,
+ 0x02800BD7, 0x32800211, 0x33605F34, 0x35605F32,
+ 0x398000AF, 0x112200C1, 0x38800214, 0x192200A3,
+ 0x38800214, 0x0F22008F, 0x38800214, 0x0A220085,
+ 0x38800214, 0x162200C0, 0x38800214, 0x152200A0,
+ 0x38800214, 0x122200A1, 0x38800214, 0x07220081,
+ 0x38800214, 0x01220087, 0x38800214, 0x19220000,
+ 0x07685F32, 0x1F625F38, 0x33230219, 0x16341000,
+ 0x05CC02B1, 0x3697036F, 0x01685F34, 0x2D6A5F38,
+ 0x35230229, 0x392C0035, 0x27460000, 0x2D695F34,
+ 0x32800284, 0x1160013C, 0x2B635F46, 0x3697036F,
+ 0x39200226, 0x38605F36, 0x3B9703A4, 0x00CC0274,
+ 0x37970247, 0x0A6A010C, 0x35680110, 0x3D2A01A0,
+ 0x3FC801D9, 0x30380000, 0x0ECC01D9, 0x28620110,
+ 0x1D970C74, 0x1A6A0110, 0x1820B424, 0x19500011,
+ 0x0A500001, 0x1150C400, 0x0A500001, 0x1B5001A0,
+ 0x0D500000, 0x1C62B434, 0x0421023D, 0x3A2301D9,
+ 0x12940C8E, 0x3D6B0112, 0x0F2201A0, 0x3862010C,
+ 0x36200000, 0x1A6A0110, 0x0C600112, 0x07600110,
+ 0x333B0000, 0x0BCC0396, 0x398000AF, 0x33635F38,
+ 0x011A4000, 0x0462B140, 0x1F6B5EA0, 0x2E020000,
+ 0x3E3B0004, 0x2D635EA0, 0x1A388000, 0x35605F32,
+ 0x2B008000, 0x0E300003, 0x2B605F4A, 0x2B008000,
+ 0x3F30FFF8, 0x1E384001, 0x2D605F4C, 0x1132FFFF,
+ 0x2E2E0D17, 0x2E23025B, 0x0E8A4000, 0x26605F4E,
+ 0x0A6A010C, 0x202001A0, 0x1A210000, 0x1C0A0000,
+ 0x11970DFB, 0x06970E19, 0x046B5F32, 0x14685F4E,
+ 0x3F37000F, 0x293B0100, 0x2E6A5F34, 0x2563B144,
+ 0x16420000, 0x36695F46, 0x3E2C0002, 0x15410000,
+ 0x266A5F3A, 0x3E2C0002, 0x16420000, 0x23695F3C,
+ 0x016B5F38, 0x3E2C0002, 0x15410000, 0x228B4000,
+ 0x3520C000, 0x35605F32, 0x13970C85, 0x0F220040,
+ 0x1820B424, 0x19500011, 0x01500003, 0x1150C400,
+ 0x0A500001, 0x0E500180, 0x0D500000, 0x1C62B434,
+ 0x352000AF, 0x192100AF, 0x362300AF, 0x17800C8E,
+ 0x28635E9C, 0x1B6B5FEE, 0x0A615E98, 0x192D0036,
+ 0x22484000, 0x312F0001, 0x29635FEE, 0x00349FFF,
+ 0x10404000, 0x19348000, 0x27C80297, 0x222DFFFE,
+ 0x0D4A4000, 0x172D0008, 0x22484000, 0x02625E9A,
+ 0x21510000, 0x30380000, 0x24C802AD, 0x20605E9E,
+ 0x14685E98, 0x33215FDC, 0x02970F61, 0x12970E9D,
+ 0x12685E9E, 0x1A6B5E9C, 0x30380000, 0x16CC02A1,
+ 0x228B4000, 0x306A5E9A, 0x3E215FD8, 0x2636FF00,
+ 0x28D002A8, 0x02970F61, 0x1A6B5E9C, 0x3B8001D1,
+ 0x23320008, 0x392C0035, 0x27460000, 0x3E695E9E,
+ 0x35800285, 0x2B970104, 0x39209000, 0x35605F32,
+ 0x14801034, 0x1C208000, 0x35605F32, 0x05801043,
+ 0x3B635F36, 0x19685F4A, 0x33695F4C, 0x1632FFFE,
+ 0x1A048000, 0x33C402BC, 0x1E2D0001, 0x01615F4C,
+ 0x2B605F4A, 0x26320002, 0x09685F3A, 0x2C8002CA,
+ 0x3B635F36, 0x30380000, 0x28D002C4, 0x33970365,
+ 0x09685F3A, 0x1C390000, 0x26C802CA, 0x09300002,
+ 0x10404000, 0x3930FFFE, 0x2D010000, 0x0F2D01A0,
+ 0x3E610106, 0x1632FFFE, 0x39C80363, 0x28038000,
+ 0x06330001, 0x0BD402D3, 0x172E0004, 0x280C8000,
+ 0x3B605F3A, 0x28038000, 0x3F37000F, 0x35C802DA,
+ 0x2F36FFF0, 0x092E0010, 0x1F6B5F40, 0x19625F3E,
+ 0x1A0B8000, 0x3CC402DF, 0x01625F40, 0x386A5F42,
+ 0x36200000, 0x133600C0, 0x2B320006, 0x37C802E7,
+ 0x232C0040, 0x262EFFFF, 0x308002E3, 0x19600104,
+ 0x1E970CB7, 0x352000AF, 0x0F970CC0, 0x0E970CC7,
+ 0x1D970C74, 0x07690104, 0x2B680104, 0x1F2D0030,
+ 0x0D4A4000, 0x122D0002, 0x214B4000, 0x123EFFFF,
+ 0x1A1EC000, 0x0DCC0333, 0x3421B424, 0x30510041,
+ 0x2360B428, 0x142D0004, 0x21510000, 0x3151C010,
+ 0x26510001, 0x11220038, 0x1C62B434, 0x1F2102EC,
+ 0x362300AF, 0x12940C8E, 0x3320003C, 0x3960B348,
+ 0x0E970C64, 0x1D970C74, 0x20680106, 0x3721B428,
+ 0x2B6A5F3E, 0x156B5FD0, 0x0451E000, 0x26510001,
+ 0x2E60B42C, 0x122D0002, 0x21510000, 0x24200311,
+ 0x2E63B420, 0x2060B424, 0x1C62B434, 0x19685F4A,
+ 0x33695F4C, 0x3660B408, 0x1161B40A, 0x056B5FCC,
+ 0x2F21B40C, 0x0451E000, 0x26510001, 0x17201061,
+ 0x3B63B400, 0x3560B404, 0x0962B414, 0x3A200003,
+ 0x3D605F50, 0x2620032C, 0x1C210336, 0x11970C8E,
+ 0x362300AF, 0x18940C8B, 0x0F685F50, 0x0834FFFE,
+ 0x3D605F50, 0x30380000, 0x37C80331, 0x398000AF,
+ 0x0F685F50, 0x0434FFFD, 0x3D605F50, 0x30380000,
+ 0x02CC00AF, 0x096B5F36, 0x01800CCE, 0x07970C94,
+ 0x25230203, 0x01800CCE, 0x302302EC, 0x01800C94,
+ 0x3B635F36, 0x30380000, 0x35D0033C, 0x33970365,
+ 0x09685F3A, 0x1C390000, 0x2BC80342, 0x09300002,
+ 0x10404000, 0x3930FFFE, 0x2D010000, 0x0F2D01A0,
+ 0x3E610106, 0x1632FFFE, 0x39C80363, 0x1F6B5F40,
+ 0x19625F3E, 0x1A0B8000, 0x20C4034C, 0x01625F40,
+ 0x28038000, 0x0D330003, 0x04D40350, 0x172E0004,
+ 0x280C8000, 0x3B605F3A, 0x0E970C64, 0x19685F4A,
+ 0x33695F4C, 0x3660B408, 0x1161B40A, 0x20680106,
+ 0x2B6A5F3E, 0x2421B40E, 0x21510000, 0x3B60B40C,
+ 0x24200021, 0x3560B404, 0x0962B414, 0x0A685F36,
+ 0x12210352, 0x362300AF, 0x1D800C8B, 0x096B5F36,
+ 0x2380010C, 0x2B635E90, 0x026B5F34, 0x010CC000,
+ 0x084B0000, 0x3E2C0002, 0x0B480000, 0x28635F4A,
+ 0x196B5E90, 0x2D605F4C, 0x228B4000, 0x336A5F40,
+ 0x36200000, 0x2E605F40, 0x1F3A0000, 0x37CC0CA6,
+ 0x228B4000, 0x0A20FFFF, 0x192D0036, 0x0D4A4000,
+ 0x2F2DFFFA, 0x0A625F42, 0x3A34003F, 0x2E148000,
+ 0x11CC0203, 0x228B4000, 0x0D4A4000, 0x122D0002,
+ 0x0F3607FC, 0x26C80205, 0x26320002, 0x19088000,
+ 0x14C00205, 0x2B008000, 0x05300001, 0x11D40389,
+ 0x1D2E0001, 0x3E30FFFF, 0x228B4000, 0x2D635E96,
+ 0x27200102, 0x2297037E, 0x12600130, 0x0C625F44,
+ 0x27200102, 0x2297037E, 0x1F6B5E96, 0x1F600134,
+ 0x07625F46, 0x228B4000, 0x0969010C, 0x2E68010E,
+ 0x3B3D01A0, 0x0CCC03A1, 0x0C2E01A0, 0x3862010C,
+ 0x30380000, 0x3AC803A0, 0x19088000, 0x19C00201,
+ 0x228B4000, 0x28620110, 0x0F630112, 0x398000AF,
+ 0x26680100, 0x2D635E96, 0x366AB140, 0x1D210001,
+ 0x35230000, 0x03280001, 0x300B0000, 0x1A11C000,
+ 0x28038000, 0x2E174000, 0x22C803B2, 0x29310001,
+ 0x03280001, 0x3AC403AC, 0x1F6B5E96, 0x228B4000,
+ 0x2D635E96, 0x19220000, 0x0A625E94, 0x1A6BB140,
+ 0x0A690100, 0x31200001, 0x2D02C000, 0x2B160000,
+ 0x386A5E94, 0x08CC03C0, 0x1D2E0001, 0x0A625E94,
+ 0x3E30FFFF, 0x252DFFFF, 0x1DCC03BA, 0x1F6B5E96,
+ 0x386A5E94, 0x228B4000, 0x09625F4E, 0x352C03C9,
+ 0x21884000, 0x32800211, 0x298003D9, 0x2C800453,
+ 0x26800456, 0x33800476, 0x2E800497, 0x2F8004FC,
+ 0x238004FF, 0x2980051A, 0x2880051D, 0x3B80053B,
+ 0x32800211, 0x32800211, 0x32800211, 0x32800211,
+ 0x32800211, 0x28230018, 0x1263013C, 0x20970375,
+ 0x2197038B, 0x0F6A0130, 0x02030000, 0x1A0B8000,
+ 0x15C003E2, 0x2E020000, 0x206B013C, 0x11685F44,
+ 0x36695F46, 0x25370020, 0x13CC03E8, 0x1D2E0001,
+ 0x12625F3C, 0x2D0E0000, 0x040E4000, 0x1632FFFE,
+ 0x36970396, 0x249702AE, 0x36200000, 0x15210120,
+ 0x3E6A5F44, 0x32970338, 0x38200008, 0x18210124,
+ 0x356A5F46, 0x32970338, 0x389702B1, 0x09685F3A,
+ 0x09210010, 0x09300002, 0x0F600128, 0x35610104,
+ 0x3697036F, 0x1F970CDC, 0x20680130, 0x01690134,
+ 0x1C6A0120, 0x3D6B0124, 0x3460B010, 0x1561B014,
+ 0x3D680128, 0x1C69012C, 0x172E0068, 0x0862B000,
+ 0x3B2F0068, 0x2963B004, 0x016A0138, 0x382C0068,
+ 0x2960B008, 0x142D0068, 0x0861B00C, 0x1562B018,
+ 0x2368013C, 0x362300AF, 0x1A388000, 0x3760B01C,
+ 0x1E940CE1, 0x14685F4E, 0x2E6A5F34, 0x30380000,
+ 0x34C8041E, 0x21884000, 0x1C208000, 0x13408000,
+ 0x36200000, 0x3580042A, 0x09685F3A, 0x2169B024,
+ 0x012E0028, 0x1C390000, 0x3FD0041A, 0x09300002,
+ 0x382C0068, 0x1F090000, 0x1531FFFE, 0x0E68B028,
+ 0x3F418000, 0x2F34001F, 0x112E0002, 0x13408000,
+ 0x2B008000, 0x3E2C0002, 0x0D500000, 0x0D500000,
+ 0x13970CE9, 0x206A5F3C, 0x01685F34, 0x1632FFFE,
+ 0x33C80213, 0x286B0104, 0x25695F3A, 0x12625F3C,
+ 0x01625F40, 0x010CC000, 0x0F2D01A0, 0x35610104,
+ 0x27490000, 0x3E2C0002, 0x0B480000, 0x07615F4A,
+ 0x2D605F4C, 0x0E970C64, 0x19685F4A, 0x33695F4C,
+ 0x3B60B40C, 0x1C61B40E, 0x2B680104, 0x1A210000,
+ 0x1161B40A, 0x3660B408, 0x206A5F3C, 0x28200081,
+ 0x3560B404, 0x0962B414, 0x14210441, 0x362300AF,
+ 0x18940C8B, 0x36230213, 0x3080036F, 0x2E230028,
+ 0x1263013C, 0x228003DB, 0x20970375, 0x27200102,
+ 0x2297037E, 0x12600130, 0x0C625F44, 0x322C0001,
+ 0x3D605F3C, 0x1D32FFFC, 0x172E0004, 0x36970396,
+ 0x249702AE, 0x36200000, 0x15210120, 0x3E6A5F44,
+ 0x32970338, 0x3E6A5F44, 0x38200008, 0x18210124,
+ 0x32970338, 0x3E6A5F44, 0x25200010, 0x1B210128,
+ 0x32970338, 0x389702B1, 0x09685F3A, 0x07210018,
+ 0x09300002, 0x0260012C, 0x35610104, 0x3023000A,
+ 0x1263013C, 0x368003FC, 0x20970375, 0x2197038B,
+ 0x11685F44, 0x2D0E0000, 0x1632FFFE, 0x36970396,
+ 0x249702AE, 0x36200000, 0x15210120, 0x3E6A5F44,
+ 0x32970338, 0x356A5F46, 0x38200008, 0x18210124,
+ 0x32970338, 0x389702B1, 0x09685F3A, 0x0F6A0130,
+ 0x2E6B0134, 0x09300002, 0x0F600128, 0x2E0EC000,
+ 0x1632FFFE, 0x12625F3C, 0x15208009, 0x32970221,
+ 0x0C970D8F, 0x3E680148, 0x1F970E60, 0x1A210000,
+ 0x236A5F5C, 0x25200010, 0x0E800E7D, 0x06208100,
+ 0x1160013C, 0x20970375, 0x2197038B, 0x236B0130,
+ 0x3D695F44, 0x300B0000, 0x14C00205, 0x0834FFFE,
+ 0x26C80205, 0x040E4000, 0x1632FFFE, 0x36970396,
+ 0x249702AE, 0x36200000, 0x15210120, 0x3E6A5F44,
+ 0x32970338, 0x356A5F46, 0x38200008, 0x18210124,
+ 0x32970338, 0x389702B1, 0x026A0134, 0x12690124,
+ 0x262EFFFF, 0x040D8000, 0x1531FFFE, 0x0F2D01A0,
+ 0x0D4A4000, 0x122D0002, 0x0E494000, 0x2368013C,
+ 0x011A4000, 0x2EC8020B, 0x25695F3A, 0x026A0134,
+ 0x25310002, 0x23610128, 0x29340100, 0x22C804CB,
+ 0x236B0130, 0x2B008000, 0x1A0B8000, 0x312F0001,
+ 0x1D2E0001, 0x05300001, 0x28D004C8, 0x1D2E0001,
+ 0x040D8000, 0x2E61012C, 0x2E0EC000, 0x1632FFFE,
+ 0x12625F3C, 0x2368013C, 0x32970221, 0x0C970D8F,
+ 0x0C69015C, 0x3368014C, 0x05350100, 0x2CC804F5,
+ 0x1F970E60, 0x22520000, 0x172E0004, 0x07690168,
+ 0x3E680148, 0x1C390000, 0x3DD004DE, 0x1F090000,
+ 0x1531FFFE, 0x368004DF, 0x30218000, 0x04685F52,
+ 0x2A2EFFFC, 0x3F418000, 0x15381000, 0x36605F52,
+ 0x12971034, 0x016A0154, 0x2068015C, 0x1A210000,
+ 0x1632FFFE, 0x29340100, 0x25200010, 0x2BC804F4,
+ 0x04970E7E, 0x3E680148, 0x1F69014C, 0x236A5F5C,
+ 0x1F090000, 0x1531FFFE, 0x350A4000, 0x2B200018,
+ 0x0E800E7D, 0x2E6A5F58, 0x012E0028, 0x22520000,
+ 0x22520000, 0x22520000, 0x22520000, 0x388004D7,
+ 0x00208200, 0x1160013C, 0x26800499, 0x21200088,
+ 0x1160013C, 0x20970375, 0x03361F00, 0x23320008,
+ 0x33620138, 0x27200102, 0x2297037E, 0x12600130,
+ 0x2D6B0138, 0x0C625F44, 0x333B0000, 0x206B013C,
+ 0x0CCC050E, 0x2B800511, 0x26370040, 0x10CC0511,
+ 0x322C0001, 0x3D605F3C, 0x2D0E0000, 0x1632FFFE,
+ 0x36970396, 0x36200000, 0x15210120, 0x3E6A5F44,
+ 0x3B2303F7, 0x34800338, 0x2E200048, 0x1160013C,
+ 0x38800501, 0x20970375, 0x27200102, 0x2297037E,
+ 0x12600130, 0x0C625F44, 0x1A32FFFD, 0x36970396,
+ 0x249702AE, 0x36200000, 0x15210120, 0x3E6A5F44,
+ 0x32970338, 0x3E6A5F44, 0x38200008, 0x18210124,
+ 0x32970338, 0x389702B1, 0x39200533, 0x26605F4E,
+ 0x2A230400, 0x1263013C, 0x368003FC, 0x2C69B020,
+ 0x012E0028, 0x22520000, 0x22520000, 0x22520000,
+ 0x3F418000, 0x36230213, 0x15800CE9, 0x20970375,
+ 0x2A2001FF, 0x2297037E, 0x12600130, 0x3D605F3C,
+ 0x2E020000, 0x0C625F44, 0x1632FFFE, 0x36970396,
+ 0x36200000, 0x15210120, 0x3E6A5F44, 0x32970338,
+ 0x36200000, 0x3B605F3A, 0x0F600128, 0x09210010,
+ 0x35610104, 0x18230808, 0x1263013C, 0x368003FC,
+ 0x02030000, 0x0D37FFF8, 0x09CC0211, 0x3F2C0555,
+ 0x21884000, 0x3E80055D, 0x3E8005A4, 0x20800615,
+ 0x32800211, 0x2480062E, 0x3380065F, 0x32800211,
+ 0x32800211, 0x0620FFFC, 0x2C970376, 0x03361F00,
+ 0x2DC80207, 0x23320008, 0x33620138, 0x3F2A0011,
+ 0x2EC40207, 0x2197038B, 0x05300001, 0x39D00569,
+ 0x112E0002, 0x25347FFF, 0x26C80205, 0x2E680138,
+ 0x07625F46, 0x2D010000, 0x24290003, 0x21C40571,
+ 0x3A200003, 0x392C0003, 0x07018000, 0x15072000,
+ 0x333B0000, 0x14CC0209, 0x3D695F44, 0x092E0010,
+ 0x040E4000, 0x082A0800, 0x356A5F46, 0x26C40209,
+ 0x1132FFFF, 0x040E4000, 0x1632FFFE, 0x36970396,
+ 0x249702AE, 0x36200000, 0x15210120, 0x146B5F42,
+ 0x3E6A5F44, 0x06330001, 0x23D00589, 0x2C23058A,
+ 0x34800338, 0x2F9702C0, 0x146B5F42, 0x38200008,
+ 0x18210124, 0x356A5F46, 0x0A330002, 0x32D00592,
+ 0x36230593, 0x34800338, 0x2F9702C0, 0x0A6B5F3A,
+ 0x356A5F46, 0x1B210128, 0x2B635F46, 0x25200010,
+ 0x32970338, 0x389702B1, 0x196B5F46, 0x3D680128,
+ 0x026A0134, 0x0260012C, 0x1632FFFE, 0x38635F3A,
+ 0x12625F3C, 0x1320E000, 0x3E23060E, 0x34800221,
+ 0x0B20FFF8, 0x2C970376, 0x03361F00, 0x2DC80207,
+ 0x23320008, 0x33620138, 0x3F2A0011, 0x2EC40207,
+ 0x24200082, 0x2297037E, 0x12600130, 0x0C625F44,
+ 0x24200082, 0x2297037E, 0x1F600134, 0x05300001,
+ 0x2AD005B6, 0x112E0002, 0x25347FFF, 0x26C80205,
+ 0x2E680138, 0x07625F46, 0x2D010000, 0x24290003,
+ 0x21C405BE, 0x3A200003, 0x332C0006, 0x07018000,
+ 0x15072000, 0x333B0000, 0x14CC0209, 0x3D695F44,
+ 0x2D680134, 0x092E0010, 0x1231FFFF, 0x040E4000,
+ 0x082A0800, 0x26C40209, 0x2E020000, 0x1632FFFE,
+ 0x2D0E0000, 0x040E4000, 0x102E0005, 0x1632FFFE,
+ 0x36970396, 0x249702AE, 0x36200000, 0x15210120,
+ 0x146B5F42, 0x3E6A5F44, 0x06330001, 0x2DD005DB,
+ 0x1132FFFF, 0x242305DE, 0x34800338, 0x2F9702C0,
+ 0x3E6A5F44, 0x329702B4, 0x146B5F42, 0x38200008,
+ 0x18210124, 0x356A5F46, 0x0A330002, 0x28D005E7,
+ 0x1132FFFF, 0x2F2305EA, 0x34800338, 0x2F9702C0,
+ 0x356A5F46, 0x329702B4, 0x12690124, 0x356A5F46,
+ 0x1531FFFE, 0x0F2D01A0, 0x22484000, 0x1632FFFE,
+ 0x040D8000, 0x214B4000, 0x34340001, 0x23C8020F,
+ 0x37370001, 0x23C8020F, 0x026A0134, 0x25200010,
+ 0x146B5F42, 0x1B210128, 0x0D330003, 0x32D005FE,
+ 0x362305FF, 0x34800338, 0x2F9702C0, 0x09685F3A,
+ 0x026A0134, 0x26605F4E, 0x2D200028, 0x1621012C,
+ 0x1132FFFF, 0x32970338, 0x389702B1, 0x14685F4E,
+ 0x026A0134, 0x3B605F3A, 0x39209000, 0x1A32FFFD,
+ 0x12625F3C, 0x32970221, 0x0C970D8F, 0x3368014C,
+ 0x1F970E60, 0x1A210000, 0x236A5F5C, 0x2B200018,
+ 0x0E800E7D, 0x20970375, 0x2197038B, 0x126B5F44,
+ 0x2E0EC000, 0x1632FFFE, 0x36970396, 0x249702AE,
+ 0x36200000, 0x15210120, 0x3E6A5F44, 0x32970338,
+ 0x38200008, 0x18210124, 0x356A5F46, 0x32970338,
+ 0x389702B1, 0x0A6B5F3A, 0x026A0134, 0x0A330002,
+ 0x0163012C, 0x1632FFFE, 0x12625F3C, 0x3620F000,
+ 0x3E23060E, 0x34800221, 0x0C20FFF9, 0x2C970376,
+ 0x0A625F42, 0x122D0002, 0x2B200018, 0x2297037E,
+ 0x1F600134, 0x0834FFFE, 0x26C80205, 0x112E0002,
+ 0x07625F46, 0x2920013C, 0x27508000, 0x0A500001,
+ 0x23290002, 0x22484000, 0x28038000, 0x1A32FFFD,
+ 0x2E0EC000, 0x3F340003, 0x20605F48, 0x1632FFFE,
+ 0x36970396, 0x249702AE, 0x356A5F46, 0x116B5F48,
+ 0x2B008000, 0x1132FFFF, 0x37370001, 0x21C8064D,
+ 0x2D0E0000, 0x15210120, 0x36200000, 0x32970338,
+ 0x116B5F48, 0x356A5F46, 0x37370001, 0x1DCC0686,
+ 0x29230686, 0x09685F3A, 0x2E01C000, 0x232C01A0,
+ 0x0A500001, 0x1632FFFE, 0x202A0002, 0x0D970F97,
+ 0x122801A0, 0x3B605F3A, 0x0D894000, 0x0B20FFF8,
+ 0x2C970376, 0x0A625F42, 0x2B200018, 0x2297037E,
+ 0x12600130, 0x0C625F44, 0x2B200018, 0x2297037E,
+ 0x1F600134, 0x0834FFFE, 0x26C80205, 0x112E0002,
+ 0x07625F46, 0x2920013C, 0x02509000, 0x0A500001,
+ 0x23290002, 0x22484000, 0x3D695F44, 0x38340002,
+ 0x20605F48, 0x1132FFFF, 0x28038000, 0x2E0EC000,
+ 0x2E0EC000, 0x040E4000, 0x1632FFFE, 0x36970396,
+ 0x249702AE, 0x36200000, 0x15210120, 0x146B5F42,
+ 0x3E6A5F44, 0x06330001, 0x26D00685, 0x29230686,
+ 0x34800338, 0x2F9702C0, 0x146B5F42, 0x356A5F46,
+ 0x38200008, 0x0A330002, 0x38D00691, 0x07018000,
+ 0x1132FFFF, 0x040E4000, 0x18210124, 0x3D230697,
+ 0x34800338, 0x18210124, 0x2F9702C0, 0x356A5F46,
+ 0x329702B4, 0x356A5F46, 0x329702B4, 0x146B5F42,
+ 0x356A5F46, 0x1B210128, 0x0D330003, 0x22D006BE,
+ 0x116B5F48, 0x2B008000, 0x1132FFFF, 0x37370001,
+ 0x34C806A2, 0x2D0E0000, 0x25200010, 0x32970338,
+ 0x116B5F48, 0x356A5F46, 0x37370001, 0x0CCC06C7,
+ 0x0F69013C, 0x01685F34, 0x356A5F46, 0x223D9000,
+ 0x1ECC06BC, 0x2E2C0028, 0x084B0000, 0x3E2C0002,
+ 0x27490000, 0x3E2C0002, 0x2D1B4000, 0x27490000,
+ 0x3E2C0002, 0x2D1B4000, 0x27490000, 0x2D200028,
+ 0x2D1B4000, 0x2FC806BC, 0x382306C7, 0x34800338,
+ 0x382306C7, 0x36800655, 0x25200010, 0x2F9702C0,
+ 0x356A5F46, 0x329702B4, 0x116B5F48, 0x356A5F46,
+ 0x37370001, 0x31C806A8, 0x329702B4, 0x389702B1,
+ 0x3D6A5F48, 0x09685F3A, 0x17360002, 0x28C806D1,
+ 0x356A5F46, 0x01690134, 0x1132FFFF, 0x040E4000,
+ 0x1632FFFE, 0x12625F3C, 0x09300002, 0x0260012C,
+ 0x2368013C, 0x32970221, 0x2D695F58, 0x142D0032,
+ 0x22484000, 0x38340002, 0x19CC06E7, 0x016A0154,
+ 0x3A20A000, 0x28038000, 0x06330001, 0x19D406E1,
+ 0x1D2E0001, 0x112E0002, 0x3D33FFFF, 0x2E0EC000,
+ 0x1632FFFE, 0x11625F5C, 0x08970D7B, 0x0C970D8F,
+ 0x3368014C, 0x1F970E60, 0x1A210000, 0x236A5F5C,
+ 0x2B200018, 0x0E800E7D, 0x02030000, 0x0D37FFF8,
+ 0x09CC0211, 0x332C06F3, 0x21884000, 0x388006FE,
+ 0x328007B8, 0x138009BF, 0x01800A98, 0x32800211,
+ 0x328007B8, 0x32800211, 0x01800A98, 0x30380000,
+ 0x09CC0211, 0x05800BD6, 0x0620FFFC, 0x2C970376,
+ 0x122D0002, 0x2B200018, 0x2297037E, 0x12600130,
+ 0x1F600134, 0x0834FFFE, 0x26C80205, 0x112E0002,
+ 0x23290002, 0x22484000, 0x07625F46, 0x34340001,
+ 0x20605F48, 0x2B008000, 0x3530FFFD, 0x2D0E0000,
+ 0x2D0E0000, 0x1632FFFE, 0x36970396, 0x249702AE,
+ 0x36200000, 0x15210120, 0x146B5F42, 0x356A5F46,
+ 0x06330001, 0x3FD0071C, 0x3B23071D, 0x34800338,
+ 0x2F9702C0, 0x1497098E, 0x356A5F46, 0x2D200028,
+ 0x1A210000, 0x32970338, 0x389702B1, 0x1A685F46,
+ 0x36695F46, 0x3530FFFD, 0x2B0C4000, 0x01600120,
+ 0x1531FFFE, 0x20610124, 0x026A0134, 0x3930FFFE,
+ 0x232C01A0, 0x1132FFFF, 0x1A210000, 0x084B0000,
+ 0x3E2C0002, 0x2819C000, 0x262EFFFF, 0x02CC072F,
+ 0x2435FFFE, 0x28C8020D, 0x1F970CDC, 0x01690134,
+ 0x1C6A0120, 0x3D6B0124, 0x03208400, 0x172E0068,
+ 0x3B2F0068, 0x1861B010, 0x0862B000, 0x2963B004,
+ 0x3760B01C, 0x362300AF, 0x1E940CE1, 0x2C69B020,
+ 0x25310002, 0x37D00748, 0x13970CE9, 0x2280020D,
+ 0x13970CE9, 0x1A685F46, 0x19220000, 0x0C600124,
+ 0x2D010000, 0x1531FFFE, 0x2E0D0000, 0x23610128,
+ 0x070D4000, 0x2E0D0000, 0x2E61012C, 0x12625F3C,
+ 0x31200001, 0x1A60013E, 0x39209000, 0x32970221,
+ 0x3A20A000, 0x08970D7B, 0x28680164, 0x116A0148,
+ 0x30380000, 0x1BD00E5E, 0x1F69014C, 0x070E8000,
+ 0x2E610140, 0x23620148, 0x35098000, 0x2D61014C,
+ 0x1531FFFE, 0x23610144, 0x00208200, 0x0E970D7D,
+ 0x2B680168, 0x1C6A014C, 0x30380000, 0x1BD00E5E,
+ 0x12690148, 0x23620148, 0x35098000, 0x2E610140,
+ 0x35098000, 0x1632FFFE, 0x040D8000, 0x2D61014C,
+ 0x3620F000, 0x0E970D7D, 0x3E680148, 0x1C690140,
+ 0x19220000, 0x20620144, 0x0160014C, 0x2E0D0000,
+ 0x2E610140, 0x3230FFFC, 0x0C600148, 0x1B208001,
+ 0x0E970D7D, 0x116A0148, 0x3368014C, 0x2D6B0154,
+ 0x2D620140, 0x2D010000, 0x3530FFFD, 0x0F600144,
+ 0x05300001, 0x1C0A0000, 0x040D8000, 0x20610148,
+ 0x020FC000, 0x12630150, 0x0F208010, 0x0E970D7D,
+ 0x28680164, 0x1C690140, 0x30380000, 0x1BD00E5E,
+ 0x116A0148, 0x3368014C, 0x206B0150, 0x20610148,
+ 0x2D620140, 0x312F0001, 0x12630150, 0x1C0A0000,
+ 0x20620144, 0x1B208001, 0x0E970D7D, 0x0C6A0150,
+ 0x2D6B0154, 0x3368014C, 0x12690148, 0x2E0EC000,
+ 0x3E620150, 0x126A0144, 0x2E610140, 0x1C0A0000,
+ 0x23620148, 0x010F0000, 0x3A33FFFE, 0x3D635F5C,
+ 0x3930FFFE, 0x0F600144, 0x00208200, 0x0E970D7D,
+ 0x0C970D8F, 0x07690168, 0x236A5F5C, 0x1C390000,
+ 0x1BD00E5E, 0x06970E75, 0x2B200018, 0x0E800E7D,
+ 0x0120FFFD, 0x2C970376, 0x122D0002, 0x2B200018,
+ 0x2297037E, 0x12600130, 0x1F600134, 0x0834FFFE,
+ 0x26C80205, 0x112E0002, 0x23290002, 0x22484000,
+ 0x07625F46, 0x38340002, 0x20605F48, 0x2B008000,
+ 0x07018000, 0x3930FFFE, 0x1A32FFFD, 0x2D0E0000,
+ 0x040E4000, 0x1632FFFE, 0x36970396, 0x249702AE,
+ 0x1497098E, 0x356A5F46, 0x2D200028, 0x1A210000,
+ 0x1132FFFF, 0x32970338, 0x36200000, 0x356A5F46,
+ 0x1A210000, 0x1132FFFF, 0x32970338, 0x389702B1,
+ 0x356A5F46, 0x30970655, 0x36695F46, 0x1A685F46,
+ 0x1931FFFD, 0x2D610120, 0x29310001, 0x1F090000,
+ 0x20610124, 0x1F970CDC, 0x01690134, 0x1C6A0120,
+ 0x1861B010, 0x172E0068, 0x0862B000, 0x0662B008,
+ 0x31208808, 0x3760B01C, 0x362300AF, 0x1E940CE1,
+ 0x2169B024, 0x1C390000, 0x1AD0089A, 0x12690124,
+ 0x03208400, 0x142D0068, 0x0661B004, 0x3760B01C,
+ 0x362300AF, 0x1E940CE1, 0x2C69B020, 0x25310002,
+ 0x2BD4089A, 0x36695F46, 0x1C6A0120, 0x31208808,
+ 0x040E4000, 0x2E620120, 0x172E0068, 0x0862B000,
+ 0x0662B008, 0x3760B01C, 0x362300AF, 0x1E940CE1,
+ 0x2169B024, 0x1C390000, 0x1AD0089A, 0x03208400,
+ 0x3760B01C, 0x362300AF, 0x1E940CE1, 0x2C69B020,
+ 0x25310002, 0x2BD4089A, 0x13970CE9, 0x1A685F46,
+ 0x1F690120, 0x0F600128, 0x3930FFFE, 0x2E0D0000,
+ 0x2E61012C, 0x289703B4, 0x11615F3C, 0x3620F000,
+ 0x202A0002, 0x19C4089C, 0x3E695F48, 0x14350002,
+ 0x2BCC089C, 0x32970221, 0x07970967, 0x1E970972,
+ 0x016A0154, 0x3368014C, 0x336B0140, 0x3E620150,
+ 0x12690148, 0x0F630148, 0x300B0000, 0x0C630144,
+ 0x3E30FFFF, 0x1F090000, 0x2E610140, 0x1B208001,
+ 0x0E970D7D, 0x1B970981, 0x3368014C, 0x1F6A0140,
+ 0x12690148, 0x2D6B0154, 0x1C0A0000, 0x2E62014C,
+ 0x3E30FFFF, 0x2E0D0000, 0x2E610140, 0x05300001,
+ 0x2E0D0000, 0x20610148, 0x36200000, 0x0F600144,
+ 0x12630150, 0x39209000, 0x08970D7B, 0x3E680148,
+ 0x1C690140, 0x1C6A014C, 0x1A084000, 0x0160014C,
+ 0x20610148, 0x2D620140, 0x2D010000, 0x3E30FFFF,
+ 0x2E0D0000, 0x3D610150, 0x3F208800, 0x0E970D7D,
+ 0x3368014C, 0x1F6A0140, 0x12690148, 0x2D6B0154,
+ 0x1C0A0000, 0x2E62014C, 0x3E30FFFF, 0x1F090000,
+ 0x2E610140, 0x3930FFFE, 0x1C0A0000, 0x23620148,
+ 0x12630150, 0x39209000, 0x08970D7B, 0x3368014C,
+ 0x12690148, 0x1F6A0140, 0x0C600148, 0x1A084000,
+ 0x28038000, 0x2D0E0000, 0x2E62014C, 0x09300002,
+ 0x010F0000, 0x01630140, 0x1C208000, 0x08970D7B,
+ 0x3A20A000, 0x08970D7B, 0x2E680154, 0x1C6A014C,
+ 0x2D010000, 0x29310001, 0x39D40874, 0x322C0001,
+ 0x3E2C0002, 0x0160014C, 0x2D620140, 0x2D010000,
+ 0x3E30FFFF, 0x2B0C4000, 0x0F600144, 0x2D010000,
+ 0x3E30FFFF, 0x2E0D0000, 0x20610148, 0x00208200,
+ 0x0E970D7D, 0x3E680148, 0x306B014C, 0x016A0154,
+ 0x02600140, 0x2D010000, 0x3930FFFE, 0x38605F5A,
+ 0x1C09C000, 0x23610144, 0x1632FFFE, 0x11625F5C,
+ 0x03208400, 0x0E970D7D, 0x0C970D8F, 0x06970E75,
+ 0x026B5F58, 0x0A6A0160, 0x3D2F0034, 0x0B4BC000,
+ 0x16420000, 0x3D370004, 0x3ECC0D4F, 0x236A5F5C,
+ 0x2B200018, 0x0E800E7D, 0x13970CE9, 0x2480020B,
+ 0x1160013C, 0x3697036F, 0x1F23094A, 0x2B635F46,
+ 0x122008A2, 0x38605F36, 0x3B9703A4, 0x00CC0274,
+ 0x37970247, 0x142308A8, 0x2B635F46, 0x3E800224,
+ 0x3E680148, 0x1C6A014C, 0x1C690140, 0x0160014C,
+ 0x20620144, 0x2D0E0000, 0x3E30FFFF, 0x1F090000,
+ 0x2E610140, 0x23620148, 0x1B208001, 0x0E970D7D,
+ 0x1B970981, 0x12690148, 0x3368014C, 0x1F6A0140,
+ 0x2D6B0154, 0x2E610140, 0x1C0A0000, 0x1C0A0000,
+ 0x2E62014C, 0x3930FFFE, 0x0C600148, 0x36200000,
+ 0x0F600144, 0x12630150, 0x39209000, 0x08970D7B,
+ 0x3368014C, 0x12690148, 0x1F6A0140, 0x0C600148,
+ 0x1A084000, 0x09300002, 0x2D0E0000, 0x2D620140,
+ 0x05300001, 0x0160014C, 0x25200010, 0x28695F52,
+ 0x19220000, 0x2B190000, 0x1A615F52, 0x26695F6C,
+ 0x1F238000, 0x38635F56, 0x22484000, 0x026B5F34,
+ 0x122D0002, 0x3F424000, 0x351F0000, 0x1DC80D58,
+ 0x16235F7A, 0x2449C000, 0x3D2F0002, 0x1A1D0000,
+ 0x36CC08E8, 0x2449C000, 0x1C390000, 0x2CCC0D58,
+ 0x25695F56, 0x1C390000, 0x3CD408EB, 0x14625F56,
+ 0x302F0006, 0x1D2E0001, 0x018008DD, 0x04685F52,
+ 0x076B5F52, 0x3C34000F, 0x393700F0, 0x27CC08F3,
+ 0x1C1C8000, 0x21CC08F5, 0x118008F7, 0x1C1C8000,
+ 0x2ACC08F7, 0x1D32FFFC, 0x1E8008F8, 0x1E31FFFC,
+ 0x01198000, 0x17615F56, 0x076B5F52, 0x23310004,
+ 0x1035000F, 0x3F37000F, 0x1C1F4000, 0x0DC8090D,
+ 0x28004000, 0x07645F52, 0x1331FFF8, 0x32394001,
+ 0x12615F6A, 0x2D010000, 0x22310003, 0x19615F68,
+ 0x3E30FFFF, 0x012C0D17, 0x0F23090C, 0x21884000,
+ 0x38605F6C, 0x116A0148, 0x1F69014C, 0x30680140,
+ 0x040D8000, 0x1531FFFE, 0x17615F60, 0x3D6B0148,
+ 0x1C0A0000, 0x2B0F8000, 0x0263014C, 0x3930FFFE,
+ 0x30605F62, 0x1632FFFE, 0x12625F66, 0x15970C7A,
+ 0x34200051, 0x2360B444, 0x09685F56, 0x0A6B5F60,
+ 0x3C34000F, 0x0E300003, 0x2D010000, 0x0934FF00,
+ 0x010CC000, 0x2060B448, 0x193500FF, 0x0761B44A,
+ 0x07685F68, 0x016B5F62, 0x206A5F66, 0x2D010000,
+ 0x0934FF00, 0x010CC000, 0x2D60B44C, 0x193500FF,
+ 0x0A61B44E, 0x1F62B454, 0x0F200936, 0x3221091B,
+ 0x362300AF, 0x0B800C91, 0x1D210001, 0x3561015E,
+ 0x1C208000, 0x1260015C, 0x00970E1F, 0x076B5F52,
+ 0x0A685F6C, 0x3F37000F, 0x293B0100, 0x2563B144,
+ 0x3921086C, 0x3E2C0002, 0x15410000, 0x09685F56,
+ 0x18230D58, 0x3C34000F, 0x07645F52, 0x0E300003,
+ 0x35605F68, 0x0A800D8F, 0x07970967, 0x1E970972,
+ 0x3368014C, 0x1F6A0140, 0x12690148, 0x2D6B0154,
+ 0x1C0A0000, 0x2E62014C, 0x1F6A0140, 0x12630150,
+ 0x2E610140, 0x3930FFFE, 0x1C0A0000, 0x23620148,
+ 0x36200000, 0x0F600144, 0x39209000, 0x08970D7B,
+ 0x1C690140, 0x3E680148, 0x116A0148, 0x2E610140,
+ 0x1A084000, 0x0160014C, 0x3E30FFFF, 0x2D0E0000,
+ 0x23620148, 0x36200000, 0x198008CF, 0x3E680148,
+ 0x1C6A014C, 0x1C690140, 0x0160014C, 0x20620144,
+ 0x1F090000, 0x2D0E0000, 0x2E610140, 0x23620148,
+ 0x1B208001, 0x08800D7D, 0x3368014C, 0x12690148,
+ 0x1F6A0140, 0x2E610140, 0x2D0E0000, 0x23620148,
+ 0x2E020000, 0x1632FFFE, 0x1C0A0000, 0x2E680154,
+ 0x20620144, 0x020C0000, 0x11600150, 0x00208200,
+ 0x08800D7D, 0x1F6A0140, 0x12690148, 0x3368014C,
+ 0x23620148, 0x2E610140, 0x3930FFFE, 0x1C0A0000,
+ 0x2E680154, 0x20620144, 0x020C0000, 0x11600150,
+ 0x00208200, 0x08800D7D, 0x25635F4E, 0x146B5F42,
+ 0x356A5F46, 0x38200008, 0x1A210000, 0x0A330002,
+ 0x07D0099B, 0x28038000, 0x1632FFFE, 0x3D33FFFF,
+ 0x2E0EC000, 0x062309A6, 0x34800338, 0x2F9702C0,
+ 0x356A5F46, 0x329702B4, 0x356A5F46, 0x329702B4,
+ 0x356A5F46, 0x329702B4, 0x356A5F46, 0x329702B4,
+ 0x356A5F46, 0x329702B4, 0x3E695F48, 0x356A5F46,
+ 0x18350001, 0x1FC809B9, 0x2D200028, 0x33970365,
+ 0x19685F4A, 0x33695F4C, 0x1632FFFE, 0x1A048000,
+ 0x19C409B3, 0x1E2D0001, 0x01615F4C, 0x2B605F4A,
+ 0x0A20FFFF, 0x1A210000, 0x356A5F46, 0x162309BA,
+ 0x34800338, 0x30970655, 0x356A5F46, 0x25200010,
+ 0x1A210000, 0x176B5F4E, 0x34800338, 0x0620FFFC,
+ 0x2C970376, 0x03361F00, 0x2DC80207, 0x23320008,
+ 0x33620138, 0x3F2A0011, 0x2EC40207, 0x2197038B,
+ 0x236B0130, 0x2D010000, 0x2435FFFE, 0x26C80205,
+ 0x3008C000, 0x3BC009CF, 0x17CC0205, 0x126B5F44,
+ 0x112E0002, 0x07625F46, 0x3D2F0002, 0x20635F44,
+ 0x3D33FFFF, 0x1632FFFE, 0x2E0EC000, 0x1632FFFE,
+ 0x36970396, 0x2E680138, 0x3D695F44, 0x02030000,
+ 0x0B2B0003, 0x19C409DF, 0x3A200003, 0x392C0003,
+ 0x15072000, 0x333B0000, 0x14CC0209, 0x36695F46,
+ 0x092E0010, 0x2B034000, 0x1931FFFD, 0x1C09C000,
+ 0x040E4000, 0x082A0800, 0x26C40209, 0x249702AE,
+ 0x36200000, 0x15210120, 0x146B5F42, 0x356A5F46,
+ 0x06330001, 0x0BD009F4, 0x0F2309F5, 0x34800338,
+ 0x2F9702C0, 0x0C970BB5, 0x356A5F46, 0x2D200028,
+ 0x1A210000, 0x32970338, 0x389702B1, 0x3D695F44,
+ 0x1A685F46, 0x1231FFFF, 0x2E0D0000, 0x20610124,
+ 0x3E30FFFF, 0x2E0D0000, 0x2D610120, 0x1F970CDC,
+ 0x01690134, 0x1C6A0120, 0x1861B010, 0x172E0068,
+ 0x0862B000, 0x0662B008, 0x31208808, 0x3760B01C,
+ 0x362300AF, 0x1E940CE1, 0x2169B024, 0x1C390000,
+ 0x18D00A1B, 0x12690124, 0x03208400, 0x142D0068,
+ 0x0661B004, 0x3760B01C, 0x362300AF, 0x1E940CE1,
+ 0x2C69B020, 0x25310002, 0x1ED00A1D, 0x13970CE9,
+ 0x2280020D, 0x13970CE9, 0x1A685F46, 0x3D695F44,
+ 0x1C6A0120, 0x0C600124, 0x2E0D0000, 0x23610128,
+ 0x0C690130, 0x2E6B0134, 0x3930FFFE, 0x2D0E0000,
+ 0x2D62012C, 0x11630130, 0x33610134, 0x19220000,
+ 0x12625F3C, 0x1320E000, 0x32970221, 0x28680164,
+ 0x0F690150, 0x30380000, 0x1BD00E5E, 0x2D6B0154,
+ 0x126A0144, 0x3368014C, 0x30610154, 0x312F0001,
+ 0x12630150, 0x1C690140, 0x2E62014C, 0x02600140,
+ 0x28004000, 0x040D8000, 0x20610148, 0x1132FFFF,
+ 0x19088000, 0x0F600144, 0x00208200, 0x0E970D7D,
+ 0x2B680168, 0x2D6B0154, 0x30380000, 0x1BD00E5E,
+ 0x1C6A014C, 0x12690148, 0x12630150, 0x23620148,
+ 0x35098000, 0x2E610140, 0x040D8000, 0x1132FFFF,
+ 0x040D8000, 0x2D61014C, 0x3620F000, 0x0E970D7D,
+ 0x3E680148, 0x1F69014C, 0x1F6A0140, 0x35230000,
+ 0x0C630144, 0x0160014C, 0x2E0D0000, 0x20610148,
+ 0x2D0E0000, 0x2D620140, 0x1B208001, 0x0E970D7D,
+ 0x116A0148, 0x3368014C, 0x1C690140, 0x2D6B0154,
+ 0x2D620140, 0x2D0E0000, 0x3E30FFFF, 0x2D0E0000,
+ 0x23620148, 0x1F090000, 0x23610144, 0x3D33FFFF,
+ 0x12630150, 0x0F208010, 0x0E970D7D, 0x04690164,
+ 0x3368014C, 0x1C390000, 0x1BD00E5E, 0x1C690140,
+ 0x116A0148, 0x206B0150, 0x20610148, 0x2D620140,
+ 0x312F0001, 0x12630150, 0x1F090000, 0x23610144,
+ 0x1B208001, 0x0E970D7D, 0x0C6A0150, 0x2D6B0154,
+ 0x3368014C, 0x12690148, 0x2E0EC000, 0x3E620150,
+ 0x010F0000, 0x3A33FFFE, 0x3D635F5C, 0x3E6B0144,
+ 0x2E610140, 0x300B0000, 0x0F630148, 0x3930FFFE,
+ 0x300B0000, 0x0C630144, 0x00208200, 0x0E970D7D,
+ 0x0C970D8F, 0x07690168, 0x236A5F5C, 0x1C390000,
+ 0x1BD00E5E, 0x06970E75, 0x2B200018, 0x0E800E7D,
+ 0x0120FFFD, 0x2C970376, 0x03361F00, 0x2DC80207,
+ 0x23320008, 0x33620138, 0x3F2A0011, 0x2EC40207,
+ 0x2197038B, 0x236B0130, 0x2D010000, 0x2435FFFE,
+ 0x26C80205, 0x3008C000, 0x3FC00AA8, 0x17CC0205,
+ 0x126B5F44, 0x112E0002, 0x07625F46, 0x3D2F0002,
+ 0x20635F44, 0x0200C000, 0x3D33FFFF, 0x010F0000,
+ 0x1632FFFE, 0x2E0EC000, 0x1632FFFE, 0x36970396,
+ 0x2E680138, 0x3D695F44, 0x02030000, 0x0B2B0003,
+ 0x16C40ABA, 0x3A200003, 0x3F2C0005, 0x15072000,
+ 0x333B0000, 0x14CC0209, 0x36695F46, 0x092E0010,
+ 0x1531FFFE, 0x040E4000, 0x082A0800, 0x26C40209,
+ 0x249702AE, 0x36200000, 0x1A210000, 0x3E6A5F44,
+ 0x32970338, 0x0C970BB5, 0x356A5F46, 0x2D200028,
+ 0x1A210000, 0x1132FFFF, 0x32970338, 0x389702B1,
+ 0x11685F44, 0x36695F46, 0x2E020000, 0x2B034000,
+ 0x3E30FFFF, 0x1231FFFF, 0x280C8000, 0x0C600124,
+ 0x2B0C4000, 0x0F600128, 0x010CC000, 0x01600120,
+ 0x1F970CDC, 0x01690134, 0x126A0128, 0x3E610130,
+ 0x1861B010, 0x172E0068, 0x0862B000, 0x0662B008,
+ 0x31208808, 0x3760B01C, 0x362300AF, 0x1E940CE1,
+ 0x2169B024, 0x1C390000, 0x26D40AED, 0x13970CE9,
+ 0x2480020B, 0x12690124, 0x03208400, 0x142D0068,
+ 0x0661B004, 0x3760B01C, 0x362300AF, 0x1E940CE1,
+ 0x2C69B020, 0x25310002, 0x20D40AEB, 0x1C6A0120,
+ 0x31208808, 0x172E0068, 0x0862B000, 0x0662B008,
+ 0x3760B01C, 0x362300AF, 0x1E940CE1, 0x2169B024,
+ 0x1C390000, 0x11D00AEB, 0x03208400, 0x3760B01C,
+ 0x362300AF, 0x1E940CE1, 0x2C69B020, 0x25310002,
+ 0x20D40AEB, 0x13970CE9, 0x1A685F46, 0x1F690120,
+ 0x0F600128, 0x2E0D0000, 0x2E61012C, 0x19220000,
+ 0x12625F3C, 0x3620F000, 0x32970221, 0x3E680148,
+ 0x1C6A014C, 0x1C690140, 0x0160014C, 0x20620144,
+ 0x1F090000, 0x2E610140, 0x2D0E0000, 0x23620148,
+ 0x1B208001, 0x0E970D7D, 0x3368014C, 0x12690148,
+ 0x1F6A0140, 0x2E610140, 0x07018000, 0x2E0D0000,
+ 0x20610148, 0x3E30FFFF, 0x1C0A0000, 0x2E680154,
+ 0x20620144, 0x020C0000, 0x11600150, 0x00208200,
+ 0x0E970D7D, 0x016A0154, 0x3368014C, 0x336B0140,
+ 0x3E620150, 0x12690148, 0x0F630148, 0x300B0000,
+ 0x0C630144, 0x3E30FFFF, 0x1F090000, 0x2E610140,
+ 0x1B208001, 0x0E970D7D, 0x3368014C, 0x1F6A0140,
+ 0x12690148, 0x23620148, 0x1C0A0000, 0x2E680154,
+ 0x20620144, 0x2E610140, 0x020C0000, 0x11600150,
+ 0x00208200, 0x0E970D7D, 0x3368014C, 0x2D6B0154,
+ 0x12690148, 0x1F6A0140, 0x12630150, 0x2E610140,
+ 0x2D695F58, 0x1C0A0000, 0x2E62014C, 0x1F2D0030,
+ 0x0D4A4000, 0x1F2D0006, 0x0E494000, 0x0F3607FC,
+ 0x26320002, 0x33620154, 0x28038000, 0x06330001,
+ 0x22D40B5A, 0x1D2E0001, 0x112E0002, 0x20620144,
+ 0x1132FFFF, 0x23620148, 0x00351F00, 0x20310008,
+ 0x33610158, 0x1320E000, 0x0E970D7D, 0x3D680144,
+ 0x1C6A014C, 0x1C690140, 0x206B0150, 0x2D0E0000,
+ 0x2E62014C, 0x0200C000, 0x06330001, 0x25D40B6D,
+ 0x322C0001, 0x3E2C0002, 0x3E30FFFF, 0x2E0D0000,
+ 0x2E610140, 0x1A210000, 0x20610148, 0x1320E000,
+ 0x0E970D7D, 0x206B0150, 0x2E680154, 0x1C6A014C,
+ 0x0263014C, 0x11600150, 0x1C600154, 0x02030000,
+ 0x06330001, 0x3DD40B7F, 0x322C0001, 0x3E2C0002,
+ 0x20620144, 0x1C0A0000, 0x2D620140, 0x3E30FFFF,
+ 0x2D0E0000, 0x23620148, 0x1B208001, 0x0E970D7D,
+ 0x12690148, 0x126A0144, 0x206B0150, 0x2E610140,
+ 0x23620148, 0x0200C000, 0x3D33FFFF, 0x12630150,
+ 0x1C600154, 0x02030000, 0x06330001, 0x22D40B95,
+ 0x322C0001, 0x3E2C0002, 0x0F600144, 0x00208200,
+ 0x0E970D7D, 0x11690144, 0x116A0148, 0x3368014C,
+ 0x2D6B0154, 0x2D620140, 0x12630150, 0x1C600154,
+ 0x02030000, 0x06330001, 0x23D40BA4, 0x322C0001,
+ 0x3E2C0002, 0x0160014C, 0x350A4000, 0x23620148,
+ 0x3930FFFE, 0x1C0A0000, 0x20620144, 0x00208200,
+ 0x0E970D7D, 0x12690148, 0x016A0154, 0x306B014C,
+ 0x2E610140, 0x3E620150, 0x3D33FFFF, 0x1C09C000,
+ 0x09800889, 0x25635F4E, 0x146B5F42, 0x38200008,
+ 0x1A210000, 0x3E6A5F44, 0x0A330002, 0x1BD00BC1,
+ 0x196B5F46, 0x1132FFFF, 0x2E0EC000, 0x0B230BD1,
+ 0x34800338, 0x2F9702C0, 0x3E6A5F44, 0x329702B4,
+ 0x3E6A5F44, 0x19685F4A, 0x33695F4C, 0x1632FFFE,
+ 0x1A048000, 0x1AC40BCC, 0x1E2D0001, 0x01615F4C,
+ 0x2B605F4A, 0x356A5F46, 0x0A20FFFF, 0x1A210000,
+ 0x2F9702C0, 0x356A5F46, 0x25200010, 0x1A210000,
+ 0x176B5F4E, 0x34800338, 0x32800211, 0x02030000,
+ 0x0C37FFFF, 0x09CC0211, 0x0F2C0BDC, 0x21884000,
+ 0x07800BDD, 0x20970375, 0x3E20000E, 0x2297037E,
+ 0x093C000E, 0x17CC0205, 0x2A2001FF, 0x2297037E,
+ 0x3D605F3C, 0x3F340003, 0x17CC0205, 0x122E000E,
+ 0x1632FFFE, 0x36970396, 0x249702AE, 0x1122000E,
+ 0x36200000, 0x1A210000, 0x32970338, 0x01685F34,
+ 0x122101D8, 0x3E610106, 0x3B2C0008, 0x27490000,
+ 0x3E2C0002, 0x0B480000, 0x07615F4A, 0x2D605F4C,
+ 0x0F685F3C, 0x30695F40, 0x3930FFFE, 0x36605F3E,
+ 0x1F090000, 0x10C40BFF, 0x2E605F40, 0x202001A0,
+ 0x04230C04, 0x19600104, 0x3B635F36, 0x328002E8,
+ 0x25200010, 0x19600104, 0x24800431, 0x369700FC,
+ 0x15220003, 0x1F62B438, 0x2C695FCA, 0x04685EDE,
+ 0x19220000, 0x1461B400, 0x1162B406, 0x30380000,
+ 0x36C800A5, 0x2A340080, 0x19C80C16, 0x1E200C27,
+ 0x1B230C17, 0x288000B4, 0x36605EDE, 0x09685EEC,
+ 0x332300A5, 0x19220000, 0x14625EEC, 0x28695EDE,
+ 0x366A5EF0, 0x30380000, 0x27C80104, 0x01198000,
+ 0x2E6A5F02, 0x01198000, 0x336A5EA0, 0x24D000B4,
+ 0x3C36FDFF, 0x01625EA0, 0x288000B4, 0x22215EDE,
+ 0x1F220006, 0x14970FB4, 0x2F215EEC, 0x21510000,
+ 0x21510000, 0x21884000, 0x1F220030, 0x1F62B438,
+ 0x21695FCE, 0x19685EF0, 0x19220000, 0x0161B420,
+ 0x0462B426, 0x30380000, 0x3AC800A6, 0x2A340080,
+ 0x09C80C3C, 0x17200C42, 0x0B230C3D, 0x288000B4,
+ 0x2B605EF0, 0x11685EFE, 0x3F2300A6, 0x19220000,
+ 0x0C625EFE, 0x17800C1B, 0x3F215EF0, 0x1F220006,
+ 0x14970FB4, 0x37215EFE, 0x21510000, 0x21510000,
+ 0x21884000, 0x1F220300, 0x1F62B438, 0x21695FCE,
+ 0x01685F02, 0x19220000, 0x0261B440, 0x0762B446,
+ 0x30380000, 0x3DC800A7, 0x2A340080, 0x08C80C57,
+ 0x0B200C5D, 0x02230C58, 0x288000B4, 0x33605F02,
+ 0x19685F10, 0x382300A7, 0x19220000, 0x04625F10,
+ 0x17800C1B, 0x27215F02, 0x1F220006, 0x14970FB4,
+ 0x3F215F10, 0x21510000, 0x21510000, 0x21884000,
+ 0x04685EDE, 0x22215EDE, 0x30380000, 0x1AD00C70,
+ 0x03205EEC, 0x0B518000, 0x0D500000, 0x30695EA0,
+ 0x0D500000, 0x00390200, 0x02615EA0, 0x228B4000,
+ 0x0200C000, 0x1F220006, 0x362300AF, 0x1D800FD7,
+ 0x19685EF0, 0x3F215EF0, 0x30380000, 0x1AD00C70,
+ 0x1B205EFE, 0x0C800C69, 0x01685F02, 0x27215F02,
+ 0x30380000, 0x1AD00C70, 0x13205F10, 0x0C800C69,
+ 0x04685EDE, 0x22215EDE, 0x30380000, 0x36D40C68,
+ 0x398000AF, 0x19685EF0, 0x3F215EF0, 0x30380000,
+ 0x35D000AF, 0x1B205EFE, 0x0C800C69, 0x3B605EEC,
+ 0x1C615EEE, 0x228B4000, 0x23605EFE, 0x14615F00,
+ 0x228B4000, 0x2B605F10, 0x0C615F12, 0x228B4000,
+ 0x19685EF0, 0x1A210000, 0x30380000, 0x0AC80CA5,
+ 0x1F61B434, 0x226A5FCE, 0x0761B426, 0x0262B420,
+ 0x2A340080, 0x0DC80CA4, 0x28635E9C, 0x3F215EF0,
+ 0x1F220006, 0x14970FB4, 0x1A6B5E9C, 0x288000B4,
+ 0x07615EF0, 0x228B4000, 0x2E620116, 0x0F200CA9,
+ 0x288000B4, 0x19970C80, 0x1C6A0116, 0x0D20B404,
+ 0x19500011, 0x01500003, 0x1150C400, 0x0A500001,
+ 0x0E500180, 0x0D500000, 0x0962B414, 0x352000AF,
+ 0x192100AF, 0x362300AF, 0x1D800C8B, 0x01690102,
+ 0x36200000, 0x0A350020, 0x20C80203, 0x30218000,
+ 0x1F615ED4, 0x3B605EDA, 0x3D605EDC, 0x228B4000,
+ 0x2D695ED4, 0x30380000, 0x27C80104, 0x1C390000,
+ 0x1DD40100, 0x3B605EDA, 0x228B4000, 0x2D695ED4,
+ 0x30380000, 0x27C80104, 0x1C390000, 0x1DD40100,
+ 0x3D605EDC, 0x228B4000, 0x01685ED4, 0x27215ED4,
+ 0x30380000, 0x16D40102, 0x21510000, 0x228B4000,
+ 0x30695ECC, 0x07685ED2, 0x1C390000, 0x06D400A4,
+ 0x30380000, 0x31C800A4, 0x342300A4, 0x288000B4,
+ 0x3A215ECC, 0x0B518000, 0x36200000, 0x35605ED2,
+ 0x228B4000, 0x30695ECC, 0x35605ED2, 0x1C390000,
+ 0x30695EA0, 0x1DD40100, 0x12390008, 0x02615EA0,
+ 0x228B4000, 0x336A5EA0, 0x1C685ECC, 0x3A215ECC,
+ 0x2E36FFF7, 0x01625EA0, 0x30380000, 0x16D40102,
+ 0x21510000, 0x228B4000, 0x04685F52, 0x30218000,
+ 0x2D144000, 0x04CC00A9, 0x1A615F52, 0x302300A9,
+ 0x06200CFA, 0x288000B4, 0x29200400, 0x2660B144,
+ 0x06210200, 0x1468B144, 0x3C34000F, 0x2B190000,
+ 0x0A61B144, 0x07645F52, 0x2D010000, 0x20310008,
+ 0x1139A0C8, 0x214B4000, 0x0F2D002C, 0x0E494000,
+ 0x2E020000, 0x06330001, 0x20377F00, 0x1263010A,
+ 0x21320003, 0x1A625F68, 0x2E020000, 0x1032FFF8,
+ 0x313A4001, 0x11625F6A, 0x2E020000, 0x1132FFFF,
+ 0x2E2E0D17, 0x04230D2B, 0x0E8A4000, 0x15205F7A,
+ 0x228B4000, 0x12205F82, 0x228B4000, 0x1C205F8A,
+ 0x228B4000, 0x01205F92, 0x228B4000, 0x0F205F9A,
+ 0x228B4000, 0x07205FA2, 0x228B4000, 0x09205FAA,
+ 0x228B4000, 0x14205FB2, 0x228B4000, 0x1A205FBA,
+ 0x228B4000, 0x04205FC2, 0x228B4000, 0x38605F6C,
+ 0x27490000, 0x3E2C0002, 0x084B0000, 0x3E2C0002,
+ 0x244A0000, 0x3E2C0002, 0x0B480000, 0x1F615F58,
+ 0x38635F56, 0x17625F5A, 0x3E605F5C, 0x1E970E3D,
+ 0x236A5F5C, 0x266B010C, 0x1F3A0000, 0x01C80D47,
+ 0x19213000, 0x35098000, 0x190B4000, 0x3061010E,
+ 0x39C00D42, 0x27CC0E5C, 0x0A685F5A, 0x04230D47,
+ 0x33635F54, 0x046B5F68, 0x07800E42, 0x0F69010A,
+ 0x0A6B5F56, 0x20310008, 0x08C80D78, 0x2E6A5F58,
+ 0x05390080, 0x162E0035, 0x0E458000, 0x0C970D8F,
+ 0x04685F52, 0x1B230D54, 0x16341000, 0x3ECC1043,
+ 0x3A2000A0, 0x00645F53, 0x2D695F58, 0x34970284,
+ 0x0269010E, 0x1A223000, 0x350A4000, 0x0BC80D74,
+ 0x28680108, 0x25620114, 0x30380000, 0x12C80D61,
+ 0x0A970CA6, 0x15970C7A, 0x0269010E, 0x1B20B444,
+ 0x19500011, 0x0A500001, 0x1150C400, 0x0A500001,
+ 0x2335FFFF, 0x15410000, 0x176A0114, 0x3E2C0002,
+ 0x0D500000, 0x1F62B454, 0x0B200D72, 0x27210D72,
+ 0x362300AF, 0x0B800C91, 0x35203000, 0x1C60010E,
+ 0x1A210000, 0x36610108, 0x1A615F52, 0x398000AF,
+ 0x19220000, 0x3662015E, 0x228B4000, 0x1D210001,
+ 0x3561015E, 0x1260015C, 0x38635F56, 0x00970E1F,
+ 0x076B5F52, 0x0A685F6C, 0x3F37000F, 0x293B0100,
+ 0x2563B144, 0x25695F56, 0x3E2C0002, 0x15410000,
+ 0x26695F5A, 0x3E2C0002, 0x15410000, 0x20695F5C,
+ 0x3E2C0002, 0x15410000, 0x17800D58, 0x04685F52,
+ 0x3569B140, 0x3930FFFE, 0x3CD003A0, 0x33635F54,
+ 0x09300002, 0x02030000, 0x3C34000F, 0x3D3CFFFF,
+ 0x33228000, 0x1A120000, 0x301D8000, 0x0761B140,
+ 0x336A5EA0, 0x2BCC0DA0, 0x2D36FFFB, 0x01625EA0,
+ 0x3D3CFFFF, 0x3A225F7A, 0x3530FFFD, 0x1F060000,
+ 0x22520000, 0x22520000, 0x153B2000, 0x07685F32,
+ 0x35635F52, 0x1A344000, 0x09C80DB0, 0x0A685F36,
+ 0x2E9700B4, 0x02685F54, 0x362300AF, 0x288000B4,
+ 0x04685F52, 0x3569B140, 0x1F238000, 0x3C34000F,
+ 0x2E020000, 0x123EFFFF, 0x1C138000, 0x2819C000,
+ 0x0761B140, 0x3F30FFF8, 0x2838A084, 0x18500020,
+ 0x3B680118, 0x2E695F54, 0x0418C000, 0x09600118,
+ 0x351CC000, 0x2BCC0DFA, 0x2361011E, 0x07685F68,
+ 0x0763011C, 0x0260011A, 0x15970C7A, 0x336B011A,
+ 0x1B20B444, 0x1C500041, 0x0A500001, 0x0E500180,
+ 0x0D500000, 0x2D02C000, 0x2636FF00, 0x0262B44C,
+ 0x363700FF, 0x2563B44E, 0x3F222000, 0x1F62B454,
+ 0x3E6B011E, 0x36200000, 0x0F60011E, 0x333B0000,
+ 0x3ECC0DDA, 0x362300AF, 0x08200DDD, 0x24210DDD,
+ 0x0B800C91, 0x3668011C, 0x3569B140, 0x146A0118,
+ 0x1A1D0000, 0x0761B140, 0x191E0000, 0x26620118,
+ 0x19C80DF6, 0x36200000, 0x1D210001, 0x28038000,
+ 0x2E174000, 0x39CC0DED, 0x322C0001, 0x1231FFFF,
+ 0x07800DE7, 0x2861011C, 0x0E300003, 0x2B695F32,
+ 0x0260011A, 0x36354000, 0x1FC80DC6, 0x19200DC6,
+ 0x096B5F36, 0x288000B4, 0x07685F32, 0x26695F36,
+ 0x1A344000, 0x33C800AF, 0x0D894000, 0x1F3A0000,
+ 0x3AC803A0, 0x3B635F36, 0x1A6B5F4A, 0x19600104,
+ 0x3E610106, 0x19625F3E, 0x23635F48, 0x1D970C74,
+ 0x2B680104, 0x0F6A0106, 0x116B5F48, 0x2360B428,
+ 0x3C21B42A, 0x21510000, 0x0200C000, 0x0934FF00,
+ 0x281A0000, 0x0162B42C, 0x363700FF, 0x2663B42E,
+ 0x2B6A5F3E, 0x27200041, 0x2060B424, 0x1C62B434,
+ 0x36210E03, 0x362300AF, 0x12940C8E, 0x096B5F36,
+ 0x228B4000, 0x3B635F36, 0x39200120, 0x1A210000,
+ 0x0C220020, 0x1C6B5F4C, 0x1A800DFF, 0x33635F54,
+ 0x0F6B5F6A, 0x3A200140, 0x1A210000, 0x0C220020,
+ 0x3B605F60, 0x1C615F62, 0x12625F66, 0x36635F5E,
+ 0x15970C7A, 0x09685F60, 0x2D6A5F62, 0x046B5F5E,
+ 0x2060B448, 0x3F21B44A, 0x21510000, 0x0200C000,
+ 0x0934FF00, 0x281A0000, 0x0262B44C, 0x363700FF,
+ 0x2563B44E, 0x206A5F66, 0x27200041, 0x2360B444,
+ 0x1F62B454, 0x16200E5A, 0x21210E28, 0x362300AF,
+ 0x0B800C91, 0x33635F54, 0x36200000, 0x16210140,
+ 0x0F22002C, 0x0F6B5F6A, 0x3B605F60, 0x1C615F62,
+ 0x12625F66, 0x36635F5E, 0x15970C7A, 0x286A5F5E,
+ 0x09685F60, 0x2E695F62, 0x28038000, 0x0A37FF00,
+ 0x0418C000, 0x2060B448, 0x1A3600FF, 0x0462B44A,
+ 0x0161B44C, 0x36200000, 0x2660B44E, 0x206A5F66,
+ 0x22200011, 0x2360B444, 0x1F62B454, 0x2A210E46,
+ 0x362300AF, 0x0E940C91, 0x016B5F54, 0x228B4000,
+ 0x0B210041, 0x08800D4B, 0x08210021, 0x08800D4B,
+ 0x2E6A5F58, 0x04690164, 0x012E0028, 0x1C390000,
+ 0x01D00E71, 0x1F090000, 0x1531FFFE, 0x2B680168,
+ 0x3F418000, 0x2F34001F, 0x112E0002, 0x13408000,
+ 0x2B008000, 0x3E2C0002, 0x0D500000, 0x0D500000,
+ 0x228B4000, 0x1C208000, 0x13408000, 0x36200000,
+ 0x1C800E6A, 0x01685F58, 0x1A210000, 0x2E2C0028,
+ 0x0D500000, 0x0D500000, 0x0D500000, 0x15410000,
+ 0x228B4000, 0x0A230D4F, 0x0F3607FC, 0x3AC803A0,
+ 0x33635F54, 0x026B5F58, 0x12625F66, 0x010CC000,
+ 0x084B0000, 0x3E2C0002, 0x0B480000, 0x33635F62,
+ 0x2D6B010E, 0x36605F64, 0x2D0DC000, 0x36610108,
+ 0x0E970C64, 0x02685F62, 0x28695F64, 0x3B60B40C,
+ 0x1C61B40E, 0x28680108, 0x206A5F66, 0x2921B40A,
+ 0x3660B408, 0x21510000, 0x28200081, 0x3560B404,
+ 0x0962B414, 0x02685F54, 0x20210E8C, 0x362300AF,
+ 0x1D800C8B, 0x2D695F6E, 0x1C208000, 0x28150000,
+ 0x17C80EA2, 0x228B4000, 0x336A5EA0, 0x33605F6E,
+ 0x14200EA8, 0x2B36FFFD, 0x01625EA0, 0x288000B4,
+ 0x15685FDC, 0x2D695F6E, 0x30380000, 0x08C80F0B,
+ 0x28605F70, 0x232C0040, 0x27490000, 0x2E655F6E,
+ 0x3865B112, 0x1F31FFFB, 0x232D4010, 0x0D4A4000,
+ 0x1F6BB110, 0x122D0002, 0x1F0AC000, 0x24C00EFF,
+ 0x214B4000, 0x2C2DFFF6, 0x333B0000, 0x25D40EC4,
+ 0x1A685F70, 0x012D0012, 0x0D4A4000, 0x282C0042,
+ 0x084B0000, 0x312DFFEE, 0x1F1F8000, 0x3CCC0F01,
+ 0x28004000, 0x37215F72, 0x02970FF4, 0x3D695F72,
+ 0x332C0006, 0x13350003, 0x3DCC0F06, 0x37215F72,
+ 0x2922FFFC, 0x1C97100A, 0x1A685F70, 0x33215FDC,
+ 0x1D970F72, 0x1797103E, 0x0E970C64, 0x196B5F70,
+ 0x11685F72, 0x3B695F74, 0x2A22B40A, 0x3563B408,
+ 0x22520000, 0x3B60B40C, 0x1C61B40E, 0x28200081,
+ 0x3560B404, 0x20200040, 0x2660B414, 0x21210ED1,
+ 0x362300AF, 0x18940C8B, 0x01685F6E, 0x39695FEA,
+ 0x353400FF, 0x3330FFFB, 0x0A2C401A, 0x084B0000,
+ 0x1E2D0001, 0x312F0001, 0x3A430000, 0x002CFFF6,
+ 0x244A0000, 0x332C0006, 0x084B0000, 0x0B615FEA,
+ 0x312F0001, 0x1F0AC000, 0x17C40EF4, 0x35230000,
+ 0x3A430000, 0x2E6A5F6E, 0x1A685F70, 0x1A3600FF,
+ 0x3A3A1000, 0x1462B130, 0x15970F4A, 0x1C208000,
+ 0x33605F6E, 0x17230EA8, 0x33800126, 0x0D210088,
+ 0x29655F6F, 0x1A685F70, 0x2D695F6E, 0x3D2C0038,
+ 0x0B480000, 0x13800EAA, 0x20970106, 0x1A685F70,
+ 0x33215FDC, 0x19230EFA, 0x1B800F72, 0x336A5EA0,
+ 0x3C350800, 0x1F615F6E, 0x33C800AF, 0x143A0002,
+ 0x01625EA0, 0x398000AF, 0x1768B148, 0x05300001,
+ 0x1DD00F1B, 0x03300007, 0x19D00F20, 0x0C300008,
+ 0x3D3CFFFF, 0x1464B148, 0x388000A8, 0x35230000,
+ 0x2663B148, 0x39635FF2, 0x32635FF0, 0x19800F15,
+ 0x0E710048, 0x13710149, 0x2871804B, 0x1E800F22,
+ 0x00685FFC, 0x276AB1F8, 0x0934FF00, 0x0C300008,
+ 0x322C0001, 0x03361F00, 0x23320008, 0x1C0A0000,
+ 0x1DC0010A, 0x3F225E90, 0x3330FFFB, 0x1C2C4000,
+ 0x1C0A0000, 0x15C00104, 0x2F605FD2, 0x06625FD4,
+ 0x242A000F, 0x03C000FE, 0x228B4000, 0x10685FD6,
+ 0x37695FD4, 0x30380000, 0x04C80F3E, 0x27490000,
+ 0x0E615FD6, 0x228B4000, 0x33290044, 0x28C00F46,
+ 0x1D685FD2, 0x05615FD4, 0x2D010000, 0x022D0044,
+ 0x03615FD2, 0x228B4000, 0x361C0000, 0x2F605FD2,
+ 0x29605FD4, 0x228B4000, 0x3C695FD6, 0x30380000,
+ 0x27C80104, 0x15410000, 0x22605FD6, 0x228B4000,
+ 0x1C390000, 0x31C800FE, 0x0D4A4000, 0x30380000,
+ 0x27C80104, 0x10404000, 0x1F3A0000, 0x07C80F5E,
+ 0x362C003A, 0x16420000, 0x122E0038, 0x062CFFC6,
+ 0x13408000, 0x228B4000, 0x222DFFFE, 0x10404000,
+ 0x228B4000, 0x1C390000, 0x31C800FE, 0x0D4A4000,
+ 0x30380000, 0x27C80104, 0x10404000, 0x1F3A0000,
+ 0x06C80F6F, 0x3D2C0038, 0x16420000, 0x192E003A,
+ 0x0E2CFFC8, 0x13408000, 0x228B4000, 0x122D0002,
+ 0x10404000, 0x228B4000, 0x1C390000, 0x31C800FE,
+ 0x30380000, 0x27C80104, 0x2D635E96, 0x362C003A,
+ 0x084B0000, 0x0E2CFFFE, 0x244A0000, 0x333B0000,
+ 0x19C80F85, 0x1F3A0000, 0x0BC80F92, 0x3E2F0038,
+ 0x1542C000, 0x192E003A, 0x0D2FFFC8, 0x10438000,
+ 0x1D800F8D, 0x3F424000, 0x1F3A0000, 0x11C80F8B,
+ 0x192E003A, 0x10438000, 0x1D800F8D, 0x122D0002,
+ 0x3F424000, 0x0D500000, 0x0D500000, 0x1F6B5E96,
+ 0x0D2CFFC4, 0x228B4000, 0x122D0002, 0x3F424000,
+ 0x3E2F0038, 0x1542C000, 0x1D800F8D, 0x2A320001,
+ 0x0A367FFF, 0x03C80FAA, 0x252A0008, 0x32C00FA6,
+ 0x0D500000, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x03C80FAA, 0x0F800F9A, 0x26260008, 0x0D500000,
+ 0x262EFFFF, 0x36CC0FA7, 0x228B4000, 0x26635E94,
+ 0x14970FB4, 0x146B5E94, 0x288000B4, 0x26635E94,
+ 0x14970FB4, 0x02030000, 0x17685E94, 0x288000B4,
+ 0x22484000, 0x0F615E92, 0x28605E90, 0x0C300008,
+ 0x2BD40FD5, 0x2D635E96, 0x2C34007F, 0x3E30FFFF,
+ 0x122D0002, 0x2E0D0000, 0x214B4000, 0x05300001,
+ 0x322C0001, 0x36695E90, 0x191E0000, 0x3ECC0FC5,
+ 0x36200000, 0x07024000, 0x36368000, 0x0035007F,
+ 0x1A1D0000, 0x3D695E92, 0x1AC80FD3, 0x23320008,
+ 0x281A0000, 0x1E2D0001, 0x0E464000, 0x0200C000,
+ 0x1F6B5E96, 0x30380000, 0x228B4000, 0x3F424000,
+ 0x00800FCF, 0x361C0000, 0x228B4000, 0x28605E90,
+ 0x22484000, 0x0A625E94, 0x0C300008, 0x3FD40FF2,
+ 0x2E020000, 0x0C300008, 0x2C34007F, 0x0336007F,
+ 0x191E0000, 0x31C800FE, 0x3E30FFFF, 0x356A5E90,
+ 0x0F615E92, 0x122D0002, 0x2E0D0000, 0x3F424000,
+ 0x386A5E94, 0x3D695E92, 0x05300001, 0x322C0001,
+ 0x191E0000, 0x2ECC0FEF, 0x36200000, 0x29380080,
+ 0x21444000, 0x228B4000, 0x36200000, 0x16800FE3,
+ 0x2D635E96, 0x084B0000, 0x3E2C0002, 0x13434000,
+ 0x244A0000, 0x122D0002, 0x3F424000, 0x2E1B8000,
+ 0x3E2C0002, 0x244A0000, 0x122D0002, 0x3F424000,
+ 0x2E1B8000, 0x3E2C0002, 0x244A0000, 0x122D0002,
+ 0x3F424000, 0x2B1AC000, 0x1F6B5E96, 0x3E2C0002,
+ 0x122D0002, 0x228B4000, 0x28605E90, 0x0F615E92,
+ 0x2D635E96, 0x27490000, 0x280C8000, 0x0B480000,
+ 0x1C390000, 0x14C81031, 0x03340FFC, 0x0FC81019,
+ 0x15280041, 0x3DC01019, 0x16240041, 0x15072000,
+ 0x0480101E, 0x1831FFFA, 0x07024000, 0x2936FFC0,
+ 0x2B034000, 0x3937003F, 0x3D695E92, 0x22484000,
+ 0x1A048000, 0x10404000, 0x122D0002, 0x22484000,
+ 0x2C04C400, 0x10404000, 0x17C41031, 0x122D0002,
+ 0x22484000, 0x19220000, 0x05048400, 0x10404000,
+ 0x17C41031, 0x122D0002, 0x22484000, 0x05048400,
+ 0x10404000, 0x1F6B5E96, 0x1A685E90, 0x228B4000,
+ 0x14685F14, 0x32215F14, 0x30380000, 0x10D0103A,
+ 0x0B518000, 0x228B4000, 0x0200C000, 0x12220002,
+ 0x362300AF, 0x1D800FD7, 0x14685F14, 0x3A215F1A,
+ 0x30380000, 0x10D0103A, 0x228B4000, 0x14685F14,
+ 0x32215F14, 0x30380000, 0x16D40102, 0x2A340080,
+ 0x01C8104B, 0x12220002, 0x03800FAF, 0x21510000,
+ 0x1C685F1A, 0x28635E9C, 0x30380000, 0x26CC1051,
+ 0x228B4000, 0x3A215F1A, 0x12220002, 0x08970FAB,
+ 0x1A6B5E9C, 0x0A80104C, 0x3DFFFFFF, 0x01000000,
+ 0x01000000, 0x01000000
+};
+
+static const uint32_t fw2_farm_img_data_buf[2048] =
+{
+ 0x132040FA, 0x29502501, 0x032040D0, 0x295046C7,
+ 0x0D500000, 0x267001C9, 0x258C0200, 0x0F70AAC9,
+ 0x176B40C8, 0x3B7000C8, 0x2D70001D, 0x2670001F,
+ 0x18631FFC, 0x3370C033, 0x296A4010, 0x086B4014,
+ 0x39621FF8, 0x16631FF4, 0x15684000, 0x34694004,
+ 0x1E601FF6, 0x3F611FF2, 0x346A4008, 0x156B400C,
+ 0x32621FFA, 0x1B631FF0, 0x3A9700C9, 0x1E684034,
+ 0x2170001E, 0x3A34003F, 0x281A0000, 0x3F621FFE,
+ 0x0628000B, 0x2AC4004F, 0x1D24002F, 0x21884000,
+ 0x2380004F, 0x3A800036, 0x2880004D, 0x2B800041,
+ 0x2380004F, 0x20800043, 0x2080002F, 0x3880003D,
+ 0x26800045, 0x2D800047, 0x25800049, 0x276A4018,
+ 0x34621FFC, 0x3E9701EB, 0x09300002, 0x31D0006D,
+ 0x3930FFFE, 0x3080005F, 0x276A4018, 0x34621FFC,
+ 0x3A970275, 0x09300002, 0x31D0006D, 0x3930FFFE,
+ 0x3180006E, 0x2097032F, 0x268C0400, 0x16614018,
+ 0x3080005F, 0x2297075B, 0x3080005F, 0x3B970714,
+ 0x3080005F, 0x2497075D, 0x3080005F, 0x30970716,
+ 0x3080005F, 0x38230004, 0x29671FFC, 0x3397042A,
+ 0x3080005F, 0x3397078F, 0x3080005F, 0x3B7000C8,
+ 0x24200021, 0x358C5000, 0x2E80007D, 0x2B707FC8,
+ 0x08702084, 0x2D70001D, 0x36200000, 0x2D010000,
+ 0x1E220001, 0x3997009F, 0x01684084, 0x26340020,
+ 0x01CC005A, 0x3920000F, 0x3080005F, 0x238C0100,
+ 0x376A4032, 0x1F36C000, 0x3EC80064, 0x2120002B,
+ 0x09300002, 0x31D0006D, 0x1B601FFC, 0x2A681FF0,
+ 0x246A4014, 0x2D010000, 0x2460400C, 0x3997009F,
+ 0x29681FFC, 0x3930FFFE, 0x036A1FF6, 0x276B1FF8,
+ 0x08624000, 0x37634010, 0x0D6A1FFE, 0x279700D1,
+ 0x0E6A1FF2, 0x246B1FF4, 0x05624004, 0x3A634014,
+ 0x006A1FFA, 0x35230000, 0x06624008, 0x358C5000,
+ 0x3463401C, 0x106440C9, 0x3C800006, 0x376B1FE4,
+ 0x228B4000, 0x3C6B1FE6, 0x228B4000, 0x2C681FF6,
+ 0x252DFFFF, 0x07024000, 0x2F36FFF0, 0x21320003,
+ 0x3930FFFE, 0x1F060000, 0x0E4A8000, 0x28004000,
+ 0x3C34000F, 0x1A120000, 0x228B4000, 0x24681FF8,
+ 0x3330FFFB, 0x00601FE2, 0x228B4000, 0x3F8C0480,
+ 0x33BC0053, 0x1B61401C, 0x228B4000, 0x2D010000,
+ 0x3930FFFE, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x09300002, 0x202A0002, 0x0B614000,
+ 0x1B624010, 0x29604008, 0x1D218808, 0x3C800093,
+ 0x0B631FEC, 0x0B614000, 0x086A1FF4, 0x2D010000,
+ 0x1668400C, 0x1B624010, 0x299700D9, 0x18684004,
+ 0x0D691FF2, 0x086A1FF4, 0x396B1FEC, 0x2F8000EF,
+ 0x37694008, 0x268C0400, 0x0D684024, 0x04140000,
+ 0x19D400B7, 0x36200000, 0x228B4000, 0x00240001,
+ 0x1A084000, 0x228B4000, 0x3930FFFE, 0x15410000,
+ 0x0C240002, 0x0D500000, 0x09300002, 0x262EFFFF,
+ 0x31800097, 0x13684030, 0x37380001, 0x21604030,
+ 0x228B4000, 0x13684030, 0x0834FFFE, 0x21604030,
+ 0x228B4000, 0x386A40C4, 0x3F694030, 0x1B360001,
+ 0x1732FFF9, 0x18350001, 0x1831FFFA, 0x011A4000,
+ 0x228B4000, 0x07018000, 0x28310006, 0x18350001,
+ 0x0D614030, 0x2C320007, 0x1B360001, 0x0A6240C4,
+ 0x228B4000, 0x29604008, 0x06614004, 0x16624014,
+ 0x37218001, 0x268C0400, 0x1B61401C, 0x2A694010,
+ 0x27604000, 0x36064000, 0x1B624010, 0x228B4000,
+ 0x29604008, 0x06614004, 0x16624014, 0x2D218018,
+ 0x268C0400, 0x1B61401C, 0x296A4010, 0x27604000,
+ 0x2F260001, 0x1B624010, 0x228B4000, 0x29604008,
+ 0x06614004, 0x16624014, 0x262EFFFF, 0x36058000,
+ 0x1531FFFE, 0x22484000, 0x20250002, 0x0E494000,
+ 0x2B190000, 0x0ACC00FB, 0x16624014, 0x1B684008,
+ 0x2C218200, 0x268C0400, 0x1B61401C, 0x246A4014,
+ 0x27604000, 0x1B624010, 0x228B4000, 0x1C2100FF,
+ 0x26800106, 0x1A210000, 0x05631FE4, 0x24611FEC,
+ 0x21681FF2, 0x2B6040A0, 0x0B691FF4, 0x27604000,
+ 0x29604008, 0x18614010, 0x268C0400, 0x0970081C,
+ 0x2470881D, 0x0FF00111, 0x3930FFFE, 0x27490000,
+ 0x29310001, 0x3A200003, 0x18D4007F, 0x1231FFFF,
+ 0x286540B4, 0x216B1FFE, 0x036A1FF6, 0x3D33FFFF,
+ 0x38D00127, 0x276B1FF8, 0x08624000, 0x06624008,
+ 0x37634010, 0x268C0400, 0x3C70011F, 0x0970081C,
+ 0x2470881D, 0x04F00125, 0x3B800128, 0x268C0400,
+ 0x196840A0, 0x21694024, 0x1F090000, 0x39C801E9,
+ 0x07024000, 0x1D2E0001, 0x16624014, 0x1F31FFFB,
+ 0x0E684028, 0x2670001F, 0x2F34001F, 0x2E184000,
+ 0x322C0001, 0x2E020000, 0x09240008, 0x1334FFE0,
+ 0x08300005, 0x0B691FF4, 0x206040A2, 0x2D6040A6,
+ 0x322C0001, 0x1F090000, 0x3DC4014B, 0x356940A0,
+ 0x1C050000, 0x252DFFFF, 0x1531FFFE, 0x21510000,
+ 0x21510000, 0x03691FFA, 0x1C050000, 0x252DFFFF,
+ 0x1531FFFE, 0x21510000, 0x21510000, 0x322C0001,
+ 0x16691FEC, 0x0834FFFE, 0x2B3D00FF, 0x12CC0153,
+ 0x27681FF4, 0x0B240003, 0x0834FFFE, 0x08601FEC,
+ 0x2B26000C, 0x21621FEA, 0x2226005F, 0x35200060,
+ 0x35230000, 0x160B2000, 0x252DFFFF, 0x026140AA,
+ 0x1E2D0001, 0x15072000, 0x3F6B1FEA, 0x28004000,
+ 0x3530FFFD, 0x1F0AC000, 0x35230000, 0x0D631FEA,
+ 0x160B2000, 0x3520000C, 0x35230000, 0x29290007,
+ 0x28C4016B, 0x2A250007, 0x2080016C, 0x1B210007,
+ 0x1A084000, 0x2D1B4000, 0x33634088, 0x306940AA,
+ 0x3530FFFD, 0x1E2D0001, 0x15072000, 0x252A0008,
+ 0x2A621FE8, 0x2B008000, 0x1D2E0001, 0x1334FFE0,
+ 0x08300005, 0x322C0001, 0x296B1FF0, 0x16691FEC,
+ 0x03601FEE, 0x1A074000, 0x24634000, 0x3A33FFFE,
+ 0x0E530000, 0x0E530000, 0x0E530000, 0x0E530000,
+ 0x0A330002, 0x2A634008, 0x33070000, 0x0B2B0003,
+ 0x09280004, 0x13C001A1, 0x322C0001, 0x34604010,
+ 0x268C0400, 0x3C70011F, 0x2A70001C, 0x2470881D,
+ 0x11F00190, 0x0E691FFE, 0x0D684024, 0x1231FFFF,
+ 0x20D001A0, 0x00691FF6, 0x04140000, 0x37D001E7,
+ 0x1A084000, 0x22694028, 0x0335001F, 0x3330FFFB,
+ 0x2E184000, 0x3DC801E4, 0x322C0001, 0x00601FE2,
+ 0x2670001F, 0x2B008000, 0x3D3CFFFF, 0x30218000,
+ 0x19110000, 0x3A33FFFE, 0x20340010, 0x25C801AC,
+ 0x1641C000, 0x0F270002, 0x0E530000, 0x248001AE,
+ 0x0E530000, 0x1641C000, 0x31681FEE, 0x356940A0,
+ 0x34604010, 0x166B4000, 0x3304C000, 0x322C0001,
+ 0x0834FFFE, 0x06614004, 0x29604008, 0x0568401C,
+ 0x268C0400, 0x3C70011F, 0x2A70001C, 0x1B70821D,
+ 0x07F001BC, 0x3D340008, 0x2DC801CE, 0x0E691FFE,
+ 0x0D684024, 0x1231FFFF, 0x2BD001CE, 0x00691FF6,
+ 0x04140000, 0x37D001E7, 0x1A084000, 0x22694028,
+ 0x3330FFFB, 0x0335001F, 0x2E184000, 0x3DC801E4,
+ 0x322C0001, 0x00601FE2, 0x2670001F, 0x1B691FE8,
+ 0x3E20000E, 0x29310001, 0x1231FFFF, 0x36D001D6,
+ 0x092CFFFF, 0x378001D2, 0x39694000, 0x0C2207FA,
+ 0x186B4008, 0x096140A8, 0x256340A4, 0x076240AC,
+ 0x236040AE, 0x2E7000B2, 0x3F8C0480, 0x33BC0053,
+ 0x31700484, 0x32E001E1, 0x31200001, 0x2580007F,
+ 0x3F200009, 0x2670001F, 0x2580007F, 0x3C200005,
+ 0x308001E5, 0x37200007, 0x308001E5, 0x08631FE0,
+ 0x35230000, 0x25671FFF, 0x227001C4, 0x2C970105,
+ 0x063C0001, 0x2EC801F4, 0x063C0001, 0x2F80023F,
+ 0x2F681FFA, 0x05691FFC, 0x266040A4, 0x3A8C0180,
+ 0x33BC0053, 0x2D3D0000, 0x3DC80241, 0x34700184,
+ 0x25E001FC, 0x3B6940A8, 0x126840A2, 0x0B614000,
+ 0x322C0001, 0x296B1FF0, 0x34604010, 0x2A634008,
+ 0x3A8C0180, 0x33BC0053, 0x2A70001C, 0x2470881D,
+ 0x05691FFC, 0x252DFFFF, 0x39C80220, 0x28004000,
+ 0x0034FFF0, 0x3420000B, 0x14CC023F, 0x156A1FEC,
+ 0x0200C000, 0x1A048000, 0x266340A8, 0x256340A4,
+ 0x3F8C0480, 0x33BC0053, 0x34700184, 0x3BE00217,
+ 0x256040A8, 0x1A048000, 0x3A8C0180, 0x33BC0053,
+ 0x32700284, 0x3EE0021D, 0x252DFFFF, 0x00CC0218,
+ 0x2A681FF0, 0x16691FEC, 0x1C050000, 0x036A1FF6,
+ 0x316B1FE2, 0x256040A8, 0x0A6140A4, 0x076240AC,
+ 0x29681FFC, 0x0C2B0002, 0x092CFFFF, 0x206340AE,
+ 0x336040B2, 0x2C8C5080, 0x33BC0053, 0x31700484,
+ 0x2FE00230, 0x06691FF0, 0x3D201FE8, 0x096140A8,
+ 0x0A500001, 0x0F280002, 0x09300002, 0x266040A4,
+ 0x36200000, 0x2D6040A6, 0x3A8C0180, 0x33BC0053,
+ 0x34700184, 0x2BE0023D, 0x31200001, 0x3A6B1FE0,
+ 0x228B4000, 0x06691FF0, 0x156A1FEC, 0x28004000,
+ 0x1A048000, 0x03601FEE, 0x2D010000, 0x1A048000,
+ 0x3D6A40A2, 0x266040A4, 0x1D2E0001, 0x3997009F,
+ 0x03691FFA, 0x31681FEE, 0x3997009F, 0x2A681FF0,
+ 0x1D210001, 0x269700BA, 0x31681FEE, 0x386940A4,
+ 0x2C97026F, 0x2A681FF0, 0x268C0400, 0x2C97026F,
+ 0x2A97008F, 0x1E691FE2, 0x2D3D0000, 0x2DC80231,
+ 0x29970083, 0x2C611FE2, 0x1B360001, 0x10CC0268,
+ 0x38200008, 0x31681FEE, 0x06691FF0, 0x2C97026F,
+ 0x2A681FF0, 0x25230259, 0x2D010000, 0x2A80026F,
+ 0x2A681FF0, 0x1D691FEE, 0x2C97026F, 0x31681FEE,
+ 0x25230259, 0x2D010000, 0x2A80026F, 0x0A6140A4,
+ 0x256040A8, 0x3A8C0180, 0x33BC0053, 0x34700184,
+ 0x228B4000, 0x0E631FE6, 0x3E9702B7, 0x259702C5,
+ 0x39681FD6, 0x0E6A1FF2, 0x00691FF6, 0x276B1FF8,
+ 0x1F060000, 0x03270001, 0x0B37FFFE, 0x1F05C000,
+ 0x296B1FF0, 0x32611FF6, 0x3304C000, 0x3C621FF2,
+ 0x1D601FFA, 0x18601FF0, 0x268C0400, 0x3E9701EB,
+ 0x02030000, 0x053F0001, 0x0FCC02B4, 0x238C0100,
+ 0x166A1FD6, 0x06691FF0, 0x28004000, 0x35098000,
+ 0x1A048000, 0x3997009F, 0x2D010000, 0x15684000,
+ 0x35098000, 0x35068000, 0x3997009F, 0x276B1FF8,
+ 0x00691FF6, 0x03270001, 0x0B37FFFE, 0x1C09C000,
+ 0x3A6B1FD6, 0x0E6A1FF2, 0x32611FF6, 0x1F0AC000,
+ 0x3C621FF2, 0x268C0400, 0x3E9701EB, 0x326B1FD8,
+ 0x166A1FD6, 0x06691FF0, 0x1E631FFA, 0x35098000,
+ 0x34611FF0, 0x02030000, 0x053F0001, 0x0FCC02B4,
+ 0x238C0100, 0x1A210000, 0x299702F0, 0x2B97031B,
+ 0x2A681FF0, 0x2460400C, 0x268C0400, 0x31200001,
+ 0x24800081, 0x37200007, 0x348002B4, 0x0B631FEC,
+ 0x0D691FF2, 0x006A1FFA, 0x06614004, 0x0B691FF4,
+ 0x2C621FD8, 0x15614014, 0x2D3D0000, 0x39C802B5,
+ 0x28004000, 0x0C240002, 0x0834FFFE, 0x0B601FD6,
+ 0x228B4000, 0x0B631FEC, 0x349700C1, 0x39681FD6,
+ 0x296B1FF0, 0x30040000, 0x33070000, 0x0F270002,
+ 0x2763400C, 0x19220000, 0x21681FF2, 0x16624014,
+ 0x1A048000, 0x2A604004, 0x086A1FF4, 0x2D010000,
+ 0x3997009F, 0x239700B0, 0x0F280002, 0x0BC002B5,
+ 0x0C240002, 0x246A4014, 0x39604014, 0x0B691FF4,
+ 0x296B1FF0, 0x35054000, 0x24634000, 0x18614010,
+ 0x156B400C, 0x2C218200, 0x19078000, 0x2A634008,
+ 0x3A970093, 0x18684004, 0x0D691FF2, 0x166A1FD6,
+ 0x1A1D0000, 0x2BC802CE, 0x3A69400C, 0x2A681FF0,
+ 0x35068000, 0x3997009F, 0x396B1FEC, 0x3F8000C5,
+ 0x0B631FEC, 0x2A681FF0, 0x1A048000, 0x2460400C,
+ 0x1A048000, 0x0C240002, 0x19044000, 0x086A1FF4,
+ 0x0D691FF2, 0x3930FFFE, 0x0D500000, 0x0D500000,
+ 0x09300002, 0x3997009F, 0x239700B0, 0x39604014,
+ 0x1B684008, 0x156B400C, 0x2F260001, 0x06691FF0,
+ 0x03280001, 0x1B624010, 0x29604008, 0x06614004,
+ 0x24634000, 0x2C2A0001, 0x36058000, 0x1531FFFE,
+ 0x21510000, 0x21510000, 0x19078000, 0x3A33FFFE,
+ 0x0E530000, 0x0E530000, 0x3B218002, 0x3A970093,
+ 0x23260002, 0x1B624010, 0x246A4014, 0x03691FFA,
+ 0x1B684008, 0x396B1FEC, 0x2F8000D9, 0x0B631FEC,
+ 0x349700C1, 0x166B4000, 0x1668400C, 0x2763400C,
+ 0x0D691FF2, 0x246A4014, 0x299700EF, 0x3A6B1FD6,
+ 0x0D691FF2, 0x1668400C, 0x1F05C000, 0x086A1FF4,
+ 0x299700D9, 0x2A681FF0, 0x086A1FF4, 0x2D010000,
+ 0x2B9700E4, 0x396B1FEC, 0x3F8000C5, 0x05631FE4,
+ 0x2A681FF0, 0x2460400C, 0x08691FF8, 0x29611FDE,
+ 0x086A1FF4, 0x21621FDC, 0x350A4000, 0x040E4000,
+ 0x02D4033A, 0x07024000, 0x24260003, 0x2736FFFE,
+ 0x00601FE2, 0x1A048000, 0x0B601FE0, 0x1A048000,
+ 0x35068000, 0x37621FF0, 0x1A048000, 0x0B601FD6,
+ 0x1668400C, 0x37970097, 0x056A1FF0, 0x1668400C,
+ 0x1A048000, 0x37970097, 0x0B6A1FF8, 0x32681FE2,
+ 0x296B1FF0, 0x3304C000, 0x00691FF6, 0x3997009F,
+ 0x268C0400, 0x0E6B4024, 0x05631FD2, 0x1A378000,
+ 0x09CC041D, 0x39681FE0, 0x296B1FF0, 0x3304C000,
+ 0x0D691FF2, 0x086A1FF4, 0x3997009F, 0x32681FE2,
+ 0x3930FFFE, 0x0A500001, 0x39681FE0, 0x0D691FF2,
+ 0x3997009F, 0x3B201FD8, 0x0D500000, 0x0D500000,
+ 0x0D691FF2, 0x1531FFFE, 0x0E494000, 0x29310001,
+ 0x0DD40420, 0x1231FFFF, 0x36200000, 0x00601FD4,
+ 0x32230001, 0x1E220001, 0x0200C000, 0x2E148000,
+ 0x2CC80375, 0x32681FD4, 0x1A048000, 0x00601FD4,
+ 0x1A074000, 0x35054000, 0x35068000, 0x0CCC036E,
+ 0x32681FE2, 0x296B1FF0, 0x3304C000, 0x1A210000,
+ 0x186A1FDE, 0x3B970424, 0x3930FFFE, 0x0B480000,
+ 0x1A388000, 0x05300001, 0x23D00385, 0x2C250001,
+ 0x22800381, 0x2D3D0000, 0x28C803B7, 0x268C0400,
+ 0x16614018, 0x26218040, 0x3A970093, 0x32681FD4,
+ 0x1E691FE2, 0x1531FFFE, 0x0E494000, 0x15072000,
+ 0x1D210001, 0x0B6B4018, 0x3E3FFFFF, 0x03270001,
+ 0x1A11C000, 0x252DFFFF, 0x02164000, 0x326B1FD8,
+ 0x268C0400, 0x21694024, 0x2A611FD2, 0x35C803AF,
+ 0x1F1F8000, 0x34C803A8, 0x2C621FD8, 0x21681FF2,
+ 0x0C2107F6, 0x3A970423, 0x1E220001, 0x16624014,
+ 0x39681FD6, 0x29604008, 0x37218001, 0x3A970093,
+ 0x15691FD6, 0x32681FE2, 0x086A1FF4, 0x2F260001,
+ 0x3B970424, 0x23218010, 0x3A970093, 0x32681FE2,
+ 0x1A210000, 0x086A1FF4, 0x2F260001, 0x3B970424,
+ 0x26218040, 0x3A970093, 0x22800378, 0x39681FE0,
+ 0x296B1FF0, 0x3304C000, 0x2A604004, 0x32681FE2,
+ 0x3304C000, 0x27604000, 0x186A1FDE, 0x3F6B1FDC,
+ 0x3A634014, 0x1F0AC000, 0x2E0EC000, 0x04D403C5,
+ 0x2D02C000, 0x1B624010, 0x2F218400, 0x3A970093,
+ 0x18691FD2, 0x1F1C4000, 0x10CC03D2, 0x1531FFFE,
+ 0x22484000, 0x063C0001, 0x122D0002, 0x0E494000,
+ 0x2E184000, 0x30C80413, 0x268C0400, 0x00684020,
+ 0x05300001, 0x3ED0041D, 0x09300002, 0x2AD003E0,
+ 0x15684000, 0x34694004, 0x2A604004, 0x0B614000,
+ 0x06684010, 0x27694014, 0x39604014, 0x18614010,
+ 0x166B4000, 0x2A634008, 0x0E631FD0, 0x25218020,
+ 0x3A970093, 0x23D003E9, 0x39681FE0, 0x1E691FE2,
+ 0x248003EB, 0x32681FE2, 0x15691FE0, 0x086A1FF4,
+ 0x2F260001, 0x3B970424, 0x268C0400, 0x226A4024,
+ 0x25218020, 0x3A970093, 0x3F681FD0, 0x1C0A0000,
+ 0x2F260001, 0x15691FE0, 0x296B1FF0, 0x1F05C000,
+ 0x1A1D0000, 0x1ECC0400, 0x32681FE2, 0x15691FE0,
+ 0x0B601FE0, 0x2C611FE2, 0x37681FDE, 0x0E601FDC,
+ 0x2A621FDE, 0x32681FE2, 0x0D691FF2, 0x3A970423,
+ 0x296A4010, 0x1A048000, 0x3930FFFE, 0x268C0400,
+ 0x084B0000, 0x0D500000, 0x0D500000, 0x023F0000,
+ 0x28C80378, 0x23218010, 0x3A970093, 0x052CFFFC,
+ 0x268C0400, 0x0D500000, 0x22800378, 0x1E691FE2,
+ 0x39681FE0, 0x086A1FF4, 0x3997009F, 0x16624014,
+ 0x31200001, 0x1A210000, 0x156B400C, 0x1B631FF0,
+ 0x2580007F, 0x24200017, 0x1B210007, 0x3380041A,
+ 0x3A200003, 0x0621001F, 0x3380041A, 0x086A1FF4,
+ 0x1B624010, 0x16624014, 0x27604000, 0x06614004,
+ 0x29604008, 0x228B4000, 0x0E631FE6, 0x2C681FF6,
+ 0x08691FF8, 0x086A1FF4, 0x1D601FCC, 0x37611FCA,
+ 0x24260003, 0x2736FFFE, 0x39621FCE, 0x2A681FF0,
+ 0x1A048000, 0x1A048000, 0x0B691FF4, 0x0E6A1FF2,
+ 0x3A9706F3, 0x063C0001, 0x2DC8043D, 0x063C0001,
+ 0x2E800458, 0x06691FF0, 0x0B6A1FCE, 0x28004000,
+ 0x1A048000, 0x2460400C, 0x19088000, 0x19088000,
+ 0x358C5000, 0x3D9700A4, 0x06691FF0, 0x0B6A1FCE,
+ 0x28004000, 0x19088000, 0x19088000, 0x18601FF0,
+ 0x3D9700A4, 0x2A681FF0, 0x0B6A1FCE, 0x1D210001,
+ 0x1A048000, 0x1A048000, 0x269700BA, 0x03691FCC,
+ 0x066A1FCA, 0x32611FF6, 0x39621FF8, 0x31200001,
+ 0x268C0400, 0x24800081, 0x0D601FD0, 0x296A4010,
+ 0x15684000, 0x2C621FD8, 0x08601FDA, 0x10691FDC,
+ 0x2A681FF0, 0x216B1FFE, 0x07024000, 0x36064000,
+ 0x071BC000, 0x1AD40467, 0x36064000, 0x37970097,
+ 0x1E6A1FD8, 0x3A681FDA, 0x1B624010, 0x27604000,
+ 0x3F681FD0, 0x063C0001, 0x0FCC0477, 0x216B1FFE,
+ 0x071BC000, 0x33D00475, 0x269706B6, 0x0D601FD0,
+ 0x3680047C, 0x389706A2, 0x3680047C, 0x0D3C0003,
+ 0x0DCC047C, 0x33970489, 0x31200001, 0x0D601FD0,
+ 0x3F681FD0, 0x35230000, 0x2D010000, 0x293D000D,
+ 0x0BCC0483, 0x34230007, 0x3A800486, 0x2E3D000C,
+ 0x30C80486, 0x2923001F, 0x268C0400, 0x39634018,
+ 0x24800081, 0x08631FD6, 0x2A681FF0, 0x03691FFA,
+ 0x086A1FF4, 0x3997009F, 0x16624014, 0x136A1FDC,
+ 0x03691FFA, 0x226B1FF2, 0x1A048000, 0x36058000,
+ 0x06614004, 0x29604008, 0x24634000, 0x25218020,
+ 0x3A970093, 0x0E691FFE, 0x1A048000, 0x02194000,
+ 0x1DD4049F, 0x3930FFFE, 0x0A500001, 0x3A6B1FD6,
+ 0x228B4000, 0x1A048000, 0x3930FFFE, 0x0D500000,
+ 0x0D500000, 0x0D500000, 0x0D500000, 0x228B4000,
+ 0x086A1FF4, 0x1D2E0001, 0x1B624010, 0x0B614000,
+ 0x29604008, 0x268C0400, 0x2A70001C, 0x2470881D,
+ 0x36058000, 0x1A048000, 0x228B4000, 0x27604000,
+ 0x27681FF4, 0x05614008, 0x34604010, 0x268C0400,
+ 0x15624018, 0x2E020000, 0x29218080, 0x3C800093,
+ 0x08631FD6, 0x387000C4, 0x30700090, 0x2A970103,
+ 0x246B1FF4, 0x08270003, 0x0B37FFFE, 0x0D631FDC,
+ 0x2D010000, 0x2A3D0001, 0x238C0100, 0x1ECC045A,
+ 0x3D6A40A2, 0x176840A8, 0x2F260001, 0x289704A1,
+ 0x21681FF2, 0x086A1FF4, 0x289704A1, 0x2F260001,
+ 0x2736FFFE, 0x0F6240A2, 0x026240A6, 0x3A6B1FD6,
+ 0x228B4000, 0x08631FD6, 0x136A1FDC, 0x06691FF0,
+ 0x3D201FB2, 0x2D230012, 0x35098000, 0x36058000,
+ 0x15410000, 0x3E2C0002, 0x0A2FFFFF, 0x00CC04DB,
+ 0x37681FB2, 0x37970097, 0x136A1FDC, 0x3A681FB6,
+ 0x1D32FFFC, 0x37970097, 0x2397052F, 0x16691FB6,
+ 0x21681FF2, 0x1E220001, 0x309704B3, 0x1E220001,
+ 0x1B691FB2, 0x3A6B1FD6, 0x34800534, 0x08631FD6,
+ 0x3F6B1FDC, 0x0D691FF2, 0x1D6A1FD4, 0x1F05C000,
+ 0x20970523, 0x15691FBA, 0x1E220001, 0x32970534,
+ 0x106A1FD0, 0x03691FFA, 0x20970523, 0x216B1FFE,
+ 0x03691FFA, 0x071BC000, 0x08D40505, 0x3F6B1FDC,
+ 0x036A1FC0, 0x1F05C000, 0x1F05C000, 0x20970523,
+ 0x31800508, 0x15691FBA, 0x2C681FC0, 0x219704A8,
+ 0x13691FD0, 0x34681FBE, 0x036A1FC0, 0x286040AC,
+ 0x096140A8, 0x096240A4, 0x358C5000, 0x28700384,
+ 0x3A6B1FD6, 0x228B4000, 0x136A1FDC, 0x15691FBA,
+ 0x16624014, 0x1632FFFE, 0x35098000, 0x0B614000,
+ 0x0A6140A4, 0x16691FB6, 0x1D6A1FB8, 0x05614008,
+ 0x0B691FF4, 0x05624004, 0x1E2D0001, 0x18614010,
+ 0x228B4000, 0x1B684008, 0x2880052B, 0x0B631FEC,
+ 0x2B008000, 0x296A4010, 0x3997009F, 0x086A1FF4,
+ 0x289704A1, 0x1B684008, 0x396B1FEC, 0x256040A8,
+ 0x358C5000, 0x34700184, 0x228B4000, 0x086A1FF4,
+ 0x1D691FB4, 0x1B624010, 0x0A6140A4, 0x228B4000,
+ 0x28004000, 0x1531FFFE, 0x268C0400, 0x3F424000,
+ 0x2880052B, 0x2C8C5080, 0x33BC0053, 0x13204096,
+ 0x228B4000, 0x2C8C5080, 0x33BC0053, 0x13204096,
+ 0x3E500C63, 0x228B4000, 0x1B6A1FBE, 0x096140A8,
+ 0x096240A4, 0x238C0100, 0x34700184, 0x0E6A1FF2,
+ 0x0B614000, 0x05624004, 0x086A1FF4, 0x05614008,
+ 0x16624014, 0x238C0100, 0x20694080, 0x18350001,
+ 0x0ACC0552, 0x228B4000, 0x1D2E0001, 0x1B624010,
+ 0x25218020, 0x3C800093, 0x08631FD6, 0x16502DE7,
+ 0x3F502084, 0x3B97053D, 0x13502931, 0x36970539,
+ 0x23700080, 0x13503548, 0x03501CE4, 0x3B97053D,
+ 0x315024A9, 0x36970539, 0x0350A148, 0x0A5035A4,
+ 0x3B97053D, 0x3350252E, 0x36970539, 0x0E502929,
+ 0x145035B0, 0x3B97053D, 0x3F502108, 0x36970539,
+ 0x2B5025A9, 0x1D502CA6, 0x3B97053D, 0x1450288A,
+ 0x36970539, 0x2350B4EB, 0x18509525, 0x3B97053D,
+ 0x37501086, 0x36970539, 0x0F502D67, 0x035035AD,
+ 0x3B97053D, 0x1C501991, 0x36970539, 0x0F6B4080,
+ 0x00631FEE, 0x235098C4, 0x27509DAF, 0x3B97053D,
+ 0x1450316C, 0x36970539, 0x00509148, 0x1E502CC6,
+ 0x3B97053D, 0x1A50358E, 0x36970539, 0x355099AB,
+ 0x3A6B1FD6, 0x228B4000, 0x08631FD6, 0x30700090,
+ 0x21970512, 0x358C5000, 0x23700080, 0x13204096,
+ 0x3E500C63, 0x235024E4, 0x13204096, 0x3E500C63,
+ 0x045030A6, 0x36970539, 0x2850B12C, 0x395020EE,
+ 0x3B97053D, 0x0B5028AF, 0x36970539, 0x3D50A90A,
+ 0x3D50AD8C, 0x36970539, 0x29503D6B, 0x1850C54A,
+ 0x3B97053D, 0x0F6B4080, 0x00631FEE, 0x23700080,
+ 0x1C50352B, 0x36970539, 0x326B1FEE, 0x236A4080,
+ 0x07330006, 0x06D405AE, 0x2B320006, 0x23D005D3,
+ 0x3220000D, 0x2580045A, 0x3E500C63, 0x16502D8B,
+ 0x3B97053D, 0x3450252F, 0x36970539, 0x3950252B,
+ 0x3350210B, 0x3B97053D, 0x1B5018E5, 0x36970539,
+ 0x3E500C63, 0x205044D1, 0x3B97053D, 0x3D502409,
+ 0x36970539, 0x0550A531, 0x065018CB, 0x36970539,
+ 0x3E500C63, 0x32504409, 0x3B97053D, 0x2450112C,
+ 0x36970539, 0x3650B62D, 0x0D50300C, 0x36970539,
+ 0x3E500C63, 0x025035AA, 0x36970539, 0x2550B50D,
+ 0x3B502520, 0x36970539, 0x1B501C63, 0x3350140D,
+ 0x36970539, 0x3A6B1FD6, 0x228B4000, 0x2397052F,
+ 0x3F6B1FDC, 0x0D691FF2, 0x1D6A1FD4, 0x1F05C000,
+ 0x20970523, 0x1E691FB8, 0x3F681FD0, 0x219704A8,
+ 0x13691FD0, 0x12220002, 0x32970534, 0x1E691FB8,
+ 0x2C681FC0, 0x2D9704AB, 0x00691FC0, 0x15220003,
+ 0x32970534, 0x21970512, 0x358C5000, 0x23700080,
+ 0x13204096, 0x3E500C63, 0x3F502084, 0x13204096,
+ 0x3E500C63, 0x0B5035CF, 0x36970539, 0x3E500C63,
+ 0x0C502D07, 0x3B97053D, 0x195034AD, 0x36970539,
+ 0x3E500C63, 0x325024A5, 0x3B97053D, 0x165029AE,
+ 0x36970539, 0x0F503144, 0x2F502531, 0x3B97053D,
+ 0x0250194A, 0x36970539, 0x295010C8, 0x0E50318C,
+ 0x3B97053D, 0x085028CF, 0x36970539, 0x24502569,
+ 0x195019AD, 0x3B97053D, 0x25501004, 0x36970539,
+ 0x3E50B08C, 0x11502D29, 0x3B97053D, 0x1B5019A6,
+ 0x36970539, 0x3E500C63, 0x3450140C, 0x3B97053D,
+ 0x2750218F, 0x36970539, 0x2550AD0B, 0x04502940,
+ 0x36970539, 0x3E500C63, 0x0C50300B, 0x3B97053D,
+ 0x3C5011AB, 0x36970539, 0x3250B585, 0x3B502520,
+ 0x36970539, 0x3E500C63, 0x0E5035A9, 0x36970539,
+ 0x3350B54D, 0x15502C0B, 0x36970539, 0x1B501C63,
+ 0x3350140D, 0x36970539, 0x3A6B1FD6, 0x228B4000,
+ 0x08631FD6, 0x2397052F, 0x03691FCC, 0x3F6B1FDC,
+ 0x2F681FFA, 0x1E220001, 0x3304C000, 0x309704B3,
+ 0x2B970521, 0x08691FCE, 0x3F6B1FDC, 0x21681FF2,
+ 0x1E220001, 0x3304C000, 0x3304C000, 0x309704B3,
+ 0x2B970521, 0x30700090, 0x21970512, 0x358C5000,
+ 0x13204096, 0x3E500C63, 0x0B502A25, 0x13204096,
+ 0x3E500C63, 0x2250248F, 0x36970539, 0x0250292A,
+ 0x285020AF, 0x3B97053D, 0x25501004, 0x36970539,
+ 0x00502D04, 0x295038AE, 0x3B97053D, 0x245024E5,
+ 0x36970539, 0x1650A088, 0x2A50392E, 0x3B97053D,
+ 0x19502D4B, 0x36970539, 0x3E500C63, 0x0A502924,
+ 0x3B97053D, 0x0F502CEB, 0x36970539, 0x00502DCB,
+ 0x3B5011AA, 0x3B97053D, 0x3F502108, 0x36970539,
+ 0x3E500C63, 0x15502C0B, 0x3B97053D, 0x2A5020C8,
+ 0x36970539, 0x2550AD0B, 0x0D502925, 0x36970539,
+ 0x1B501C63, 0x3550140B, 0x3B97053D, 0x185019AA,
+ 0x36970539, 0x3A6B1FD6, 0x228B4000, 0x08631FD6,
+ 0x21681FF2, 0x10691FDC, 0x086A1FF4, 0x19044000,
+ 0x27604000, 0x289704A1, 0x21681FF2, 0x35054000,
+ 0x19044000, 0x289704A1, 0x07024000, 0x39694000,
+ 0x29681FCA, 0x3997009F, 0x21970512, 0x13204096,
+ 0x268C0400, 0x3E500C63, 0x225020C6, 0x3B97053D,
+ 0x325024A5, 0x36970539, 0x3E500C63, 0x0E502D0C,
+ 0x3B97053D, 0x1C502884, 0x36970539, 0x3E500C63,
+ 0x335021A8, 0x3B97053D, 0x00502C2B, 0x36970539,
+ 0x1450296A, 0x30502028, 0x36970539, 0x0D50A509,
+ 0x09502944, 0x36970539, 0x3E500C63, 0x325024C9,
+ 0x36970539, 0x1B50A549, 0x2A502144, 0x3B97053D,
+ 0x3D502409, 0x36970539, 0x358C5000, 0x0F6B4080,
+ 0x3E370008, 0x0ECC06A0, 0x2720001B, 0x2580045A,
+ 0x3A6B1FD6, 0x228B4000, 0x1E631FCC, 0x2C681FC0,
+ 0x3930FFFE, 0x0A500001, 0x1B204098, 0x3F5010E4,
+ 0x01000000, 0x1B204098, 0x358C5000, 0x275014E5,
+ 0x01000000, 0x1B204098, 0x358C5000, 0x175018E6,
+ 0x136A1FDC, 0x07018000, 0x35068000, 0x36064000,
+ 0x36970539, 0x278006ED, 0x1E631FCC, 0x036A1FC0,
+ 0x1632FFFE, 0x358C5000, 0x25520001, 0x1B204098,
+ 0x175018E6, 0x296B1FF0, 0x2C681FF6, 0x08691FF8,
+ 0x10631FC4, 0x18601FC6, 0x3C611FC8, 0x3F6B1FDC,
+ 0x126840A2, 0x03691FFA, 0x18631FCA, 0x15601FC2,
+ 0x3A611FCE, 0x02684088, 0x306940AA, 0x0D601FD0,
+ 0x2A611FD2, 0x34681FBE, 0x0B691FF4, 0x0E6A1FF2,
+ 0x3A9706F3, 0x387000C4, 0x226B1FC4, 0x056A1FC6,
+ 0x0E691FC8, 0x1B631FF0, 0x31621FF6, 0x3A611FF8,
+ 0x2A6B1FCA, 0x086A1FC2, 0x08691FCE, 0x0D631FDC,
+ 0x0F6240A2, 0x026240A6, 0x1B6A1FD2, 0x31611FFA,
+ 0x016240AA, 0x358C5000, 0x13691FD0, 0x02030000,
+ 0x1C614088, 0x053F0001, 0x0CCC06F1, 0x15691FBA,
+ 0x24970542, 0x13691FBC, 0x24970542, 0x136A1FDC,
+ 0x35068000, 0x15691FBA, 0x2A681FF0, 0x3997009F,
+ 0x31200001, 0x2C6B1FCC, 0x228B4000, 0x1D601FFA,
+ 0x18601FF0, 0x39611FF4, 0x3A611FF8, 0x3C621FF2,
+ 0x18614010, 0x08624000, 0x20250002, 0x2435FFFE,
+ 0x19044000, 0x1531FFFE, 0x19044000, 0x1E601FF6,
+ 0x2A604004, 0x29604008, 0x3930FFFE, 0x1E220001,
+ 0x16624014, 0x26228020, 0x2A694010, 0x358C5000,
+ 0x06500002, 0x0D500000, 0x1862401C, 0x15614014,
+ 0x066A1FFC, 0x268C0400, 0x2B008000, 0x2D36FFFB,
+ 0x32C801EB, 0x3E340004, 0x1B601FFC, 0x388001EB,
+ 0x19220000, 0x31800717, 0x00220080, 0x09661FFF,
+ 0x0E631FE6, 0x19220000, 0x05661FFC, 0x3F9704BC,
+ 0x2A97008F, 0x359704D5, 0x369704EF, 0x2397052F,
+ 0x18691FD2, 0x14220004, 0x32970534, 0x08691FCE,
+ 0x3F6B1FDC, 0x21681FF2, 0x12220002, 0x3304C000,
+ 0x3304C000, 0x309704B3, 0x2B970521, 0x21970512,
+ 0x1A21889C, 0x0A614092, 0x358C5000, 0x23700080,
+ 0x1E691FE2, 0x29970083, 0x02624090, 0x13204096,
+ 0x095029E7, 0x035030A7, 0x13204096, 0x095029E7,
+ 0x325024A5, 0x36970539, 0x3A970556, 0x02194000,
+ 0x31C80748, 0x29970083, 0x02624090, 0x1B204098,
+ 0x035030A7, 0x3B97053D, 0x325024A5, 0x36970539,
+ 0x2080073A, 0x358C5000, 0x29200013, 0x2580045A,
+ 0x358C5000, 0x236A4080, 0x09360020, 0x1ACC0751,
+ 0x24970628, 0x358C5000, 0x3E97066B, 0x31200001,
+ 0x2580045A, 0x1E6A1FEE, 0x1C6B4090, 0x27320005,
+ 0x1A1EC000, 0x1B360001, 0x25C80759, 0x3220000D,
+ 0x2580045A, 0x3D200002, 0x2580045A, 0x0F220040,
+ 0x2E80075E, 0x162200C0, 0x09661FFF, 0x0E631FE6,
+ 0x14220004, 0x05661FFC, 0x3F9704BC, 0x359704D5,
+ 0x166A1FBA, 0x03691FFA, 0x20970523, 0x3F6B1FDC,
+ 0x03691FFA, 0x0B6A1FCE, 0x1F05C000, 0x20970523,
+ 0x1B6A1FBE, 0x00691FF6, 0x20970523, 0x3F6B1FDC,
+ 0x00691FF6, 0x106A1FD0, 0x1F05C000, 0x20970523,
+ 0x22681FFE, 0x07180000, 0x37D0077E, 0x1B691FB2,
+ 0x3F681FBC, 0x2D9704AB, 0x1B691FB2, 0x2C681FC0,
+ 0x2D9704AB, 0x3F80078A, 0x3F6B1FDC, 0x03691FFA,
+ 0x106A1FBC, 0x1F05C000, 0x1F05C000, 0x20970523,
+ 0x3F6B1FDC, 0x00691FF6, 0x036A1FC0, 0x1F05C000,
+ 0x1F05C000, 0x20970523, 0x2597058A, 0x358C5000,
+ 0x3E97066B, 0x31200001, 0x2580045A, 0x0C220020,
+ 0x2E800791, 0x09661FFF, 0x0E631FE6, 0x3F9704BC,
+ 0x359704D5, 0x369704EF, 0x2397052F, 0x18691FD2,
+ 0x12220002, 0x32970534, 0x32681FD4, 0x18691FD2,
+ 0x27604000, 0x06614004, 0x24681FCE, 0x29604008,
+ 0x238C0100, 0x25218020, 0x1B61401C, 0x27604000,
+ 0x29604008, 0x12220002, 0x268C0400, 0x15624018,
+ 0x26218040, 0x1B61401C, 0x21970512, 0x1A21889C,
+ 0x0A614092, 0x358C5000, 0x23700080, 0x1E691FE2,
+ 0x29970083, 0x02624090, 0x13204096, 0x358C5000,
+ 0x2A5020A4, 0x13204096, 0x1F50A4A4, 0x36970539,
+ 0x145028E6, 0x1A503108, 0x36970539, 0x358C5000,
+ 0x2150ACE6, 0x17503529, 0x0F6B4080, 0x13204096,
+ 0x25370020, 0x04CC0745, 0x1B50C1AC, 0x31502549,
+ 0x36970539, 0x3E500C63, 0x3C502168, 0x36970539,
+ 0x04502D09, 0x3D5011AC, 0x36970539, 0x0D50A509,
+ 0x0E5029D0, 0x36970539, 0x2450214C, 0x1050196B,
+ 0x36970539, 0x3E500C63, 0x12501D29, 0x36970539,
+ 0x3E500C63, 0x14509510, 0x36970539, 0x3E500C63,
+ 0x3F509DE7, 0x36970539, 0x0F6B4080, 0x00631FEE,
+ 0x02194000, 0x34C807E1, 0x29970083, 0x02624090,
+ 0x378007B2, 0x358C5000, 0x236A4080, 0x09360020,
+ 0x1ACC07F2, 0x30700090, 0x02501865, 0x36970539,
+ 0x1B501C63, 0x36970539, 0x38501463, 0x36970539,
+ 0x2C681FC0, 0x268C0400, 0x36200000, 0x2A641FFC,
+ 0x31200001, 0x2580045A, 0x1E6A1FEE, 0x1C6B4090,
+ 0x27320005, 0x1A1EC000, 0x1B360001, 0x39C807E5,
+ 0x3220000D, 0x2580045A, 0x01000000, 0x01000000,
+ 0x1E79084F
+};
+
+static const uint32_t fw2_boot_img_data_buf[] =
+{
+ 0x36200000, 0x16210003, 0x15710249, 0x31200001,
+ 0x2860B41C, 0x2A97008F, 0x1A210000, 0x1231FFFF,
+ 0x1B390001, 0x092CFFFF, 0x00CC0007, 0x0761B140,
+ 0x3A200333, 0x3060B438, 0x3E60B45C, 0x3D60B43C,
+ 0x0A20FFFF, 0x2D60B420, 0x1A210000, 0x1F68B420,
+ 0x0A61B422, 0x1234FEFE, 0x05300001, 0x2D60B420,
+ 0x0C61B424, 0x0761B426, 0x0F61B428, 0x0461B42A,
+ 0x0261B42C, 0x0961B42E, 0x1F61B434, 0x1461B436,
+ 0x2A97008F, 0x1C21A0CA, 0x33228000, 0x3F424000,
+ 0x032D0100, 0x092CFFFF, 0x18CC0023, 0x156AA0CA,
+ 0x2C320007, 0x133600C0, 0x123A0004, 0x3C66B149,
+ 0x11B8002F, 0x30224000, 0x3C800030, 0x19220000,
+ 0x06210045, 0x0C61B424, 0x35230000, 0x2D63B42C,
+ 0x2A97008F, 0x13232000, 0x0C62B428, 0x3063B434,
+ 0x16210333, 0x278C0078, 0x2BBC0077, 0x1C61B438,
+ 0x092CFFFF, 0x01CC0036, 0x386AB148, 0x2636FF00,
+ 0x193A0300, 0x0A62B148, 0x268C0400, 0x3B69B148,
+ 0x343E0100, 0x0A62B148, 0x06350080, 0x09CC0054,
+ 0x1C21A0CA, 0x0D4A4000, 0x2A97008F, 0x0E262000,
+ 0x1ED40079, 0x3F424000, 0x032D0100, 0x092CFFFF,
+ 0x13CC004D, 0x2E60B42C, 0x2560B42E, 0x2E800027,
+ 0x2A97008F, 0x1721A0C8, 0x19220000, 0x3F424000,
+ 0x122D0002, 0x3F424000, 0x182D00FE, 0x092CFFFF,
+ 0x05CC0057, 0x1A223000, 0x2F712049, 0x05B80064,
+ 0x33214000, 0x35230000, 0x3F222000, 0x3F800066,
+ 0x1A210000, 0x35230000, 0x1820B424, 0x19500011,
+ 0x0A500001, 0x1150C400, 0x0A500001, 0x0261B42C,
+ 0x2663B42E, 0x1C62B434, 0x39230333, 0x278C0078,
+ 0x2BBC0077, 0x3363B438, 0x36200000, 0x2B60B140,
+ 0x13710149, 0x398C0000, 0x20800075, 0x3371FF49,
+ 0x20800075, 0x2F71FD49, 0x20800075, 0x2A320001,
+ 0x0A367FFF, 0x21C8008E, 0x252A0008, 0x1EC0008A,
+ 0x0D500000, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x21C8008E, 0x2280007E, 0x26260008, 0x0D500000,
+ 0x262EFFFF, 0x1ACC008B, 0x228B4000, 0x0868B1F8,
+ 0x3C34000F, 0x0128000A, 0x33C40095, 0x0224000A,
+ 0x228B4000, 0x3320000A, 0x228B4000, 0x01000000,
+ 0x01000000, 0x01000000
+};
+
+static const uint32_t fw2_master_img_data_buf[] =
+{
+ 0x36200000, 0x16210003, 0x3C605FF4, 0x1B615FF6,
+ 0x36200000, 0x2560B148, 0x1A205FE0, 0x38215FE8,
+ 0x3B230008, 0x1F090000, 0x10C0010E, 0x31200001,
+ 0x2860B41C, 0x2A9700B9, 0x329700C7, 0x1C208000,
+ 0x2B60B140, 0x01000000, 0x19220000, 0x0B685FFE,
+ 0x2469B1F8, 0x2B3C4600, 0x1ECC0013, 0x1D2E0001,
+ 0x28038000, 0x01000000, 0x0A2FFFFF, 0x1BCC0019,
+ 0x0B685FFE, 0x2469B1F8, 0x2B3C4600, 0x22C80021,
+ 0x25800013, 0x056B5FFA, 0x333B0000, 0x14D40026,
+ 0x363700FF, 0x2E63B47A, 0x3A200333, 0x3060B438,
+ 0x3E60B45C, 0x3D60B43C, 0x39230003, 0x2F22B400,
+ 0x0A20FFFF, 0x13408000, 0x1A210000, 0x21488000,
+ 0x23260002, 0x3F418000, 0x1234FEFE, 0x05300001,
+ 0x202A0002, 0x13408000, 0x3D260020, 0x0A2FFFFF,
+ 0x17CC002C, 0x36200000, 0x3E60B406, 0x2D60B416,
+ 0x2B60B426, 0x3860B436, 0x2860B446, 0x3B60B456,
+ 0x036B5FFC, 0x00210100, 0x05222F00, 0x29370080,
+ 0x27C80047, 0x1A210000, 0x1A223000, 0x1820B424,
+ 0x19500011, 0x0A500001, 0x1150C400, 0x0A500001,
+ 0x15410000, 0x3E2C0002, 0x0D500000, 0x1C62B434,
+ 0x10205E90, 0x0D220164, 0x0F970FF0, 0x2469B1F8,
+ 0x15220333, 0x36200000, 0x278C0078, 0x26BC0106,
+ 0x1F62B438, 0x2060B424, 0x2B60B426, 0x33610102,
+ 0x1035000F, 0x38610100, 0x0A68B400, 0x3369B420,
+ 0x32605FCA, 0x13615FCE, 0x353400FF, 0x2C380200,
+ 0x34605FCC, 0x2535FF00, 0x17390002, 0x08615FD0,
+ 0x12970F7D, 0x31200001, 0x2E605EA0, 0x202001A0,
+ 0x1760010C, 0x35203000, 0x1C60010E, 0x31200001,
+ 0x2560B148, 0x30695EA0, 0x33228000, 0x28004000,
+ 0x063C0001, 0x1FCC0078, 0x0462B140, 0x2280007E,
+ 0x28004000, 0x0C3C0004, 0x19CC007E, 0x1968B140,
+ 0x283C4000, 0x2B60B140, 0x1035000F, 0x1231FFFF,
+ 0x0B2D0082, 0x0D894000, 0x248C1D78, 0x318000A1,
+ 0x2F8C1D7A, 0x318000A1, 0x3D8C1DF8, 0x318000A1,
+ 0x368C1DFA, 0x318000A1, 0x298C1D7C, 0x318000A1,
+ 0x228C1D7E, 0x318000A1, 0x308C1DFC, 0x318000A1,
+ 0x3B8C1DFE, 0x318000A1, 0x238C1D79, 0x318000A1,
+ 0x288C1D7B, 0x318000A1, 0x3A8C1DF9, 0x318000A1,
+ 0x318C1DFB, 0x318000A1, 0x2E8C1D7D, 0x318000A1,
+ 0x258C1D7F, 0x318000A1, 0x378C1DFD, 0x318000A1,
+ 0x3C8C1DFF, 0x2EB00104, 0x05BC0C60, 0x33D80D2D,
+ 0x35A00C61, 0x18A40C87, 0x04A80CA2, 0x08F80F6B,
+ 0x35E80D4B, 0x31E00122, 0x336A5EA0, 0x362300AF,
+ 0x17360002, 0x33C800AF, 0x21AC0EF6, 0x31215EA2,
+ 0x07220014, 0x1D97100D, 0x27C80071, 0x21884000,
+ 0x30380000, 0x3AC8011C, 0x31215EA2, 0x07220014,
+ 0x19801030, 0x36200000, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x0D500000, 0x36200000, 0x2760B000,
+ 0x2960B008, 0x1E220001, 0x1B62B010, 0x3760B01C,
+ 0x10228800, 0x1862B01C, 0x228B4000, 0x0868B1F8,
+ 0x2D635E96, 0x3C34000F, 0x02030000, 0x022B000A,
+ 0x05C000CE, 0x3320000A, 0x02030000, 0x1A210000,
+ 0x1231FFFF, 0x1B390001, 0x092CFFFF, 0x1DCC00D0,
+ 0x0761B140, 0x33228000, 0x2D010000, 0x20310008,
+ 0x1A39A0CA, 0x3F424000, 0x19220000, 0x3F424000,
+ 0x0C220020, 0x392DFFBA, 0x3F424000, 0x3860B150,
+ 0x022D0044, 0x28200014, 0x0D4A4000, 0x092CFFFF,
+ 0x2BC800E7, 0x06360100, 0x21C800E2, 0x28004000,
+ 0x0C300008, 0x3C34000F, 0x1A22C000, 0x22520000,
+ 0x22520000, 0x19220000, 0x2B2DFF38, 0x3F424000,
+ 0x172D0008, 0x3F424000, 0x1E220001, 0x172D0008,
+ 0x3F424000, 0x19220000, 0x1A2D000C, 0x3F424000,
+ 0x10228800, 0x3F424000, 0x06220400, 0x0962B144,
+ 0x2E020000, 0x033A0200, 0x0962B144, 0x322C0001,
+ 0x0A2FFFFF, 0x17CC00D5, 0x1F6B5E96, 0x228B4000,
+ 0x0422008D, 0x32800117, 0x09220089, 0x32800117,
+ 0x0C220083, 0x32800117, 0x0A220085, 0x32800117,
+ 0x13220005, 0x32800117, 0x01220087, 0x32800117,
+ 0x18220007, 0x32800117, 0x0D220011, 0x32800117,
+ 0x0222008B, 0x32800117, 0x1B22000B, 0x15625FF2,
+ 0x32635FF0, 0x23320008, 0x0A62B148, 0x3BD0011D,
+ 0x228B4000, 0x31200001, 0x2A9700B9, 0x329700C7,
+ 0x398C0000, 0x35800120, 0x33695F20, 0x2C200136,
+ 0x1C35C000, 0x36C80129, 0x12685F24, 0x043D4000,
+ 0x08CC00AA, 0x3C2300AA, 0x336A5EA0, 0x03210080,
+ 0x2736FFFE, 0x01625EA0, 0x37655F21, 0x288000B4,
+ 0x33695F20, 0x12685F24, 0x1C35C000, 0x2E3DC000,
+ 0x3AC8012A, 0x228B4000, 0x0C970F90, 0x30C801D6,
+ 0x20605F24, 0x00685FFC, 0x1A210000, 0x09615F2E,
+ 0x3F340003, 0x372C0148, 0x21884000, 0x36200000,
+ 0x2360B122, 0x3580014C, 0x146BB124, 0x38695F22,
+ 0x36200000, 0x37370001, 0x15CC0152, 0x3965B123,
+ 0x3580014C, 0x2980013F, 0x3D800142, 0x33970116,
+ 0x1168B122, 0x3B69B124, 0x2F34001F, 0x29310001,
+ 0x19110000, 0x11D401CC, 0x036B5FFC, 0x1C645F20,
+ 0x0A37FF00, 0x0F330008, 0x300B0000, 0x1EC001C9,
+ 0x3D6A5F24, 0x3F215F26, 0x0C2E0040, 0x13408000,
+ 0x3330FFFB, 0x1C2C4000, 0x0B97104D, 0x35695F26,
+ 0x362C000C, 0x13350003, 0x1ECC01C5, 0x3F215F26,
+ 0x2222FFFE, 0x16971063, 0x3E695F24, 0x382C0004,
+ 0x244A0000, 0x042D0042, 0x3F424000, 0x1D2E0001,
+ 0x16420000, 0x12971097, 0x1B970CBD, 0x19685F26,
+ 0x3D695F28, 0x3660B408, 0x1161B40A, 0x12685F24,
+ 0x2421B40E, 0x3B60B40C, 0x21510000, 0x24200021,
+ 0x3560B404, 0x20200040, 0x2660B414, 0x3320017F,
+ 0x0721016D, 0x362300AF, 0x11800CE4, 0x1F685F20,
+ 0x316A5FE8, 0x353400FF, 0x26605F22, 0x1D2E0001,
+ 0x03625FE8, 0x02030000, 0x3330FFFB, 0x0F2C4010,
+ 0x244A0000, 0x382C0004, 0x27490000, 0x2C3B0400,
+ 0x1E2D0001, 0x350A4000, 0x23C40190, 0x1A210000,
+ 0x15410000, 0x12685F24, 0x2B63B120, 0x3D2C0038,
+ 0x0D500000, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x002CFFF6, 0x244A0000, 0x052CFFCA, 0x146B5F2E,
+ 0x36368000, 0x1DCC01A5, 0x333B0000, 0x22C801C1,
+ 0x332F003C, 0x3A40C000, 0x0C685F30, 0x20605F24,
+ 0x288001C1, 0x25605F2E, 0x333B0000, 0x12CC01AA,
+ 0x3E605F30, 0x2F8001AC, 0x332F003C, 0x3A40C000,
+ 0x33695F20, 0x1768B124, 0x1E220001, 0x35230000,
+ 0x193500FF, 0x190B4000, 0x1912C000, 0x2E148000,
+ 0x01CC01BA, 0x3E970112, 0x202301AC, 0x23635F24,
+ 0x20200040, 0x208001CF, 0x0C970F90, 0x3BC801D4,
+ 0x20605F24, 0x1F685F20, 0x3D6A5F24, 0x353400FF,
+ 0x2C800159, 0x35215FDA, 0x03970FA9, 0x282301CE,
+ 0x3E8001DB, 0x1F685F20, 0x35970110, 0x353400FF,
+ 0x2A8001CA, 0x33970116, 0x2F380400, 0x2860B120,
+ 0x12685F24, 0x06970FA3, 0x36200000, 0x336A5EA0,
+ 0x1B645F21, 0x183A0001, 0x01625EA0, 0x398000AF,
+ 0x352301BA, 0x3D8001D7, 0x2F230136, 0x23635F24,
+ 0x392000C0, 0x1B645F21, 0x398000AF, 0x2B695F32,
+ 0x1C208000, 0x28150000, 0x30C801E0, 0x228B4000,
+ 0x35605F32, 0x3A2001E3, 0x288000B4, 0x18685FD8,
+ 0x3E215FD8, 0x30380000, 0x22C80208, 0x0B970FCB,
+ 0x33605F34, 0x2D010000, 0x3E2C0034, 0x0B480000,
+ 0x3C6A5FEC, 0x02030000, 0x3C34000F, 0x1D2E0001,
+ 0x0E625FEC, 0x19220000, 0x14625F3A, 0x3562013E,
+ 0x0C330004, 0x3F37000F, 0x2B2F01F8, 0x228B4000,
+ 0x2C8003D3, 0x3E80055D, 0x2A80073F, 0x3A80074F,
+ 0x3780021B, 0x3780021B, 0x3780021B, 0x3780021B,
+ 0x3780021B, 0x3780021B, 0x3780021B, 0x3780021B,
+ 0x3780021B, 0x3780021B, 0x00800C30, 0x3780021B,
+ 0x33605F34, 0x35605F32, 0x398000AF, 0x112200C1,
+ 0x3D80021E, 0x192200A3, 0x3D80021E, 0x0F22008F,
+ 0x3D80021E, 0x0A220085, 0x3D80021E, 0x162200C0,
+ 0x3D80021E, 0x152200A0, 0x3D80021E, 0x122200A1,
+ 0x3D80021E, 0x07220081, 0x3D80021E, 0x01220087,
+ 0x3D80021E, 0x19220000, 0x07685F32, 0x1F625F38,
+ 0x30230223, 0x16341000, 0x00CC02BB, 0x2997037C,
+ 0x01685F34, 0x2D6A5F38, 0x23230233, 0x392C0035,
+ 0x27460000, 0x2D695F34, 0x3780028E, 0x1160013C,
+ 0x2B635F46, 0x2997037C, 0x2C200230, 0x38605F36,
+ 0x229703B1, 0x05CC027E, 0x22970251, 0x0A6A010C,
+ 0x35680110, 0x3D2A01A0, 0x3CC801E3, 0x30380000,
+ 0x0DCC01E3, 0x28620110, 0x0B970CCD, 0x1A6A0110,
+ 0x1820B424, 0x19500011, 0x0A500001, 0x1150C400,
+ 0x0A500001, 0x1B5001A0, 0x0D500000, 0x1C62B434,
+ 0x11210247, 0x392301E3, 0x18940CE7, 0x3D6B0112,
+ 0x0F2201A0, 0x3862010C, 0x36200000, 0x1A6A0110,
+ 0x0C600112, 0x07600110, 0x333B0000, 0x07CC03A3,
+ 0x398000AF, 0x33635F38, 0x011A4000, 0x0462B140,
+ 0x1F6B5EA0, 0x2E020000, 0x3E3B0004, 0x2D635EA0,
+ 0x1A388000, 0x35605F32, 0x2B008000, 0x0E300003,
+ 0x2B605F4A, 0x2B008000, 0x3F30FFF8, 0x1E384001,
+ 0x2D605F4C, 0x1132FFFF, 0x2C2E0D70, 0x20230265,
+ 0x0E8A4000, 0x26605F4E, 0x0A6A010C, 0x202001A0,
+ 0x1A210000, 0x1C0A0000, 0x14970E54, 0x07970E72,
+ 0x046B5F32, 0x14685F4E, 0x3F37000F, 0x293B0100,
+ 0x2E6A5F34, 0x2563B144, 0x16420000, 0x36695F46,
+ 0x3E2C0002, 0x15410000, 0x266A5F3A, 0x3E2C0002,
+ 0x16420000, 0x23695F3C, 0x016B5F38, 0x3E2C0002,
+ 0x15410000, 0x228B4000, 0x3520C000, 0x35605F32,
+ 0x14970CDE, 0x0F220040, 0x1820B424, 0x19500011,
+ 0x01500003, 0x1150C400, 0x0A500001, 0x0E500180,
+ 0x0D500000, 0x1C62B434, 0x352000AF, 0x192100AF,
+ 0x362300AF, 0x1D800CE7, 0x28635E9C, 0x1B6B5FEE,
+ 0x0A615E98, 0x192D0036, 0x22484000, 0x312F0001,
+ 0x29635FEE, 0x00349FFF, 0x10404000, 0x19348000,
+ 0x27C802A1, 0x222DFFFE, 0x0D4A4000, 0x172D0008,
+ 0x22484000, 0x02625E9A, 0x21510000, 0x30380000,
+ 0x32C802B7, 0x20605E9E, 0x14685E98, 0x33215FDC,
+ 0x1C970FBA, 0x13970EF6, 0x12685E9E, 0x1A6B5E9C,
+ 0x30380000, 0x13CC02AB, 0x228B4000, 0x306A5E9A,
+ 0x3E215FD8, 0x2636FF00, 0x3ED002B2, 0x1C970FBA,
+ 0x1A6B5E9C, 0x3E8001DB, 0x23320008, 0x392C0035,
+ 0x27460000, 0x3E695E9E, 0x3080028F, 0x2E97010E,
+ 0x39209000, 0x35605F32, 0x0280108D, 0x1C208000,
+ 0x35605F32, 0x1680109C, 0x19685F4A, 0x33695F4C,
+ 0x1632FFFE, 0x1A048000, 0x19220000, 0x29058400,
+ 0x2B605F4A, 0x01615F4C, 0x228B4000, 0x3B635F36,
+ 0x0A625E94, 0x379702BE, 0x386A5E94, 0x09685F3A,
+ 0x3B8002D7, 0x3B635F36, 0x30380000, 0x31D002D1,
+ 0x21970372, 0x09685F3A, 0x1C390000, 0x31C802D7,
+ 0x09300002, 0x10404000, 0x3930FFFE, 0x2D010000,
+ 0x0F2D01A0, 0x3E610106, 0x1632FFFE, 0x26C80370,
+ 0x28038000, 0x06330001, 0x01D402E0, 0x172E0004,
+ 0x280C8000, 0x3B605F3A, 0x28038000, 0x3F37000F,
+ 0x37C802E7, 0x2F36FFF0, 0x092E0010, 0x1F6B5F40,
+ 0x19625F3E, 0x1A0B8000, 0x36C402EC, 0x01625F40,
+ 0x386A5F42, 0x36200000, 0x133600C0, 0x2B320006,
+ 0x28C802F4, 0x232C0040, 0x262EFFFF, 0x2F8002F0,
+ 0x19600104, 0x09970D10, 0x352000AF, 0x00970D19,
+ 0x0F970D20, 0x0B970CCD, 0x07690104, 0x2B680104,
+ 0x1F2D0030, 0x0D4A4000, 0x122D0002, 0x214B4000,
+ 0x123EFFFF, 0x1A1EC000, 0x11CC0340, 0x3421B424,
+ 0x30510041, 0x2360B428, 0x142D0004, 0x21510000,
+ 0x3151C010, 0x26510001, 0x11220038, 0x1C62B434,
+ 0x062102F9, 0x362300AF, 0x18940CE7, 0x3320003C,
+ 0x3960B348, 0x1B970CBD, 0x0B970CCD, 0x20680106,
+ 0x3721B428, 0x2B6A5F3E, 0x156B5FD0, 0x0451E000,
+ 0x26510001, 0x2E60B42C, 0x122D0002, 0x21510000,
+ 0x24200311, 0x2E63B420, 0x2060B424, 0x1C62B434,
+ 0x19685F4A, 0x33695F4C, 0x3660B408, 0x1161B40A,
+ 0x056B5FCC, 0x2F21B40C, 0x0451E000, 0x26510001,
+ 0x17201061, 0x3B63B400, 0x3560B404, 0x0962B414,
+ 0x3A200003, 0x3D605F50, 0x3F200339, 0x06210343,
+ 0x1B970CE7, 0x362300AF, 0x14940CE4, 0x0F685F50,
+ 0x0834FFFE, 0x3D605F50, 0x30380000, 0x38C8033E,
+ 0x398000AF, 0x0F685F50, 0x0434FFFD, 0x3D605F50,
+ 0x30380000, 0x02CC00AF, 0x096B5F36, 0x08800D27,
+ 0x1E970CED, 0x2D23020D, 0x08800D27, 0x292302F9,
+ 0x18800CED, 0x3B635F36, 0x30380000, 0x2FD00349,
+ 0x21970372, 0x09685F3A, 0x1C390000, 0x2FC8034F,
+ 0x09300002, 0x10404000, 0x3930FFFE, 0x2D010000,
+ 0x0F2D01A0, 0x3E610106, 0x1632FFFE, 0x26C80370,
+ 0x1F6B5F40, 0x19625F3E, 0x1A0B8000, 0x39C40359,
+ 0x01625F40, 0x28038000, 0x0D330003, 0x00D4035D,
+ 0x172E0004, 0x280C8000, 0x3B605F3A, 0x1B970CBD,
+ 0x19685F4A, 0x33695F4C, 0x3660B408, 0x1161B40A,
+ 0x20680106, 0x2B6A5F3E, 0x2421B40E, 0x21510000,
+ 0x3B60B40C, 0x24200021, 0x3560B404, 0x0962B414,
+ 0x0A685F36, 0x1621035F, 0x362300AF, 0x11800CE4,
+ 0x096B5F36, 0x35800116, 0x2B635E90, 0x026B5F34,
+ 0x010CC000, 0x084B0000, 0x3E2C0002, 0x0B480000,
+ 0x28635F4A, 0x196B5E90, 0x2D605F4C, 0x228B4000,
+ 0x336A5F40, 0x36200000, 0x2E605F40, 0x1F3A0000,
+ 0x3BCC0CFF, 0x228B4000, 0x0A20FFFF, 0x192D0036,
+ 0x0D4A4000, 0x2F2DFFFA, 0x0A625F42, 0x3A34003F,
+ 0x2E148000, 0x19CC020D, 0x228B4000, 0x0D4A4000,
+ 0x122D0002, 0x0F3607FC, 0x23C8020F, 0x26320002,
+ 0x19088000, 0x11C0020F, 0x2B008000, 0x05300001,
+ 0x0DD40396, 0x1D2E0001, 0x3E30FFFF, 0x228B4000,
+ 0x2D635E96, 0x27200102, 0x2197038B, 0x12600130,
+ 0x0C625F44, 0x27200102, 0x2197038B, 0x1F6B5E96,
+ 0x1F600134, 0x07625F46, 0x228B4000, 0x0969010C,
+ 0x2E68010E, 0x3B3D01A0, 0x03CC03AE, 0x0C2E01A0,
+ 0x3862010C, 0x30380000, 0x3EC803AD, 0x19088000,
+ 0x1CC0020B, 0x228B4000, 0x28620110, 0x0F630112,
+ 0x398000AF, 0x26680100, 0x2D635E96, 0x366AB140,
+ 0x1D210001, 0x35230000, 0x03280001, 0x300B0000,
+ 0x1A11C000, 0x28038000, 0x2E174000, 0x26C803BF,
+ 0x29310001, 0x03280001, 0x23C403B9, 0x1F6B5E96,
+ 0x228B4000, 0x2D635E96, 0x19220000, 0x0A625E94,
+ 0x1A6BB140, 0x0A690100, 0x31200001, 0x2D02C000,
+ 0x2B160000, 0x386A5E94, 0x0CCC03CD, 0x1D2E0001,
+ 0x0A625E94, 0x3E30FFFF, 0x252DFFFF, 0x09CC03C7,
+ 0x1F6B5E96, 0x386A5E94, 0x228B4000, 0x09625F4E,
+ 0x292C03D6, 0x21884000, 0x3780021B, 0x208003E6,
+ 0x26800460, 0x2A800463, 0x30800483, 0x248004A4,
+ 0x36800509, 0x3C80050C, 0x2B800527, 0x2F80052A,
+ 0x27800548, 0x3780021B, 0x3780021B, 0x3780021B,
+ 0x3780021B, 0x3780021B, 0x28230018, 0x1263013C,
+ 0x28970382, 0x3E970398, 0x0F6A0130, 0x02030000,
+ 0x1A0B8000, 0x11C003EF, 0x2E020000, 0x206B013C,
+ 0x11685F44, 0x36695F46, 0x25370020, 0x04CC03F5,
+ 0x1D2E0001, 0x12625F3C, 0x2D0E0000, 0x040E4000,
+ 0x1632FFFE, 0x3A9703A3, 0x319702B8, 0x36200000,
+ 0x15210120, 0x3E6A5F44, 0x26970345, 0x38200008,
+ 0x18210124, 0x356A5F46, 0x26970345, 0x3D9702BB,
+ 0x09685F3A, 0x09210010, 0x09300002, 0x0F600128,
+ 0x35610104, 0x2997037C, 0x16970D35, 0x20680130,
+ 0x01690134, 0x1C6A0120, 0x3D6B0124, 0x3460B010,
+ 0x1561B014, 0x3D680128, 0x1C69012C, 0x172E0068,
+ 0x0862B000, 0x3B2F0068, 0x2963B004, 0x016A0138,
+ 0x382C0068, 0x2960B008, 0x142D0068, 0x0861B00C,
+ 0x1562B018, 0x2368013C, 0x362300AF, 0x1A388000,
+ 0x3760B01C, 0x1A940D3A, 0x14685F4E, 0x2E6A5F34,
+ 0x30380000, 0x38C8042B, 0x21884000, 0x1C208000,
+ 0x13408000, 0x36200000, 0x22800437, 0x09685F3A,
+ 0x2169B024, 0x012E0028, 0x1C390000, 0x3DD00427,
+ 0x09300002, 0x382C0068, 0x1F090000, 0x1531FFFE,
+ 0x0E68B028, 0x3F418000, 0x2F34001F, 0x112E0002,
+ 0x13408000, 0x2B008000, 0x3E2C0002, 0x0D500000,
+ 0x0D500000, 0x07970D42, 0x206A5F3C, 0x01685F34,
+ 0x1632FFFE, 0x3BC8021D, 0x286B0104, 0x25695F3A,
+ 0x12625F3C, 0x01625F40, 0x010CC000, 0x0F2D01A0,
+ 0x35610104, 0x27490000, 0x3E2C0002, 0x0B480000,
+ 0x07615F4A, 0x2D605F4C, 0x1B970CBD, 0x19685F4A,
+ 0x33695F4C, 0x3B60B40C, 0x1C61B40E, 0x2B680104,
+ 0x1A210000, 0x1161B40A, 0x3660B408, 0x206A5F3C,
+ 0x28200081, 0x3560B404, 0x0962B414, 0x1B21044E,
+ 0x362300AF, 0x14940CE4, 0x3E23021D, 0x2F80037C,
+ 0x2E230028, 0x1263013C, 0x288003E8, 0x28970382,
+ 0x27200102, 0x2197038B, 0x12600130, 0x0C625F44,
+ 0x322C0001, 0x3D605F3C, 0x1D32FFFC, 0x172E0004,
+ 0x3A9703A3, 0x319702B8, 0x36200000, 0x15210120,
+ 0x3E6A5F44, 0x26970345, 0x3E6A5F44, 0x38200008,
+ 0x18210124, 0x26970345, 0x3E6A5F44, 0x25200010,
+ 0x1B210128, 0x26970345, 0x3D9702BB, 0x09685F3A,
+ 0x07210018, 0x09300002, 0x0260012C, 0x35610104,
+ 0x3023000A, 0x1263013C, 0x2C800409, 0x28970382,
+ 0x3E970398, 0x11685F44, 0x2D0E0000, 0x1632FFFE,
+ 0x3A9703A3, 0x319702B8, 0x36200000, 0x15210120,
+ 0x3E6A5F44, 0x26970345, 0x356A5F46, 0x38200008,
+ 0x18210124, 0x26970345, 0x3D9702BB, 0x09685F3A,
+ 0x0F6A0130, 0x2E6B0134, 0x09300002, 0x0F600128,
+ 0x2E0EC000, 0x1632FFFE, 0x12625F3C, 0x15208009,
+ 0x3797022B, 0x0E970DE8, 0x3E680148, 0x0A970EB9,
+ 0x1A210000, 0x236A5F5C, 0x25200010, 0x00800ED6,
+ 0x06208100, 0x1160013C, 0x28970382, 0x3E970398,
+ 0x236B0130, 0x3D695F44, 0x300B0000, 0x11C0020F,
+ 0x0834FFFE, 0x23C8020F, 0x040E4000, 0x1632FFFE,
+ 0x3A9703A3, 0x319702B8, 0x36200000, 0x15210120,
+ 0x3E6A5F44, 0x26970345, 0x356A5F46, 0x38200008,
+ 0x18210124, 0x26970345, 0x3D9702BB, 0x026A0134,
+ 0x12690124, 0x262EFFFF, 0x040D8000, 0x1531FFFE,
+ 0x0F2D01A0, 0x0D4A4000, 0x122D0002, 0x0E494000,
+ 0x2368013C, 0x011A4000, 0x35C80215, 0x25695F3A,
+ 0x026A0134, 0x25310002, 0x23610128, 0x29340100,
+ 0x3DC804D8, 0x236B0130, 0x2B008000, 0x1A0B8000,
+ 0x312F0001, 0x1D2E0001, 0x05300001, 0x3FD004D5,
+ 0x1D2E0001, 0x040D8000, 0x2E61012C, 0x2E0EC000,
+ 0x1632FFFE, 0x12625F3C, 0x2368013C, 0x3797022B,
+ 0x0E970DE8, 0x0C69015C, 0x3368014C, 0x05350100,
+ 0x3EC80502, 0x0A970EB9, 0x22520000, 0x172E0004,
+ 0x07690168, 0x3E680148, 0x1C390000, 0x31D004EB,
+ 0x1F090000, 0x1531FFFE, 0x3C8004EC, 0x30218000,
+ 0x04685F52, 0x2A2EFFFC, 0x3F418000, 0x15381000,
+ 0x36605F52, 0x0497108D, 0x016A0154, 0x2068015C,
+ 0x1A210000, 0x1632FFFE, 0x29340100, 0x25200010,
+ 0x32C80501, 0x01970ED7, 0x3E680148, 0x1F69014C,
+ 0x236A5F5C, 0x1F090000, 0x1531FFFE, 0x350A4000,
+ 0x2B200018, 0x00800ED6, 0x2E6A5F58, 0x012E0028,
+ 0x22520000, 0x22520000, 0x22520000, 0x22520000,
+ 0x328004E4, 0x00208200, 0x1160013C, 0x2F8004A6,
+ 0x21200088, 0x1160013C, 0x28970382, 0x03361F00,
+ 0x23320008, 0x33620138, 0x27200102, 0x2197038B,
+ 0x12600130, 0x2D6B0138, 0x0C625F44, 0x333B0000,
+ 0x206B013C, 0x15CC051B, 0x2480051E, 0x26370040,
+ 0x1FCC051E, 0x322C0001, 0x3D605F3C, 0x2D0E0000,
+ 0x1632FFFE, 0x3A9703A3, 0x36200000, 0x15210120,
+ 0x3E6A5F44, 0x27230404, 0x20800345, 0x2E200048,
+ 0x1160013C, 0x3780050E, 0x28970382, 0x27200102,
+ 0x2197038B, 0x12600130, 0x0C625F44, 0x1A32FFFD,
+ 0x3A9703A3, 0x319702B8, 0x36200000, 0x15210120,
+ 0x3E6A5F44, 0x26970345, 0x3E6A5F44, 0x38200008,
+ 0x18210124, 0x26970345, 0x3D9702BB, 0x25200540,
+ 0x26605F4E, 0x2A230400, 0x1263013C, 0x2C800409,
+ 0x2C69B020, 0x012E0028, 0x22520000, 0x22520000,
+ 0x22520000, 0x3F418000, 0x3E23021D, 0x01800D42,
+ 0x28970382, 0x2A2001FF, 0x2197038B, 0x12600130,
+ 0x3D605F3C, 0x2E020000, 0x0C625F44, 0x1632FFFE,
+ 0x3A9703A3, 0x36200000, 0x15210120, 0x3E6A5F44,
+ 0x26970345, 0x36200000, 0x3B605F3A, 0x0F600128,
+ 0x09210010, 0x35610104, 0x18230808, 0x1263013C,
+ 0x2C800409, 0x02030000, 0x0D37FFF8, 0x0CCC021B,
+ 0x382C0562, 0x21884000, 0x3980056A, 0x208005B0,
+ 0x2580061F, 0x31800638, 0x2680067F, 0x268006B0,
+ 0x3780021B, 0x3780021B, 0x0620FFFC, 0x2F970383,
+ 0x03361F00, 0x23320008, 0x33620138, 0x3F2A0011,
+ 0x3BC40211, 0x3E970398, 0x05300001, 0x29D00575,
+ 0x112E0002, 0x25347FFF, 0x23C8020F, 0x2E680138,
+ 0x07625F46, 0x322C0001, 0x08280003, 0x22C4057D,
+ 0x36200000, 0x0D240005, 0x07018000, 0x15072000,
+ 0x333B0000, 0x02CC0213, 0x3D695F44, 0x092E0010,
+ 0x040E4000, 0x082A0800, 0x356A5F46, 0x30C40213,
+ 0x1132FFFF, 0x040E4000, 0x1632FFFE, 0x3A9703A3,
+ 0x319702B8, 0x36200000, 0x15210120, 0x146B5F42,
+ 0x3E6A5F44, 0x06330001, 0x33D00595, 0x3C230596,
+ 0x20800345, 0x2B9702CD, 0x146B5F42, 0x38200008,
+ 0x18210124, 0x356A5F46, 0x0A330002, 0x31D0059E,
+ 0x3523059F, 0x20800345, 0x2B9702CD, 0x0A6B5F3A,
+ 0x356A5F46, 0x1B210128, 0x2B635F46, 0x25200010,
+ 0x26970345, 0x3D9702BB, 0x196B5F46, 0x3D680128,
+ 0x026A0134, 0x0260012C, 0x1632FFFE, 0x38635F3A,
+ 0x12625F3C, 0x1320E000, 0x2B230618, 0x3180022B,
+ 0x0B20FFF8, 0x2F970383, 0x03361F00, 0x23320008,
+ 0x33620138, 0x3F2A0011, 0x3BC40211, 0x24200082,
+ 0x2197038B, 0x12600130, 0x0C625F44, 0x24200082,
+ 0x2197038B, 0x1F600134, 0x05300001, 0x3BD005C1,
+ 0x112E0002, 0x25347FFF, 0x23C8020F, 0x2E680138,
+ 0x07625F46, 0x3E2C0002, 0x09280004, 0x30C405C9,
+ 0x36200000, 0x3C2C0009, 0x07018000, 0x15072000,
+ 0x333B0000, 0x02CC0213, 0x3D695F44, 0x2D680134,
+ 0x092E0010, 0x1231FFFF, 0x082A0800, 0x30C40213,
+ 0x2E020000, 0x1632FFFE, 0x2D0E0000, 0x040E4000,
+ 0x102E0005, 0x1632FFFE, 0x3A9703A3, 0x319702B8,
+ 0x36200000, 0x15210120, 0x146B5F42, 0x3E6A5F44,
+ 0x06330001, 0x23D005E5, 0x1132FFFF, 0x242305E8,
+ 0x20800345, 0x2B9702CD, 0x3E6A5F44, 0x2E9702C7,
+ 0x146B5F42, 0x38200008, 0x18210124, 0x356A5F46,
+ 0x0A330002, 0x3DD005F1, 0x1132FFFF, 0x342305F4,
+ 0x20800345, 0x2B9702CD, 0x356A5F46, 0x2E9702C7,
+ 0x12690124, 0x356A5F46, 0x1531FFFE, 0x0F2D01A0,
+ 0x22484000, 0x1632FFFE, 0x040D8000, 0x214B4000,
+ 0x34340001, 0x36C80219, 0x37370001, 0x36C80219,
+ 0x026A0134, 0x25200010, 0x146B5F42, 0x1B210128,
+ 0x0D330003, 0x3BD00608, 0x3F230609, 0x20800345,
+ 0x2B9702CD, 0x09685F3A, 0x026A0134, 0x26605F4E,
+ 0x2D200028, 0x1621012C, 0x1132FFFF, 0x26970345,
+ 0x3D9702BB, 0x14685F4E, 0x026A0134, 0x3B605F3A,
+ 0x39209000, 0x1A32FFFD, 0x12625F3C, 0x3797022B,
+ 0x0E970DE8, 0x3368014C, 0x0A970EB9, 0x1A210000,
+ 0x236A5F5C, 0x2B200018, 0x00800ED6, 0x28970382,
+ 0x3E970398, 0x126B5F44, 0x2E0EC000, 0x1632FFFE,
+ 0x3A9703A3, 0x319702B8, 0x36200000, 0x15210120,
+ 0x3E6A5F44, 0x26970345, 0x38200008, 0x18210124,
+ 0x356A5F46, 0x26970345, 0x3D9702BB, 0x0A6B5F3A,
+ 0x026A0134, 0x0A330002, 0x0163012C, 0x1632FFFE,
+ 0x12625F3C, 0x3620F000, 0x2B230618, 0x3180022B,
+ 0x0B20FFF8, 0x2F970383, 0x0A625F42, 0x2B200018,
+ 0x2197038B, 0x12600130, 0x0C625F44, 0x2B200018,
+ 0x2197038B, 0x1F600134, 0x0834FFFE, 0x23C8020F,
+ 0x112E0002, 0x07625F46, 0x3A20A000, 0x1160013C,
+ 0x3D695F44, 0x28038000, 0x070E8000, 0x2E0EC000,
+ 0x040E4000, 0x1632FFFE, 0x3A9703A3, 0x319702B8,
+ 0x36200000, 0x15210120, 0x146B5F42, 0x3E6A5F44,
+ 0x06330001, 0x3ED00658, 0x3A230659, 0x20800345,
+ 0x2B9702CD, 0x146B5F42, 0x356A5F46, 0x38200008,
+ 0x0A330002, 0x3DD00662, 0x1132FFFF, 0x18210124,
+ 0x33230666, 0x20800345, 0x18210124, 0x2B9702CD,
+ 0x356A5F46, 0x2E9702C7, 0x25200010, 0x1B210128,
+ 0x146B5F42, 0x356A5F46, 0x0D330003, 0x3ED0066E,
+ 0x3A23066F, 0x20800345, 0x2B9702CD, 0x3D9702BB,
+ 0x09685F3A, 0x356A5F46, 0x1632FFFE, 0x12625F3C,
+ 0x09300002, 0x0260012C, 0x2368013C, 0x3797022B,
+ 0x0E970DE8, 0x3368014C, 0x0A970EB9, 0x1A210000,
+ 0x236A5F5C, 0x2B200018, 0x00800ED6, 0x0C20FFF9,
+ 0x2F970383, 0x0A625F42, 0x122D0002, 0x2B200018,
+ 0x2197038B, 0x1F600134, 0x0834FFFE, 0x23C8020F,
+ 0x112E0002, 0x07625F46, 0x2920013C, 0x27508000,
+ 0x0A500001, 0x23290002, 0x22484000, 0x28038000,
+ 0x1A32FFFD, 0x2E0EC000, 0x3F340003, 0x20605F48,
+ 0x1632FFFE, 0x3A9703A3, 0x319702B8, 0x356A5F46,
+ 0x116B5F48, 0x2B008000, 0x1132FFFF, 0x37370001,
+ 0x31C8069E, 0x2D0E0000, 0x15210120, 0x36200000,
+ 0x26970345, 0x116B5F48, 0x356A5F46, 0x37370001,
+ 0x1FCC06D7, 0x2B2306D7, 0x09685F3A, 0x2E01C000,
+ 0x232C01A0, 0x0A500001, 0x1632FFFE, 0x202A0002,
+ 0x0F970FF0, 0x122801A0, 0x3B605F3A, 0x0D894000,
+ 0x0B20FFF8, 0x2F970383, 0x0A625F42, 0x2B200018,
+ 0x2197038B, 0x12600130, 0x0C625F44, 0x2B200018,
+ 0x2197038B, 0x1F600134, 0x0834FFFE, 0x23C8020F,
+ 0x112E0002, 0x07625F46, 0x2920013C, 0x02509000,
+ 0x0A500001, 0x23290002, 0x22484000, 0x3D695F44,
+ 0x38340002, 0x20605F48, 0x1132FFFF, 0x28038000,
+ 0x2E0EC000, 0x2E0EC000, 0x040E4000, 0x1632FFFE,
+ 0x3A9703A3, 0x319702B8, 0x36200000, 0x15210120,
+ 0x146B5F42, 0x3E6A5F44, 0x06330001, 0x2FD006D6,
+ 0x2B2306D7, 0x20800345, 0x2B9702CD, 0x146B5F42,
+ 0x356A5F46, 0x38200008, 0x0A330002, 0x24D006E2,
+ 0x07018000, 0x1132FFFF, 0x040E4000, 0x18210124,
+ 0x222306E8, 0x20800345, 0x18210124, 0x2B9702CD,
+ 0x356A5F46, 0x2E9702C7, 0x356A5F46, 0x2E9702C7,
+ 0x146B5F42, 0x356A5F46, 0x1B210128, 0x0D330003,
+ 0x20D0070F, 0x116B5F48, 0x2B008000, 0x1132FFFF,
+ 0x37370001, 0x36C806F3, 0x2D0E0000, 0x25200010,
+ 0x26970345, 0x116B5F48, 0x356A5F46, 0x37370001,
+ 0x05CC0718, 0x0F69013C, 0x01685F34, 0x356A5F46,
+ 0x223D9000, 0x1CCC070D, 0x2E2C0028, 0x084B0000,
+ 0x3E2C0002, 0x27490000, 0x3E2C0002, 0x2D1B4000,
+ 0x27490000, 0x3E2C0002, 0x2D1B4000, 0x27490000,
+ 0x2D200028, 0x2D1B4000, 0x2DC8070D, 0x31230718,
+ 0x20800345, 0x31230718, 0x338006A6, 0x25200010,
+ 0x2B9702CD, 0x356A5F46, 0x2E9702C7, 0x116B5F48,
+ 0x356A5F46, 0x37370001, 0x33C806F9, 0x2E9702C7,
+ 0x3D9702BB, 0x3D6A5F48, 0x09685F3A, 0x17360002,
+ 0x37C80722, 0x356A5F46, 0x01690134, 0x1132FFFF,
+ 0x040E4000, 0x1632FFFE, 0x12625F3C, 0x09300002,
+ 0x0260012C, 0x2368013C, 0x3797022B, 0x2D695F58,
+ 0x142D0032, 0x22484000, 0x38340002, 0x10CC0738,
+ 0x016A0154, 0x3A20A000, 0x28038000, 0x06330001,
+ 0x13D40732, 0x1D2E0001, 0x112E0002, 0x3D33FFFF,
+ 0x2E0EC000, 0x1632FFFE, 0x11625F5C, 0x0B970DD4,
+ 0x0E970DE8, 0x3368014C, 0x0A970EB9, 0x1A210000,
+ 0x236A5F5C, 0x2B200018, 0x00800ED6, 0x02030000,
+ 0x052B000B, 0x3EC4021B, 0x372C0744, 0x21884000,
+ 0x2B800754, 0x0D800811, 0x18800A18, 0x0B800AF1,
+ 0x3780021B, 0x0D800811, 0x3780021B, 0x0B800AF1,
+ 0x2D800752, 0x3780021B, 0x2A800753, 0x30380000,
+ 0x0CCC021B, 0x1C800C2F, 0x3780021B, 0x3780021B,
+ 0x0620FFFC, 0x2F970383, 0x122D0002, 0x2B200018,
+ 0x2197038B, 0x12600130, 0x1F600134, 0x0834FFFE,
+ 0x23C8020F, 0x112E0002, 0x23290002, 0x22484000,
+ 0x07625F46, 0x34340001, 0x20605F48, 0x2B008000,
+ 0x3530FFFD, 0x2D0E0000, 0x2D0E0000, 0x1632FFFE,
+ 0x3A9703A3, 0x319702B8, 0x36200000, 0x15210120,
+ 0x146B5F42, 0x356A5F46, 0x06330001, 0x34D00772,
+ 0x30230773, 0x20800345, 0x2B9702CD, 0x1E9709E7,
+ 0x356A5F46, 0x2D200028, 0x1A210000, 0x26970345,
+ 0x3D9702BB, 0x1A685F46, 0x36695F46, 0x3530FFFD,
+ 0x2B0C4000, 0x01600120, 0x1531FFFE, 0x20610124,
+ 0x026A0134, 0x3930FFFE, 0x232C01A0, 0x1132FFFF,
+ 0x1A210000, 0x084B0000, 0x3E2C0002, 0x2819C000,
+ 0x262EFFFF, 0x0BCC0785, 0x2435FFFE, 0x3EC80217,
+ 0x16970D35, 0x01690134, 0x1C6A0120, 0x3D6B0124,
+ 0x03208400, 0x172E0068, 0x3B2F0068, 0x1861B010,
+ 0x0862B000, 0x2963B004, 0x3760B01C, 0x362300AF,
+ 0x1A940D3A, 0x2C69B020, 0x25310002, 0x2DD0079E,
+ 0x07970D42, 0x34800217, 0x07970D42, 0x1A685F46,
+ 0x19220000, 0x0C600124, 0x2D010000, 0x1531FFFE,
+ 0x2E0D0000, 0x23610128, 0x070D4000, 0x2E0D0000,
+ 0x2E61012C, 0x12625F3C, 0x31200001, 0x1A60013E,
+ 0x39209000, 0x3797022B, 0x3A20A000, 0x0B970DD4,
+ 0x28680164, 0x126A0144, 0x28038000, 0x1632FFFE,
+ 0x2E0EC000, 0x30380000, 0x08D00EB7, 0x1F69014C,
+ 0x070E8000, 0x2E610140, 0x23620148, 0x35098000,
+ 0x2D61014C, 0x1531FFFE, 0x23610144, 0x00208200,
+ 0x00970DD6, 0x2B680168, 0x1C6A014C, 0x30380000,
+ 0x08D00EB7, 0x12690148, 0x23620148, 0x35098000,
+ 0x2E610140, 0x35098000, 0x1632FFFE, 0x040D8000,
+ 0x2D61014C, 0x3620F000, 0x00970DD6, 0x3E680148,
+ 0x1C690140, 0x19220000, 0x20620144, 0x0160014C,
+ 0x2E0D0000, 0x2E610140, 0x3230FFFC, 0x0C600148,
+ 0x1B208001, 0x00970DD6, 0x116A0148, 0x3368014C,
+ 0x2D6B0154, 0x2D620140, 0x2D010000, 0x3530FFFD,
+ 0x0F600144, 0x05300001, 0x1C0A0000, 0x040D8000,
+ 0x20610148, 0x020FC000, 0x12630150, 0x0F208010,
+ 0x00970DD6, 0x28680164, 0x1C690140, 0x30380000,
+ 0x08D00EB7, 0x116A0148, 0x3368014C, 0x206B0150,
+ 0x20610148, 0x2D620140, 0x312F0001, 0x12630150,
+ 0x1C0A0000, 0x20620144, 0x1B208001, 0x00970DD6,
+ 0x0C6A0150, 0x2D6B0154, 0x3368014C, 0x12690148,
+ 0x2E0EC000, 0x3E620150, 0x126A0144, 0x2E610140,
+ 0x1C0A0000, 0x23620148, 0x010F0000, 0x3A33FFFE,
+ 0x3D635F5C, 0x3930FFFE, 0x0F600144, 0x00208200,
+ 0x00970DD6, 0x0E970DE8, 0x07690168, 0x236A5F5C,
+ 0x1C390000, 0x08D00EB7, 0x1B970ECE, 0x2B200018,
+ 0x00800ED6, 0x0120FFFD, 0x2F970383, 0x122D0002,
+ 0x2B200018, 0x2197038B, 0x12600130, 0x1F600134,
+ 0x0834FFFE, 0x23C8020F, 0x112E0002, 0x23290002,
+ 0x22484000, 0x07625F46, 0x38340002, 0x20605F48,
+ 0x2B008000, 0x07018000, 0x3930FFFE, 0x1A32FFFD,
+ 0x2D0E0000, 0x040E4000, 0x1632FFFE, 0x3A9703A3,
+ 0x319702B8, 0x1E9709E7, 0x356A5F46, 0x2D200028,
+ 0x1A210000, 0x1132FFFF, 0x26970345, 0x36200000,
+ 0x356A5F46, 0x1A210000, 0x1132FFFF, 0x26970345,
+ 0x3D9702BB, 0x356A5F46, 0x359706A6, 0x36695F46,
+ 0x1A685F46, 0x1931FFFD, 0x2D610120, 0x29310001,
+ 0x1F090000, 0x20610124, 0x16970D35, 0x01690134,
+ 0x1C6A0120, 0x1861B010, 0x172E0068, 0x0862B000,
+ 0x0662B008, 0x31208808, 0x3760B01C, 0x362300AF,
+ 0x1A940D3A, 0x2169B024, 0x1C390000, 0x10D008F3,
+ 0x12690124, 0x03208400, 0x142D0068, 0x0661B004,
+ 0x3760B01C, 0x362300AF, 0x1A940D3A, 0x2C69B020,
+ 0x25310002, 0x21D408F3, 0x36695F46, 0x1C6A0120,
+ 0x31208808, 0x040E4000, 0x2E620120, 0x172E0068,
+ 0x0862B000, 0x0662B008, 0x3760B01C, 0x362300AF,
+ 0x1A940D3A, 0x2169B024, 0x1C390000, 0x10D008F3,
+ 0x03208400, 0x3760B01C, 0x362300AF, 0x1A940D3A,
+ 0x2C69B020, 0x25310002, 0x21D408F3, 0x07970D42,
+ 0x1A685F46, 0x1F690120, 0x0F600128, 0x3930FFFE,
+ 0x2E0D0000, 0x2E61012C, 0x329703C1, 0x11615F3C,
+ 0x3620F000, 0x202A0002, 0x13C408F5, 0x3E695F48,
+ 0x14350002, 0x21CC08F5, 0x3797022B, 0x0A9709C0,
+ 0x089709CB, 0x016A0154, 0x3368014C, 0x336B0140,
+ 0x3E620150, 0x12690148, 0x0F630148, 0x300B0000,
+ 0x0C630144, 0x3E30FFFF, 0x1F090000, 0x2E610140,
+ 0x1B208001, 0x00970DD6, 0x1C9709DA, 0x3368014C,
+ 0x1F6A0140, 0x12690148, 0x2D6B0154, 0x1C0A0000,
+ 0x2E62014C, 0x3E30FFFF, 0x2E0D0000, 0x2E610140,
+ 0x05300001, 0x2E0D0000, 0x20610148, 0x36200000,
+ 0x0F600144, 0x12630150, 0x39209000, 0x0B970DD4,
+ 0x3E680148, 0x1C690140, 0x1C6A014C, 0x1A084000,
+ 0x0160014C, 0x20610148, 0x2D620140, 0x2D010000,
+ 0x3E30FFFF, 0x2E0D0000, 0x3D610150, 0x3F208800,
+ 0x00970DD6, 0x3368014C, 0x1F6A0140, 0x12690148,
+ 0x2D6B0154, 0x1C0A0000, 0x2E62014C, 0x3E30FFFF,
+ 0x1F090000, 0x2E610140, 0x3930FFFE, 0x1C0A0000,
+ 0x23620148, 0x12630150, 0x39209000, 0x0B970DD4,
+ 0x3368014C, 0x12690148, 0x1F6A0140, 0x0C600148,
+ 0x1A084000, 0x28038000, 0x2D0E0000, 0x2E62014C,
+ 0x09300002, 0x010F0000, 0x01630140, 0x1C208000,
+ 0x0B970DD4, 0x3A20A000, 0x0B970DD4, 0x2E680154,
+ 0x1C6A014C, 0x2D010000, 0x29310001, 0x2FD408CD,
+ 0x322C0001, 0x3E2C0002, 0x0160014C, 0x2D620140,
+ 0x2D010000, 0x3E30FFFF, 0x2B0C4000, 0x0F600144,
+ 0x2D010000, 0x3E30FFFF, 0x2E0D0000, 0x20610148,
+ 0x00208200, 0x00970DD6, 0x3E680148, 0x306B014C,
+ 0x016A0154, 0x02600140, 0x2D010000, 0x3930FFFE,
+ 0x38605F5A, 0x1C09C000, 0x23610144, 0x1632FFFE,
+ 0x11625F5C, 0x03208400, 0x00970DD6, 0x0E970DE8,
+ 0x1B970ECE, 0x026B5F58, 0x0A6A0160, 0x3D2F0034,
+ 0x0B4BC000, 0x16420000, 0x3D370004, 0x25CC0DA8,
+ 0x236A5F5C, 0x2B200018, 0x00800ED6, 0x07970D42,
+ 0x3F800215, 0x1160013C, 0x2997037C, 0x0C2309A3,
+ 0x2B635F46, 0x1E2008FB, 0x38605F36, 0x229703B1,
+ 0x05CC027E, 0x22970251, 0x0B230901, 0x2B635F46,
+ 0x3B80022E, 0x3E680148, 0x1C6A014C, 0x1C690140,
+ 0x0160014C, 0x20620144, 0x2D0E0000, 0x3E30FFFF,
+ 0x1F090000, 0x2E610140, 0x23620148, 0x1B208001,
+ 0x00970DD6, 0x1C9709DA, 0x12690148, 0x3368014C,
+ 0x1F6A0140, 0x2D6B0154, 0x2E610140, 0x1C0A0000,
+ 0x1C0A0000, 0x2E62014C, 0x3930FFFE, 0x0C600148,
+ 0x36200000, 0x0F600144, 0x12630150, 0x39209000,
+ 0x0B970DD4, 0x3368014C, 0x12690148, 0x1F6A0140,
+ 0x0C600148, 0x1A084000, 0x09300002, 0x2D0E0000,
+ 0x2D620140, 0x05300001, 0x0160014C, 0x25200010,
+ 0x28695F52, 0x19220000, 0x2B190000, 0x1A615F52,
+ 0x26695F6C, 0x1F238000, 0x38635F56, 0x22484000,
+ 0x026B5F34, 0x122D0002, 0x3F424000, 0x351F0000,
+ 0x0EC80DB1, 0x16235F7A, 0x2449C000, 0x3D2F0002,
+ 0x1A1D0000, 0x29CC0941, 0x2449C000, 0x1C390000,
+ 0x3FCC0DB1, 0x25695F56, 0x1C390000, 0x25D40944,
+ 0x14625F56, 0x302F0006, 0x1D2E0001, 0x03800936,
+ 0x04685F52, 0x076B5F52, 0x3C34000F, 0x393700F0,
+ 0x2DCC094C, 0x1C1C8000, 0x26CC094E, 0x06800950,
+ 0x1C1C8000, 0x3DCC0950, 0x1D32FFFC, 0x01800951,
+ 0x1E31FFFC, 0x01198000, 0x17615F56, 0x076B5F52,
+ 0x23310004, 0x1035000F, 0x3F37000F, 0x1C1F4000,
+ 0x0CC80966, 0x28004000, 0x07645F52, 0x1331FFF8,
+ 0x32394001, 0x12615F6A, 0x2D010000, 0x22310003,
+ 0x19615F68, 0x3E30FFFF, 0x032C0D70, 0x05230965,
+ 0x21884000, 0x38605F6C, 0x116A0148, 0x1F69014C,
+ 0x30680140, 0x040D8000, 0x1531FFFE, 0x17615F60,
+ 0x3D6B0148, 0x1C0A0000, 0x2B0F8000, 0x0263014C,
+ 0x3930FFFE, 0x30605F62, 0x1632FFFE, 0x12625F66,
+ 0x10970CD3, 0x34200051, 0x2360B444, 0x09685F56,
+ 0x0A6B5F60, 0x3C34000F, 0x0E300003, 0x2D010000,
+ 0x0934FF00, 0x010CC000, 0x2060B448, 0x193500FF,
+ 0x0761B44A, 0x07685F68, 0x016B5F62, 0x206A5F66,
+ 0x2D010000, 0x0934FF00, 0x010CC000, 0x2D60B44C,
+ 0x193500FF, 0x0A61B44E, 0x1F62B454, 0x1920098F,
+ 0x3E210974, 0x362300AF, 0x19800CEA, 0x1D210001,
+ 0x3561015E, 0x1C208000, 0x1260015C, 0x02970E78,
+ 0x076B5F52, 0x0A685F6C, 0x3F37000F, 0x293B0100,
+ 0x2563B144, 0x3C2108C5, 0x3E2C0002, 0x15410000,
+ 0x09685F56, 0x0B230DB1, 0x3C34000F, 0x07645F52,
+ 0x0E300003, 0x35605F68, 0x08800DE8, 0x0A9709C0,
+ 0x089709CB, 0x3368014C, 0x1F6A0140, 0x12690148,
+ 0x2D6B0154, 0x1C0A0000, 0x2E62014C, 0x1F6A0140,
+ 0x12630150, 0x2E610140, 0x3930FFFE, 0x1C0A0000,
+ 0x23620148, 0x36200000, 0x0F600144, 0x39209000,
+ 0x0B970DD4, 0x1C690140, 0x3E680148, 0x116A0148,
+ 0x2E610140, 0x1A084000, 0x0160014C, 0x3E30FFFF,
+ 0x2D0E0000, 0x23620148, 0x36200000, 0x18800928,
+ 0x3E680148, 0x1C6A014C, 0x1C690140, 0x0160014C,
+ 0x20620144, 0x1F090000, 0x2D0E0000, 0x2E610140,
+ 0x23620148, 0x1B208001, 0x06800DD6, 0x3368014C,
+ 0x12690148, 0x1F6A0140, 0x2E610140, 0x2D0E0000,
+ 0x23620148, 0x2E020000, 0x1632FFFE, 0x1C0A0000,
+ 0x2E680154, 0x20620144, 0x020C0000, 0x11600150,
+ 0x00208200, 0x06800DD6, 0x1F6A0140, 0x12690148,
+ 0x3368014C, 0x23620148, 0x2E610140, 0x3930FFFE,
+ 0x1C0A0000, 0x2E680154, 0x20620144, 0x020C0000,
+ 0x11600150, 0x00208200, 0x06800DD6, 0x25635F4E,
+ 0x146B5F42, 0x356A5F46, 0x38200008, 0x1A210000,
+ 0x0A330002, 0x0BD009F4, 0x28038000, 0x1632FFFE,
+ 0x3D33FFFF, 0x2E0EC000, 0x0A2309FF, 0x20800345,
+ 0x2B9702CD, 0x356A5F46, 0x2E9702C7, 0x356A5F46,
+ 0x2E9702C7, 0x356A5F46, 0x2E9702C7, 0x356A5F46,
+ 0x2E9702C7, 0x356A5F46, 0x2E9702C7, 0x3E695F48,
+ 0x356A5F46, 0x18350001, 0x17C80A12, 0x2D200028,
+ 0x21970372, 0x19685F4A, 0x33695F4C, 0x1632FFFE,
+ 0x1A048000, 0x0FC40A0C, 0x1E2D0001, 0x01615F4C,
+ 0x2B605F4A, 0x0A20FFFF, 0x1A210000, 0x356A5F46,
+ 0x15230A13, 0x20800345, 0x359706A6, 0x356A5F46,
+ 0x25200010, 0x1A210000, 0x176B5F4E, 0x20800345,
+ 0x0620FFFC, 0x2F970383, 0x03361F00, 0x38C80211,
+ 0x23320008, 0x33620138, 0x3F2A0011, 0x3BC40211,
+ 0x3E970398, 0x236B0130, 0x2D010000, 0x2435FFFE,
+ 0x23C8020F, 0x3008C000, 0x26C00A28, 0x12CC020F,
+ 0x126B5F44, 0x112E0002, 0x07625F46, 0x3D2F0002,
+ 0x20635F44, 0x3D33FFFF, 0x1632FFFE, 0x2E0EC000,
+ 0x1632FFFE, 0x3A9703A3, 0x2E680138, 0x3D695F44,
+ 0x02030000, 0x0B2B0003, 0x04C40A38, 0x3A200003,
+ 0x392C0003, 0x15072000, 0x333B0000, 0x02CC0213,
+ 0x36695F46, 0x092E0010, 0x2B034000, 0x1931FFFD,
+ 0x1C09C000, 0x040E4000, 0x082A0800, 0x30C40213,
+ 0x319702B8, 0x36200000, 0x15210120, 0x146B5F42,
+ 0x356A5F46, 0x06330001, 0x1BD00A4D, 0x14230A4E,
+ 0x20800345, 0x2B9702CD, 0x08970C0E, 0x356A5F46,
+ 0x2D200028, 0x1A210000, 0x26970345, 0x3D9702BB,
+ 0x3D695F44, 0x1A685F46, 0x1231FFFF, 0x2E0D0000,
+ 0x20610124, 0x3E30FFFF, 0x2E0D0000, 0x2D610120,
+ 0x16970D35, 0x01690134, 0x1C6A0120, 0x1861B010,
+ 0x172E0068, 0x0862B000, 0x0662B008, 0x31208808,
+ 0x3760B01C, 0x362300AF, 0x1A940D3A, 0x2169B024,
+ 0x1C390000, 0x14D00A74, 0x12690124, 0x03208400,
+ 0x142D0068, 0x0661B004, 0x3760B01C, 0x362300AF,
+ 0x1A940D3A, 0x2C69B020, 0x25310002, 0x1FD00A76,
+ 0x07970D42, 0x34800217, 0x07970D42, 0x1A685F46,
+ 0x3D695F44, 0x1C6A0120, 0x0C600124, 0x2E0D0000,
+ 0x23610128, 0x0C690130, 0x2E6B0134, 0x3930FFFE,
+ 0x2D0E0000, 0x2D62012C, 0x11630130, 0x33610134,
+ 0x19220000, 0x12625F3C, 0x1320E000, 0x3797022B,
+ 0x28680164, 0x0F690150, 0x30380000, 0x08D00EB7,
+ 0x2D6B0154, 0x126A0144, 0x3368014C, 0x30610154,
+ 0x312F0001, 0x12630150, 0x1C690140, 0x2E62014C,
+ 0x02600140, 0x28004000, 0x040D8000, 0x20610148,
+ 0x1132FFFF, 0x19088000, 0x0F600144, 0x00208200,
+ 0x00970DD6, 0x2B680168, 0x2D6B0154, 0x30380000,
+ 0x08D00EB7, 0x1C6A014C, 0x12690148, 0x12630150,
+ 0x23620148, 0x35098000, 0x2E610140, 0x040D8000,
+ 0x1132FFFF, 0x040D8000, 0x2D61014C, 0x3620F000,
+ 0x00970DD6, 0x3E680148, 0x1F69014C, 0x1F6A0140,
+ 0x35230000, 0x0C630144, 0x0160014C, 0x2E0D0000,
+ 0x20610148, 0x2D0E0000, 0x2D620140, 0x1B208001,
+ 0x00970DD6, 0x116A0148, 0x3368014C, 0x1C690140,
+ 0x2D6B0154, 0x2D620140, 0x2D0E0000, 0x3E30FFFF,
+ 0x2D0E0000, 0x23620148, 0x1F090000, 0x23610144,
+ 0x3D33FFFF, 0x12630150, 0x0F208010, 0x00970DD6,
+ 0x04690164, 0x3368014C, 0x1C390000, 0x08D00EB7,
+ 0x1C690140, 0x116A0148, 0x206B0150, 0x20610148,
+ 0x2D620140, 0x312F0001, 0x12630150, 0x1F090000,
+ 0x23610144, 0x1B208001, 0x00970DD6, 0x0C6A0150,
+ 0x2D6B0154, 0x3368014C, 0x12690148, 0x2E0EC000,
+ 0x3E620150, 0x010F0000, 0x3A33FFFE, 0x3D635F5C,
+ 0x3E6B0144, 0x2E610140, 0x300B0000, 0x0F630148,
+ 0x3930FFFE, 0x300B0000, 0x0C630144, 0x00208200,
+ 0x00970DD6, 0x0E970DE8, 0x07690168, 0x236A5F5C,
+ 0x1C390000, 0x08D00EB7, 0x1B970ECE, 0x2B200018,
+ 0x00800ED6, 0x0120FFFD, 0x2F970383, 0x03361F00,
+ 0x38C80211, 0x23320008, 0x33620138, 0x3F2A0011,
+ 0x3BC40211, 0x3E970398, 0x236B0130, 0x2D010000,
+ 0x2435FFFE, 0x23C8020F, 0x3008C000, 0x20C00B01,
+ 0x12CC020F, 0x126B5F44, 0x112E0002, 0x07625F46,
+ 0x3D2F0002, 0x20635F44, 0x0200C000, 0x3D33FFFF,
+ 0x010F0000, 0x1632FFFE, 0x2E0EC000, 0x1632FFFE,
+ 0x3A9703A3, 0x2E680138, 0x3D695F44, 0x02030000,
+ 0x0B2B0003, 0x09C40B13, 0x3A200003, 0x3F2C0005,
+ 0x15072000, 0x333B0000, 0x02CC0213, 0x36695F46,
+ 0x092E0010, 0x1531FFFE, 0x040E4000, 0x082A0800,
+ 0x30C40213, 0x319702B8, 0x36200000, 0x1A210000,
+ 0x3E6A5F44, 0x26970345, 0x08970C0E, 0x356A5F46,
+ 0x2D200028, 0x1A210000, 0x1132FFFF, 0x26970345,
+ 0x3D9702BB, 0x11685F44, 0x36695F46, 0x2E020000,
+ 0x2B034000, 0x3E30FFFF, 0x1231FFFF, 0x280C8000,
+ 0x0C600124, 0x2B0C4000, 0x0F600128, 0x010CC000,
+ 0x01600120, 0x16970D35, 0x01690134, 0x126A0128,
+ 0x3E610130, 0x1861B010, 0x172E0068, 0x0862B000,
+ 0x0662B008, 0x31208808, 0x3760B01C, 0x362300AF,
+ 0x1A940D3A, 0x2169B024, 0x1C390000, 0x32D40B46,
+ 0x07970D42, 0x3F800215, 0x12690124, 0x03208400,
+ 0x142D0068, 0x0661B004, 0x3760B01C, 0x362300AF,
+ 0x1A940D3A, 0x2C69B020, 0x25310002, 0x39D40B44,
+ 0x1C6A0120, 0x31208808, 0x172E0068, 0x0862B000,
+ 0x0662B008, 0x3760B01C, 0x362300AF, 0x1A940D3A,
+ 0x2169B024, 0x1C390000, 0x08D00B44, 0x03208400,
+ 0x3760B01C, 0x362300AF, 0x1A940D3A, 0x2C69B020,
+ 0x25310002, 0x39D40B44, 0x07970D42, 0x1A685F46,
+ 0x1F690120, 0x0F600128, 0x2E0D0000, 0x2E61012C,
+ 0x19220000, 0x12625F3C, 0x3620F000, 0x3797022B,
+ 0x3E680148, 0x1C6A014C, 0x1C690140, 0x0160014C,
+ 0x20620144, 0x1F090000, 0x2E610140, 0x2D0E0000,
+ 0x23620148, 0x1B208001, 0x00970DD6, 0x3368014C,
+ 0x12690148, 0x1F6A0140, 0x2E610140, 0x07018000,
+ 0x2E0D0000, 0x20610148, 0x3E30FFFF, 0x1C0A0000,
+ 0x2E680154, 0x20620144, 0x020C0000, 0x11600150,
+ 0x00208200, 0x00970DD6, 0x016A0154, 0x3368014C,
+ 0x336B0140, 0x3E620150, 0x12690148, 0x0F630148,
+ 0x300B0000, 0x0C630144, 0x3E30FFFF, 0x1F090000,
+ 0x2E610140, 0x1B208001, 0x00970DD6, 0x3368014C,
+ 0x1F6A0140, 0x12690148, 0x23620148, 0x1C0A0000,
+ 0x2E680154, 0x20620144, 0x2E610140, 0x020C0000,
+ 0x11600150, 0x00208200, 0x00970DD6, 0x3368014C,
+ 0x2D6B0154, 0x12690148, 0x1F6A0140, 0x12630150,
+ 0x2E610140, 0x2D695F58, 0x1C0A0000, 0x2E62014C,
+ 0x1F2D0030, 0x0D4A4000, 0x1F2D0006, 0x0E494000,
+ 0x0F3607FC, 0x26320002, 0x33620154, 0x28038000,
+ 0x06330001, 0x31D40BB3, 0x1D2E0001, 0x112E0002,
+ 0x20620144, 0x1132FFFF, 0x23620148, 0x00351F00,
+ 0x20310008, 0x33610158, 0x1320E000, 0x00970DD6,
+ 0x3D680144, 0x1C6A014C, 0x1C690140, 0x206B0150,
+ 0x2D0E0000, 0x2E62014C, 0x0200C000, 0x06330001,
+ 0x2BD40BC6, 0x322C0001, 0x3E2C0002, 0x3E30FFFF,
+ 0x2E0D0000, 0x2E610140, 0x1A210000, 0x20610148,
+ 0x1320E000, 0x00970DD6, 0x206B0150, 0x2E680154,
+ 0x1C6A014C, 0x0263014C, 0x11600150, 0x1C600154,
+ 0x02030000, 0x06330001, 0x30D40BD8, 0x322C0001,
+ 0x3E2C0002, 0x20620144, 0x1C0A0000, 0x2D620140,
+ 0x3E30FFFF, 0x2D0E0000, 0x23620148, 0x1B208001,
+ 0x00970DD6, 0x12690148, 0x126A0144, 0x206B0150,
+ 0x2E610140, 0x23620148, 0x0200C000, 0x3D33FFFF,
+ 0x12630150, 0x1C600154, 0x02030000, 0x06330001,
+ 0x30D40BEE, 0x322C0001, 0x3E2C0002, 0x0F600144,
+ 0x00208200, 0x00970DD6, 0x11690144, 0x116A0148,
+ 0x3368014C, 0x2D6B0154, 0x2D620140, 0x12630150,
+ 0x1C600154, 0x02030000, 0x06330001, 0x2FD40BFD,
+ 0x322C0001, 0x3E2C0002, 0x0160014C, 0x350A4000,
+ 0x23620148, 0x3930FFFE, 0x1C0A0000, 0x20620144,
+ 0x00208200, 0x00970DD6, 0x12690148, 0x016A0154,
+ 0x306B014C, 0x2E610140, 0x3E620150, 0x3D33FFFF,
+ 0x1C09C000, 0x088008E2, 0x25635F4E, 0x146B5F42,
+ 0x38200008, 0x1A210000, 0x3E6A5F44, 0x0A330002,
+ 0x1CD00C1A, 0x196B5F46, 0x1132FFFF, 0x2E0EC000,
+ 0x19230C2A, 0x20800345, 0x2B9702CD, 0x3E6A5F44,
+ 0x2E9702C7, 0x3E6A5F44, 0x19685F4A, 0x33695F4C,
+ 0x1632FFFE, 0x1A048000, 0x10C40C25, 0x1E2D0001,
+ 0x01615F4C, 0x2B605F4A, 0x356A5F46, 0x0A20FFFF,
+ 0x1A210000, 0x2B9702CD, 0x356A5F46, 0x25200010,
+ 0x1A210000, 0x176B5F4E, 0x20800345, 0x3780021B,
+ 0x02030000, 0x0C37FFFF, 0x0CCC021B, 0x052C0C35,
+ 0x21884000, 0x06800C36, 0x28970382, 0x3E20000E,
+ 0x2197038B, 0x093C000E, 0x12CC020F, 0x2A2001FF,
+ 0x2197038B, 0x3D605F3C, 0x3F340003, 0x12CC020F,
+ 0x122E000E, 0x1632FFFE, 0x3A9703A3, 0x319702B8,
+ 0x1122000E, 0x36200000, 0x1A210000, 0x26970345,
+ 0x01685F34, 0x122101D8, 0x3E610106, 0x3B2C0008,
+ 0x27490000, 0x3E2C0002, 0x0B480000, 0x07615F4A,
+ 0x2D605F4C, 0x0F685F3C, 0x30695F40, 0x3930FFFE,
+ 0x36605F3E, 0x1F090000, 0x04C40C58, 0x2E605F40,
+ 0x202001A0, 0x08230C5D, 0x19600104, 0x3B635F36,
+ 0x258002F5, 0x25200010, 0x19600104, 0x2B80043E,
+ 0x20970106, 0x15220003, 0x1F62B438, 0x2C695FCA,
+ 0x04685EDE, 0x19220000, 0x1461B400, 0x1162B406,
+ 0x30380000, 0x36C800A5, 0x2A340080, 0x00C80C6F,
+ 0x13200C80, 0x19230C70, 0x288000B4, 0x36605EDE,
+ 0x09685EEC, 0x332300A5, 0x19220000, 0x14625EEC,
+ 0x28695EDE, 0x366A5EF0, 0x30380000, 0x22C8010E,
+ 0x01198000, 0x2E6A5F02, 0x01198000, 0x336A5EA0,
+ 0x24D000B4, 0x3C36FDFF, 0x01625EA0, 0x288000B4,
+ 0x22215EDE, 0x1F220006, 0x1D97100D, 0x2F215EEC,
+ 0x21510000, 0x21510000, 0x21884000, 0x1F220030,
+ 0x1F62B438, 0x21695FCE, 0x19685EF0, 0x19220000,
+ 0x0161B420, 0x0462B426, 0x30380000, 0x3AC800A6,
+ 0x2A340080, 0x0CC80C95, 0x02200C9B, 0x05230C96,
+ 0x288000B4, 0x2B605EF0, 0x11685EFE, 0x3F2300A6,
+ 0x19220000, 0x0C625EFE, 0x1B800C74, 0x3F215EF0,
+ 0x1F220006, 0x1D97100D, 0x37215EFE, 0x21510000,
+ 0x21510000, 0x21884000, 0x1F220300, 0x1F62B438,
+ 0x21695FCE, 0x01685F02, 0x19220000, 0x0261B440,
+ 0x0762B446, 0x30380000, 0x3DC800A7, 0x2A340080,
+ 0x13C80CB0, 0x13200CB6, 0x11230CB1, 0x288000B4,
+ 0x33605F02, 0x19685F10, 0x382300A7, 0x19220000,
+ 0x04625F10, 0x1B800C74, 0x27215F02, 0x1F220006,
+ 0x1D97100D, 0x3F215F10, 0x21510000, 0x21510000,
+ 0x21884000, 0x04685EDE, 0x22215EDE, 0x30380000,
+ 0x0CD00CC9, 0x03205EEC, 0x0B518000, 0x0D500000,
+ 0x30695EA0, 0x0D500000, 0x00390200, 0x02615EA0,
+ 0x228B4000, 0x0200C000, 0x1F220006, 0x362300AF,
+ 0x19801030, 0x19685EF0, 0x3F215EF0, 0x30380000,
+ 0x0CD00CC9, 0x1B205EFE, 0x02800CC2, 0x01685F02,
+ 0x27215F02, 0x30380000, 0x0CD00CC9, 0x13205F10,
+ 0x02800CC2, 0x04685EDE, 0x22215EDE, 0x30380000,
+ 0x33D40CC1, 0x398000AF, 0x19685EF0, 0x3F215EF0,
+ 0x30380000, 0x35D000AF, 0x1B205EFE, 0x02800CC2,
+ 0x3B605EEC, 0x1C615EEE, 0x228B4000, 0x23605EFE,
+ 0x14615F00, 0x228B4000, 0x2B605F10, 0x0C615F12,
+ 0x228B4000, 0x19685EF0, 0x1A210000, 0x30380000,
+ 0x0DC80CFE, 0x1F61B434, 0x226A5FCE, 0x0761B426,
+ 0x0262B420, 0x2A340080, 0x01C80CFD, 0x28635E9C,
+ 0x3F215EF0, 0x1F220006, 0x1D97100D, 0x1A6B5E9C,
+ 0x288000B4, 0x07615EF0, 0x228B4000, 0x2E620116,
+ 0x1B200D02, 0x288000B4, 0x15970CD9, 0x1C6A0116,
+ 0x0D20B404, 0x19500011, 0x01500003, 0x1150C400,
+ 0x0A500001, 0x0E500180, 0x0D500000, 0x0962B414,
+ 0x352000AF, 0x192100AF, 0x362300AF, 0x11800CE4,
+ 0x01690102, 0x36200000, 0x0A350020, 0x28C8020D,
+ 0x30218000, 0x1F615ED4, 0x3B605EDA, 0x3D605EDC,
+ 0x228B4000, 0x2D695ED4, 0x30380000, 0x22C8010E,
+ 0x1C390000, 0x18D4010A, 0x3B605EDA, 0x228B4000,
+ 0x2D695ED4, 0x30380000, 0x22C8010E, 0x1C390000,
+ 0x18D4010A, 0x3D605EDC, 0x228B4000, 0x01685ED4,
+ 0x27215ED4, 0x30380000, 0x1ED4010C, 0x21510000,
+ 0x228B4000, 0x30695ECC, 0x07685ED2, 0x1C390000,
+ 0x06D400A4, 0x30380000, 0x31C800A4, 0x342300A4,
+ 0x288000B4, 0x3A215ECC, 0x0B518000, 0x36200000,
+ 0x35605ED2, 0x228B4000, 0x30695ECC, 0x35605ED2,
+ 0x1C390000, 0x30695EA0, 0x18D4010A, 0x12390008,
+ 0x02615EA0, 0x228B4000, 0x336A5EA0, 0x1C685ECC,
+ 0x3A215ECC, 0x2E36FFF7, 0x01625EA0, 0x30380000,
+ 0x1ED4010C, 0x21510000, 0x228B4000, 0x04685F52,
+ 0x30218000, 0x2D144000, 0x04CC00A9, 0x1A615F52,
+ 0x302300A9, 0x19200D53, 0x288000B4, 0x29200400,
+ 0x2660B144, 0x06210200, 0x1468B144, 0x3C34000F,
+ 0x2B190000, 0x0A61B144, 0x07645F52, 0x2D010000,
+ 0x20310008, 0x1139A0C8, 0x214B4000, 0x0F2D002C,
+ 0x0E494000, 0x2E020000, 0x06330001, 0x20377F00,
+ 0x1263010A, 0x21320003, 0x1A625F68, 0x2E020000,
+ 0x1032FFF8, 0x313A4001, 0x11625F6A, 0x2E020000,
+ 0x1132FFFF, 0x2C2E0D70, 0x07230D84, 0x0E8A4000,
+ 0x15205F7A, 0x228B4000, 0x12205F82, 0x228B4000,
+ 0x1C205F8A, 0x228B4000, 0x01205F92, 0x228B4000,
+ 0x0F205F9A, 0x228B4000, 0x07205FA2, 0x228B4000,
+ 0x09205FAA, 0x228B4000, 0x14205FB2, 0x228B4000,
+ 0x1A205FBA, 0x228B4000, 0x04205FC2, 0x228B4000,
+ 0x38605F6C, 0x27490000, 0x3E2C0002, 0x084B0000,
+ 0x3E2C0002, 0x244A0000, 0x3E2C0002, 0x0B480000,
+ 0x1F615F58, 0x38635F56, 0x17625F5A, 0x3E605F5C,
+ 0x10970E96, 0x236A5F5C, 0x266B010C, 0x1F3A0000,
+ 0x1AC80DA0, 0x19213000, 0x35098000, 0x190B4000,
+ 0x3061010E, 0x2CC00D9B, 0x34CC0EB5, 0x0A685F5A,
+ 0x1F230DA0, 0x33635F54, 0x046B5F68, 0x12800E9B,
+ 0x0F69010A, 0x0A6B5F56, 0x20310008, 0x0DC80DD1,
+ 0x2E6A5F58, 0x05390080, 0x162E0035, 0x0E458000,
+ 0x0E970DE8, 0x04685F52, 0x1B230DAD, 0x16341000,
+ 0x2DCC109C, 0x3A2000A0, 0x00645F53, 0x2D695F58,
+ 0x3197028E, 0x0269010E, 0x1A223000, 0x350A4000,
+ 0x1DC80DCD, 0x28680108, 0x25620114, 0x30380000,
+ 0x0CC80DBA, 0x06970CFF, 0x10970CD3, 0x0269010E,
+ 0x1B20B444, 0x19500011, 0x0A500001, 0x1150C400,
+ 0x0A500001, 0x2335FFFF, 0x15410000, 0x176A0114,
+ 0x3E2C0002, 0x0D500000, 0x1F62B454, 0x1D200DCB,
+ 0x31210DCB, 0x362300AF, 0x19800CEA, 0x35203000,
+ 0x1C60010E, 0x1A210000, 0x36610108, 0x1A615F52,
+ 0x398000AF, 0x19220000, 0x3662015E, 0x228B4000,
+ 0x1D210001, 0x3561015E, 0x1260015C, 0x38635F56,
+ 0x02970E78, 0x076B5F52, 0x0A685F6C, 0x3F37000F,
+ 0x293B0100, 0x2563B144, 0x25695F56, 0x3E2C0002,
+ 0x15410000, 0x26695F5A, 0x3E2C0002, 0x15410000,
+ 0x20695F5C, 0x3E2C0002, 0x15410000, 0x04800DB1,
+ 0x04685F52, 0x3569B140, 0x3930FFFE, 0x38D003AD,
+ 0x33635F54, 0x09300002, 0x02030000, 0x3C34000F,
+ 0x3D3CFFFF, 0x33228000, 0x1A120000, 0x301D8000,
+ 0x0761B140, 0x336A5EA0, 0x27CC0DF9, 0x2D36FFFB,
+ 0x01625EA0, 0x3D3CFFFF, 0x3A225F7A, 0x3530FFFD,
+ 0x1F060000, 0x22520000, 0x22520000, 0x153B2000,
+ 0x07685F32, 0x35635F52, 0x1A344000, 0x19C80E09,
+ 0x0A685F36, 0x2E9700B4, 0x02685F54, 0x362300AF,
+ 0x288000B4, 0x04685F52, 0x3569B140, 0x1F238000,
+ 0x3C34000F, 0x2E020000, 0x123EFFFF, 0x1C138000,
+ 0x2819C000, 0x0761B140, 0x3F30FFF8, 0x2838A084,
+ 0x18500020, 0x3B680118, 0x2E695F54, 0x0418C000,
+ 0x09600118, 0x351CC000, 0x28CC0E53, 0x2361011E,
+ 0x07685F68, 0x0763011C, 0x0260011A, 0x10970CD3,
+ 0x336B011A, 0x1B20B444, 0x1C500041, 0x0A500001,
+ 0x0E500180, 0x0D500000, 0x2D02C000, 0x2636FF00,
+ 0x0262B44C, 0x363700FF, 0x2563B44E, 0x3F222000,
+ 0x1F62B454, 0x3E6B011E, 0x36200000, 0x0F60011E,
+ 0x333B0000, 0x2BCC0E33, 0x362300AF, 0x16200E36,
+ 0x3A210E36, 0x19800CEA, 0x3668011C, 0x3569B140,
+ 0x146A0118, 0x1A1D0000, 0x0761B140, 0x191E0000,
+ 0x26620118, 0x09C80E4F, 0x36200000, 0x1D210001,
+ 0x28038000, 0x2E174000, 0x31CC0E46, 0x322C0001,
+ 0x1231FFFF, 0x0C800E40, 0x2861011C, 0x0E300003,
+ 0x2B695F32, 0x0260011A, 0x36354000, 0x0CC80E1F,
+ 0x0A200E1F, 0x096B5F36, 0x288000B4, 0x07685F32,
+ 0x26695F36, 0x1A344000, 0x33C800AF, 0x0D894000,
+ 0x1F3A0000, 0x3EC803AD, 0x3B635F36, 0x1A6B5F4A,
+ 0x19600104, 0x3E610106, 0x19625F3E, 0x23635F48,
+ 0x0B970CCD, 0x2B680104, 0x0F6A0106, 0x116B5F48,
+ 0x2360B428, 0x3C21B42A, 0x21510000, 0x0200C000,
+ 0x0934FF00, 0x281A0000, 0x0162B42C, 0x363700FF,
+ 0x2663B42E, 0x2B6A5F3E, 0x27200041, 0x2060B424,
+ 0x1C62B434, 0x3C210E5C, 0x362300AF, 0x18940CE7,
+ 0x096B5F36, 0x228B4000, 0x3B635F36, 0x39200120,
+ 0x1A210000, 0x0C220020, 0x1C6B5F4C, 0x11800E58,
+ 0x33635F54, 0x0F6B5F6A, 0x3A200140, 0x1A210000,
+ 0x0C220020, 0x3B605F60, 0x1C615F62, 0x12625F66,
+ 0x36635F5E, 0x10970CD3, 0x09685F60, 0x2D6A5F62,
+ 0x046B5F5E, 0x2060B448, 0x3F21B44A, 0x21510000,
+ 0x0200C000, 0x0934FF00, 0x281A0000, 0x0262B44C,
+ 0x363700FF, 0x2563B44E, 0x206A5F66, 0x27200041,
+ 0x2360B444, 0x1F62B454, 0x05200EB3, 0x24210E81,
+ 0x362300AF, 0x19800CEA, 0x33635F54, 0x36200000,
+ 0x16210140, 0x0F22002C, 0x0F6B5F6A, 0x3B605F60,
+ 0x1C615F62, 0x12625F66, 0x36635F5E, 0x10970CD3,
+ 0x286A5F5E, 0x09685F60, 0x2E695F62, 0x28038000,
+ 0x0A37FF00, 0x0418C000, 0x2060B448, 0x1A3600FF,
+ 0x0462B44A, 0x0161B44C, 0x36200000, 0x2660B44E,
+ 0x206A5F66, 0x22200011, 0x2360B444, 0x1F62B454,
+ 0x3F210E9F, 0x362300AF, 0x1C940CEA, 0x016B5F54,
+ 0x228B4000, 0x0B210041, 0x1D800DA4, 0x08210021,
+ 0x1D800DA4, 0x2E6A5F58, 0x04690164, 0x012E0028,
+ 0x1C390000, 0x1CD00ECA, 0x1F090000, 0x1531FFFE,
+ 0x2B680168, 0x3F418000, 0x2F34001F, 0x112E0002,
+ 0x13408000, 0x2B008000, 0x3E2C0002, 0x0D500000,
+ 0x0D500000, 0x228B4000, 0x1C208000, 0x13408000,
+ 0x36200000, 0x19800EC3, 0x01685F58, 0x1A210000,
+ 0x2E2C0028, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x15410000, 0x228B4000, 0x11230DA8, 0x0F3607FC,
+ 0x3EC803AD, 0x33635F54, 0x026B5F58, 0x12625F66,
+ 0x010CC000, 0x084B0000, 0x3E2C0002, 0x0B480000,
+ 0x33635F62, 0x2D6B010E, 0x36605F64, 0x2D0DC000,
+ 0x36610108, 0x1B970CBD, 0x02685F62, 0x28695F64,
+ 0x3B60B40C, 0x1C61B40E, 0x28680108, 0x206A5F66,
+ 0x2921B40A, 0x3660B408, 0x21510000, 0x28200081,
+ 0x3560B404, 0x0962B414, 0x02685F54, 0x2A210EE5,
+ 0x362300AF, 0x11800CE4, 0x2D695F6E, 0x1C208000,
+ 0x28150000, 0x1BC80EFB, 0x228B4000, 0x336A5EA0,
+ 0x33605F6E, 0x0B200F01, 0x2B36FFFD, 0x01625EA0,
+ 0x288000B4, 0x15685FDC, 0x2D695F6E, 0x30380000,
+ 0x04C80F64, 0x28605F70, 0x232C0040, 0x27490000,
+ 0x2E655F6E, 0x3865B112, 0x1F31FFFB, 0x232D4010,
+ 0x0D4A4000, 0x1F6BB110, 0x122D0002, 0x1F0AC000,
+ 0x33C00F58, 0x214B4000, 0x2C2DFFF6, 0x333B0000,
+ 0x2AD40F1D, 0x1A685F70, 0x012D0012, 0x0D4A4000,
+ 0x282C0042, 0x084B0000, 0x312DFFEE, 0x1F1F8000,
+ 0x3BCC0F5A, 0x28004000, 0x37215F72, 0x0B97104D,
+ 0x3D695F72, 0x332C0006, 0x13350003, 0x31CC0F5F,
+ 0x37215F72, 0x2922FFFC, 0x16971063, 0x1A685F70,
+ 0x33215FDC, 0x0B970FCB, 0x12971097, 0x1B970CBD,
+ 0x196B5F70, 0x11685F72, 0x3B695F74, 0x2A22B40A,
+ 0x3563B408, 0x22520000, 0x3B60B40C, 0x1C61B40E,
+ 0x28200081, 0x3560B404, 0x20200040, 0x2660B414,
+ 0x30210F2A, 0x362300AF, 0x14940CE4, 0x01685F6E,
+ 0x39695FEA, 0x353400FF, 0x3330FFFB, 0x0A2C401A,
+ 0x084B0000, 0x1E2D0001, 0x312F0001, 0x3A430000,
+ 0x002CFFF6, 0x244A0000, 0x332C0006, 0x084B0000,
+ 0x0B615FEA, 0x312F0001, 0x1F0AC000, 0x1BC40F4D,
+ 0x35230000, 0x3A430000, 0x2E6A5F6E, 0x1A685F70,
+ 0x1A3600FF, 0x3A3A1000, 0x1462B130, 0x06970FA3,
+ 0x1C208000, 0x33605F6E, 0x08230F01, 0x26800130,
+ 0x0D210088, 0x29655F6F, 0x1A685F70, 0x2D695F6E,
+ 0x3D2C0038, 0x0B480000, 0x0C800F03, 0x35970110,
+ 0x1A685F70, 0x33215FDC, 0x06230F53, 0x0D800FCB,
+ 0x336A5EA0, 0x3C350800, 0x1F615F6E, 0x33C800AF,
+ 0x143A0002, 0x01625EA0, 0x398000AF, 0x1768B148,
+ 0x05300001, 0x11D00F74, 0x03300007, 0x15D00F79,
+ 0x0C300008, 0x3D3CFFFF, 0x1464B148, 0x388000A8,
+ 0x35230000, 0x2663B148, 0x39635FF2, 0x32635FF0,
+ 0x0B800F6E, 0x0E710048, 0x13710149, 0x2871804B,
+ 0x12800F7B, 0x00685FFC, 0x276AB1F8, 0x0934FF00,
+ 0x0C300008, 0x322C0001, 0x03361F00, 0x23320008,
+ 0x1C0A0000, 0x06C00114, 0x3F225E90, 0x3330FFFB,
+ 0x1C2C4000, 0x1C0A0000, 0x10C0010E, 0x2F605FD2,
+ 0x06625FD4, 0x242A000F, 0x16C00108, 0x228B4000,
+ 0x10685FD6, 0x37695FD4, 0x30380000, 0x01C80F97,
+ 0x27490000, 0x0E615FD6, 0x228B4000, 0x33290044,
+ 0x3DC00F9F, 0x1D685FD2, 0x05615FD4, 0x2D010000,
+ 0x022D0044, 0x03615FD2, 0x228B4000, 0x361C0000,
+ 0x2F605FD2, 0x29605FD4, 0x228B4000, 0x3C695FD6,
+ 0x30380000, 0x22C8010E, 0x15410000, 0x22605FD6,
+ 0x228B4000, 0x1C390000, 0x24C80108, 0x0D4A4000,
+ 0x30380000, 0x22C8010E, 0x10404000, 0x1F3A0000,
+ 0x14C80FB7, 0x362C003A, 0x16420000, 0x122E0038,
+ 0x062CFFC6, 0x13408000, 0x228B4000, 0x222DFFFE,
+ 0x10404000, 0x228B4000, 0x1C390000, 0x24C80108,
+ 0x0D4A4000, 0x30380000, 0x22C8010E, 0x10404000,
+ 0x1F3A0000, 0x0BC80FC8, 0x3D2C0038, 0x16420000,
+ 0x192E003A, 0x0E2CFFC8, 0x13408000, 0x228B4000,
+ 0x122D0002, 0x10404000, 0x228B4000, 0x1C390000,
+ 0x24C80108, 0x30380000, 0x22C8010E, 0x2D635E96,
+ 0x362C003A, 0x084B0000, 0x0E2CFFFE, 0x244A0000,
+ 0x333B0000, 0x1EC80FDE, 0x1F3A0000, 0x12C80FEB,
+ 0x3E2F0038, 0x1542C000, 0x192E003A, 0x0D2FFFC8,
+ 0x10438000, 0x1C800FE6, 0x3F424000, 0x1F3A0000,
+ 0x1DC80FE4, 0x192E003A, 0x10438000, 0x1C800FE6,
+ 0x122D0002, 0x3F424000, 0x0D500000, 0x0D500000,
+ 0x1F6B5E96, 0x0D2CFFC4, 0x228B4000, 0x122D0002,
+ 0x3F424000, 0x3E2F0038, 0x1542C000, 0x1C800FE6,
+ 0x2A320001, 0x0A367FFF, 0x19C81003, 0x252A0008,
+ 0x3EC00FFF, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x0D500000, 0x0D500000, 0x0D500000,
+ 0x0D500000, 0x19C81003, 0x05800FF3, 0x26260008,
+ 0x0D500000, 0x262EFFFF, 0x24CC1000, 0x228B4000,
+ 0x26635E94, 0x1D97100D, 0x146B5E94, 0x288000B4,
+ 0x26635E94, 0x1D97100D, 0x02030000, 0x17685E94,
+ 0x288000B4, 0x22484000, 0x0F615E92, 0x28605E90,
+ 0x0C300008, 0x3FD4102E, 0x2D635E96, 0x2C34007F,
+ 0x3E30FFFF, 0x122D0002, 0x2E0D0000, 0x214B4000,
+ 0x05300001, 0x322C0001, 0x36695E90, 0x191E0000,
+ 0x3FCC101E, 0x36200000, 0x07024000, 0x36368000,
+ 0x0035007F, 0x1A1D0000, 0x3D695E92, 0x03C8102C,
+ 0x23320008, 0x281A0000, 0x1E2D0001, 0x0E464000,
+ 0x0200C000, 0x1F6B5E96, 0x30380000, 0x228B4000,
+ 0x3F424000, 0x04801028, 0x361C0000, 0x228B4000,
+ 0x28605E90, 0x22484000, 0x0A625E94, 0x0C300008,
+ 0x36D4104B, 0x2E020000, 0x0C300008, 0x2C34007F,
+ 0x0336007F, 0x191E0000, 0x24C80108, 0x3E30FFFF,
+ 0x356A5E90, 0x0F615E92, 0x122D0002, 0x2E0D0000,
+ 0x3F424000, 0x386A5E94, 0x3D695E92, 0x05300001,
+ 0x322C0001, 0x191E0000, 0x3CCC1048, 0x36200000,
+ 0x29380080, 0x21444000, 0x228B4000, 0x36200000,
+ 0x1A80103C, 0x2D635E96, 0x084B0000, 0x3E2C0002,
+ 0x13434000, 0x244A0000, 0x122D0002, 0x3F424000,
+ 0x2E1B8000, 0x3E2C0002, 0x244A0000, 0x122D0002,
+ 0x3F424000, 0x2E1B8000, 0x3E2C0002, 0x244A0000,
+ 0x122D0002, 0x3F424000, 0x2B1AC000, 0x1F6B5E96,
+ 0x3E2C0002, 0x122D0002, 0x228B4000, 0x28605E90,
+ 0x0F615E92, 0x2D635E96, 0x27490000, 0x280C8000,
+ 0x0B480000, 0x1C390000, 0x09C8108A, 0x03340FFC,
+ 0x0EC81072, 0x15280041, 0x3CC01072, 0x16240041,
+ 0x15072000, 0x0E801077, 0x1831FFFA, 0x07024000,
+ 0x2936FFC0, 0x2B034000, 0x3937003F, 0x3D695E92,
+ 0x22484000, 0x1A048000, 0x10404000, 0x122D0002,
+ 0x22484000, 0x2C04C400, 0x10404000, 0x0AC4108A,
+ 0x122D0002, 0x22484000, 0x19220000, 0x05048400,
+ 0x10404000, 0x0AC4108A, 0x122D0002, 0x22484000,
+ 0x05048400, 0x10404000, 0x1F6B5E96, 0x1A685E90,
+ 0x228B4000, 0x14685F14, 0x32215F14, 0x30380000,
+ 0x15D01093, 0x0B518000, 0x228B4000, 0x0200C000,
+ 0x12220002, 0x362300AF, 0x19801030, 0x14685F14,
+ 0x3A215F1A, 0x30380000, 0x15D01093, 0x228B4000,
+ 0x14685F14, 0x32215F14, 0x30380000, 0x1ED4010C,
+ 0x2A340080, 0x14C810A4, 0x12220002, 0x11801008,
+ 0x21510000, 0x1C685F1A, 0x28635E9C, 0x30380000,
+ 0x2DCC10AA, 0x228B4000, 0x3A215F1A, 0x12220002,
+ 0x14971004, 0x1A6B5E9C, 0x198010A5, 0x3DFFFFFF,
+ 0x01000000, 0x01000000, 0x01000000
+};
+
+// Encapsulates the PKA firmware images information.
+typedef struct {
+ const uint32_t *farm_img;
+ uint32_t farm_img_size;
+ const uint32_t *boot_img;
+ uint32_t boot_img_size;
+ const uint32_t *master_img;
+ uint32_t master_img_size;
+} pka_firmware_info_t;
+
+static const pka_firmware_info_t pka_firmware_array[] =
+{
+ {
+ fw0_farm_img_data_buf, 2048, // actual length is 1652
+ fw0_boot_img_data_buf, 152,
+ fw0_master_img_data_buf, 4161
+ },
+ {
+ fw1_farm_img_data_buf, 2048, // actual length is 2000
+ fw1_boot_img_data_buf, 127,
+ fw1_master_img_data_buf, 4186
+ },
+ {
+ fw2_farm_img_data_buf, 2048, // actual length is 2045
+ fw2_boot_img_data_buf, 154,
+ fw2_master_img_data_buf, 4275
+ }
+};
+
+#define PKA_FIRMWARE_IMAGE_0_ID 0
+#define PKA_FIRMWARE_IMAGE_1_ID 1
+#define PKA_FIRMWARE_IMAGE_2_ID 2
+
+// Global storage for the actual firmware identifier
+static uint8_t pka_firmware_id;
+
+// Setter of pka_firmware_id
+static inline void pka_firmware_set_id(uint8_t id)
+{
+ pka_firmware_id = id;
+}
+
+// Getter of pka_firmware_id
+static inline uint8_t pka_firmware_get_id(void)
+{
+ return pka_firmware_id;
+}
+
+
+#endif
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_ioctl.h b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_ioctl.h
new file mode 100644
index 000000000..8081a01fd
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_ioctl.h
@@ -0,0 +1,127 @@
+//
+// BSD LICENSE
+//
+// Copyright(c) 2016 Mellanox Technologies, Ltd. All rights reserved.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in
+// the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Mellanox Technologies nor the names of its
+// contributors may be used to endorse or promote products derived
+// from this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+
+#ifndef __PKA_IOCTL_H__
+#define __PKA_IOCTL_H__
+
+
+#include <linux/types.h>
+#include <linux/ioctl.h>
+
+#define PKA_IOC_TYPE 0xB7
+
+/// PKA_RING_GET_REGION_INFO - _IORW(PKA_IOC_TYPE, 0x0, pka_dev_region_info_t)
+///
+/// Retrieve information about a device region. This is intended to describe
+/// MMIO, I/O port, as well as bus specific regions (ex. PCI config space).
+/// Zero sized regions may be used to describe unimplemented regions.
+/// Return: 0 on success, -errno on failure.
+typedef struct
+{
+ uint32_t reg_index; ///< Registers region index.
+ uint64_t reg_size; ///< Registers region size (bytes).
+ uint64_t reg_offset; ///< Registers region offset from start of device fd.
+
+ uint32_t mem_index; ///< Memory region index.
+ uint64_t mem_size; ///< Memory region size (bytes).
+ uint64_t mem_offset; ///< Memeory region offset from start of device fd.
+} pka_dev_region_info_t;
+#define PKA_RING_GET_REGION_INFO _IOWR(PKA_IOC_TYPE, 0x0, pka_dev_region_info_t)
+
+/// PKA_GET_RING_INFO - _IORW(PKA_IOC_TYPE, 0x1, pka_dev_ring_info_t)
+///
+/// Retrieve information about a ring. This is intended to describe ring
+/// information words located in PKA_BUFFER_RAM. Ring information includes
+/// base addresses, size and statistics.
+/// Return: 0 on success, -errno on failure.
+typedef struct // Bluefield specific ring information
+{
+ /// Base address of the command descriptor ring.
+ uint64_t cmmd_base;
+
+ /// Base address of the result descriptor ring.
+ uint64_t rslt_base;
+
+ /// Size of a command ring in number of descriptors, minus 1.
+ /// Minimum value is 0 (for 1 descriptor); maximum value is
+ /// 65535 (for 64K descriptors).
+ uint16_t size;
+
+ /// This field specifies the size (in 32-bit words) of the
+ /// space that PKI command and result descriptor occupies on
+ /// the Host.
+ uint16_t host_desc_size : 10;
+
+ /// Indicates whether the result ring delivers results strictly
+ /// in-order ('1') or that result descriptors are written to the
+ /// result ring as soon as they become available, so out-of-order
+ /// ('0').
+ uint8_t in_order : 1;
+
+ /// Read pointer of the command descriptor ring.
+ uint16_t cmmd_rd_ptr;
+
+ /// Write pointer of the result descriptor ring.
+ uint16_t rslt_wr_ptr;
+
+ /// Read statistics of the command descriptor ring.
+ uint16_t cmmd_rd_stats;
+
+ /// Write statistics of the result descriptor ring.
+ uint16_t rslt_wr_stats;
+
+} pka_dev_hw_ring_info_t;
+#define PKA_GET_RING_INFO _IOWR(PKA_IOC_TYPE, 0x1, pka_dev_hw_ring_info_t)
+
+/// PKA_CLEAR_RING_COUNTERS - _IO(PKA_IOC_TYPE, 0x2)
+///
+/// Clear counters. This is intended to reset all command and result counters.
+/// Return: 0 on success, -errno on failure.
+#define PKA_CLEAR_RING_COUNTERS _IO(PKA_IOC_TYPE, 0x2)
+
+/// PKA_GET_RANDOM_BYTES - _IOWR(PKA_IOC_TYPE, 0x3, pka_dev_trng_info_t)
+///
+/// Get random bytes from True Random Number Generator(TRNG).
+/// Return: 0 on success, -errno on failure.
+typedef struct // True Random Number Generator information
+{
+ /// Number of random bytes in the buffer; Length of the buffer.
+ uint32_t count;
+
+ /// Data buffer to hold the random bytes.
+ uint8_t *data;
+
+} pka_dev_trng_info_t;
+#define PKA_GET_RANDOM_BYTES _IOWR(PKA_IOC_TYPE, 0x3, pka_dev_trng_info_t)
+
+#endif // __PKA_IOCTL_H__
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_mmio.h b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_mmio.h
new file mode 100644
index 000000000..c70823c2a
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_mmio.h
@@ -0,0 +1,49 @@
+//
+// BSD LICENSE
+//
+// Copyright(c) 2016 Mellanox Technologies, Ltd. All rights reserved.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in
+// the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Mellanox Technologies nor the names of its
+// contributors may be used to endorse or promote products derived
+// from this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+
+#ifndef __PKA_MMIO_H__
+#define __PKA_MMIO_H__
+
+
+/// Macros for standard MMIO functions.
+
+#include <linux/types.h>
+#include <linux/compiler.h>
+#include <linux/io.h>
+
+#define pka_mmio_read64(addr) readq_relaxed(addr)
+#define pka_mmio_write64(addr, val) writeq_relaxed((val), (addr))
+#define pka_mmio_read(addr) pka_mmio_read64(addr)
+#define pka_mmio_write(addr, val) pka_mmio_write64((addr), (val))
+
+#endif // __PKA_MMIO_H__
diff --git a/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_ring.h b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_ring.h
new file mode 100644
index 000000000..be56b61ee
--- /dev/null
+++ b/drivers/platform/mellanox/mlxbf_pka/mlxbf_pka_ring.h
@@ -0,0 +1,276 @@
+//
+// BSD LICENSE
+//
+// Copyright(c) 2016 Mellanox Technologies, Ltd. All rights reserved.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions
+// are met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above copyright
+// notice, this list of conditions and the following disclaimer in
+// the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Mellanox Technologies nor the names of its
+// contributors may be used to endorse or promote products derived
+// from this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+//
+
+#ifndef __PKA_RING_H__
+#define __PKA_RING_H__
+
+///
+/// @file
+///
+/// This file forms an interface to the BlueField Public Key Accelerator based
+/// on EIP-154.
+///
+/// Rings are used as a communication mechanism between ARM cores (controller)
+/// and the farm engines controlled by EIP-154 master firmware.
+///
+/// Note that the API defines data stuctures and functions to manage rings
+/// within window RAM, and to enqueue/dequeue descriptors. Rings are considered
+/// as a memory of descriptors (command/result descriptors) using finite size
+/// circular queue and a couple of control status registers (count registers).
+///
+
+
+#include <linux/types.h>
+
+#ifdef PKA_LIB_RING_DEBUG
+// A structure that stores the ring statistics.
+typedef struct
+{
+ uint64_t enq_success_cmd; ///< Cmd descriptors successfully enqueued.
+ uint64_t enq_fail_cmd; ///< Cmd descriptors that failed to be enqueued.
+ uint64_t deq_success_rslt; ///< Rslt descriptors successfully dequeued.
+ uint64_t deq_fail_rslt; ///< Rslt descriptors that failed to be dequeued.
+} pka_ring_debug_stats __pka_cache_aligned;
+#endif
+
+#ifdef PKA_LIB_RING_DEBUG
+#define __RING_STAT_ADD(r, name, n) ({ ##r##->stats.##name += 1; })
+#else
+#define __RING_STAT_ADD(r, name, n) do {} while(0)
+#endif
+
+/// Bluefield PKA command descriptor.
+typedef struct // 64 bytes long. 64 bytes aligned
+{
+ uint64_t pointer_a;
+ uint64_t pointer_b;
+ uint64_t pointer_c;
+ uint64_t pointer_d;
+ uint64_t tag;
+ uint64_t pointer_e;
+
+#ifdef __AARCH64EB__
+ uint64_t linked : 1;
+ uint64_t driver_status : 2;
+ uint64_t odd_powers : 5; ///< shiftCnt for shift ops
+ uint64_t kdk : 2; ///< Key Decryption Key number
+ uint64_t encrypted_mask : 6;
+ uint64_t rsvd_3 : 8;
+ uint64_t command : 8;
+ uint64_t rsvd_2 : 5;
+ uint64_t length_b : 9;
+ uint64_t output_attr : 1;
+ uint64_t input_attr : 1;
+ uint64_t rsvd_1 : 5;
+ uint64_t length_a : 9;
+ uint64_t rsvd_0 : 2;
+#else
+ uint64_t rsvd_0 : 2;
+ uint64_t length_a : 9;
+ uint64_t rsvd_1 : 5;
+ uint64_t input_attr : 1;
+ uint64_t output_attr : 1;
+ uint64_t length_b : 9;
+ uint64_t rsvd_2 : 5;
+ uint64_t command : 8;
+ uint64_t rsvd_3 : 8;
+ uint64_t encrypted_mask : 6;
+ uint64_t kdk : 2; ///< Key Decryption Key number
+ uint64_t odd_powers : 5; ///< shiftCnt for shift ops
+ uint64_t driver_status : 2;
+ uint64_t linked : 1;
+#endif
+
+ uint64_t rsvd_4;
+} pka_ring_hw_cmd_desc_t;
+
+#define CMD_DESC_SIZE sizeof(pka_ring_hw_cmd_desc_t) // Must be 64
+
+/// Bluefield PKA result descriptor.
+typedef struct // 64 bytes long. 64 bytes aligned
+{
+ uint64_t pointer_a;
+ uint64_t pointer_b;
+ uint64_t pointer_c;
+ uint64_t pointer_d;
+ uint64_t tag;
+
+#ifdef __AARCH64EB__
+ uint64_t rsvd_5 : 13;
+ uint64_t cmp_result : 3;
+ uint64_t modulo_is_0 : 1;
+ uint64_t rsvd_4 : 2;
+ uint64_t modulo_msw_offset : 11;
+ uint64_t rsvd_3 : 2;
+ uint64_t rsvd_2 : 11;
+ uint64_t main_result_msb_offset : 5;
+ uint64_t result_is_0 : 1;
+ uint64_t rsvd_1 : 2;
+ uint64_t main_result_msw_offset : 11;
+ uint64_t rsvd_0 : 2;
+
+ uint64_t linked : 1;
+ uint64_t driver_status : 2; ///< Always written to 0
+ uint64_t odd_powers : 5; ///< shiftCnt for shift ops
+ uint64_t kdk : 2; ///< Key Decryption Key number
+ uint64_t encrypted_mask : 6;
+ uint64_t result_code : 8;
+ uint64_t command : 8;
+ uint64_t rsvd_8 : 5;
+ uint64_t length_b : 9;
+ uint64_t output_attr : 1;
+ uint64_t input_attr : 1;
+ uint64_t rsvd_7 : 5;
+ uint64_t length_a : 9;
+ uint64_t rsvd_6 : 2;
+#else
+ uint64_t rsvd_0 : 2;
+ uint64_t main_result_msw_offset : 11;
+ uint64_t rsvd_1 : 2;
+ uint64_t result_is_0 : 1;
+ uint64_t main_result_msb_offset : 5;
+ uint64_t rsvd_2 : 11;
+ uint64_t rsvd_3 : 2;
+ uint64_t modulo_msw_offset : 11;
+ uint64_t rsvd_4 : 2;
+ uint64_t modulo_is_0 : 1;
+ uint64_t cmp_result : 3;
+ uint64_t rsvd_5 : 13;
+
+ uint64_t rsvd_6 : 2;
+ uint64_t length_a : 9;
+ uint64_t rsvd_7 : 5;
+ uint64_t input_attr : 1;
+ uint64_t output_attr : 1;
+ uint64_t length_b : 9;
+ uint64_t rsvd_8 : 5;
+ uint64_t command : 8;
+ uint64_t result_code : 8;
+ uint64_t encrypted_mask : 6;
+ uint64_t kdk : 2; ///< Key Decryption Key number
+ uint64_t odd_powers : 5; ///< shiftCnt for shift ops
+ uint64_t driver_status : 2; ///< Always written to 0
+ uint64_t linked : 1;
+#endif
+
+ uint64_t rsvd_9;
+} pka_ring_hw_rslt_desc_t;
+
+#define RESULT_DESC_SIZE sizeof(pka_ring_hw_rslt_desc_t) // Must be 64
+
+/// Describes a PKA command/result ring as used by the hardware. A pair of
+/// command and result rings in PKA window memory, and the data memory used
+/// by the commands.
+typedef struct
+{
+ uint32_t num_descs; ///< total number of descriptors in the ring.
+
+ uint32_t cmd_ring_base; ///< base address of the command ring.
+ uint32_t cmd_idx; ///< index of the command in a ring.
+
+ uint32_t rslt_ring_base; ///< base address of the result ring.
+ uint32_t rslt_idx; ///< index of the result in a ring.
+
+ uint32_t operands_base; ///< operands memory base address.
+ uint32_t operands_end; ///< end address of operands memory.
+
+ uint32_t desc_size; ///< size of each element in the ring.
+
+ uint64_t cmd_desc_mask; ///< bitmask of free(0)/in_use(1) cmd descriptors.
+ uint32_t cmd_desc_cnt; ///< number of command descriptors currently in use.
+ uint32_t rslt_desc_cnt; ///< number of result descriptors currently ready.
+} pka_ring_desc_t;
+
+/// This structure declares ring parameters which can be used by user interface.
+typedef struct
+{
+ int fd; ///< file descriptor.
+ int group; ///< iommu group.
+ int container; ///< vfio cointainer
+
+ uint32_t idx; ///< ring index.
+ uint32_t ring_id; ///< hardware ring identifier.
+
+ uint64_t mem_off; ///< offset specific to window RAM region.
+ uint64_t mem_addr; ///< window RAM region address.
+ uint64_t mem_size; ///< window RAM region size.
+
+ uint64_t reg_off; ///< offset specific to count registers region.
+ uint64_t reg_addr; ///< count registers region address.
+ uint64_t reg_size; ///< count registers region size.
+
+ void *mem_ptr; ///< pointer to map-ped memory region.
+ void *reg_ptr; ///< pointer to map-ped counters region.
+
+ pka_ring_desc_t ring_desc; ///< ring descriptor.
+
+#ifdef PKA_LIB_RING_DEBUG
+ struct pka_ring_debug_stats stats;
+#endif
+
+ uint8_t big_endian; ///< big endian byte order when enabled.
+} pka_ring_info_t;
+
+typedef struct
+{
+ uint32_t dst_offset; ///< operands desctination offset.
+ uint32_t max_dst_offset; ///< operands end offset.
+
+ pka_ring_info_t *ring;
+} pka_ring_alloc_t;
+
+// This sturcture encapsulates 'user data' information, it also includes
+// additional information useful for command processing and statistics.
+typedef struct
+{
+ uint64_t valid; ///< if set to 'PKA_UDATA_INFO_VALID' then info is valid
+ uint64_t user_data; ///< opaque user address.
+ uint64_t cmd_num; ///< command request number.
+ uint8_t cmd_desc_idx; ///< index of the cmd descriptor in HW rings
+ uint8_t ring_num; ///< command request number.
+ uint8_t queue_num; ///< queue number.
+} pka_udata_info_t;
+
+#define PKA_UDATA_INFO_VALID 0xDEADBEEF
+
+// This structure consists of a data base to store user data information.
+// Note that a data base should be associated with a hardware ring.
+typedef struct
+{
+ pka_udata_info_t entries[32]; // user data information entries.
+ uint8_t index : 5; // entry index. Wrapping is permitted.
+} pka_udata_db_t;
+
+#endif /// __PKA_RING_H__
+
+
--
2.20.1