diff options
author | Trygve Laugstøl <trygvis@inamo.no> | 2018-08-23 17:08:59 +0200 |
---|---|---|
committer | Trygve Laugstøl <trygvis@inamo.no> | 2018-08-23 17:12:21 +0200 |
commit | 3061ecca3d0fdfb87dabbf5f63c9e06c2a30f53a (patch) | |
tree | ab49cc16ed0b853452c5c2ed2d3042416d628986 /thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132 | |
download | iot-sensors-master.tar.gz iot-sensors-master.tar.bz2 iot-sensors-master.tar.xz iot-sensors-master.zip |
Diffstat (limited to 'thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132')
26 files changed, 18028 insertions, 0 deletions
diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/doc/s132_nrf52_6.0.0_licence-agreement.txt b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/doc/s132_nrf52_6.0.0_licence-agreement.txt new file mode 100644 index 0000000..a71adee --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/doc/s132_nrf52_6.0.0_licence-agreement.txt @@ -0,0 +1,35 @@ +Copyright (c) 2007 - 2018, Nordic Semiconductor ASA +All rights reserved. + +Redistribution and use in source and binary forms, with or without modification, +are permitted provided that the following conditions are met: + +1. Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + +2. Redistributions in binary form, except as embedded into a Nordic + Semiconductor ASA integrated circuit in a product or a software update for + such product, 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. + +3. Neither the name of Nordic Semiconductor ASA nor the names of its + contributors may be used to endorse or promote products derived from this + software without specific prior written permission. + +4. This software, with or without modification, must only be used with a + Nordic Semiconductor ASA integrated circuit. + +5. Any software provided in binary form under this license must not be reverse + engineered, decompiled, modified and/or disassembled. + +THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS +OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES +OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/doc/s132_nrf52_6.0.0_migration-document.pdf b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/doc/s132_nrf52_6.0.0_migration-document.pdf Binary files differnew file mode 100644 index 0000000..e88cd69 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/doc/s132_nrf52_6.0.0_migration-document.pdf diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/doc/s132_nrf52_6.0.0_release-notes.pdf b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/doc/s132_nrf52_6.0.0_release-notes.pdf Binary files differnew file mode 100644 index 0000000..827c06b --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/doc/s132_nrf52_6.0.0_release-notes.pdf diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble.h new file mode 100644 index 0000000..9ebb41f --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble.h @@ -0,0 +1,622 @@ +/* + * Copyright (c) 2012 - 2018, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup BLE_COMMON BLE SoftDevice Common + @{ + @defgroup ble_api Events, type definitions and API calls + @{ + + @brief Module independent events, type definitions and API calls for the BLE SoftDevice. + + */ + +#ifndef BLE_H__ +#define BLE_H__ + +#include <stdint.h> +#include "nrf_svc.h" +#include "nrf_error.h" +#include "ble_err.h" +#include "ble_gap.h" +#include "ble_l2cap.h" +#include "ble_gatt.h" +#include "ble_gattc.h" +#include "ble_gatts.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** @addtogroup BLE_COMMON_ENUMERATIONS Enumerations + * @{ */ + +/** + * @brief Common API SVC numbers. + */ +enum BLE_COMMON_SVCS +{ + SD_BLE_ENABLE = BLE_SVC_BASE, /**< Enable and initialize the BLE stack */ + SD_BLE_EVT_GET, /**< Get an event from the pending events queue. */ + SD_BLE_UUID_VS_ADD, /**< Add a Vendor Specific UUID. */ + SD_BLE_UUID_DECODE, /**< Decode UUID bytes. */ + SD_BLE_UUID_ENCODE, /**< Encode UUID bytes. */ + SD_BLE_VERSION_GET, /**< Get the local version information (company ID, Link Layer Version, Link Layer Subversion). */ + SD_BLE_USER_MEM_REPLY, /**< User Memory Reply. */ + SD_BLE_OPT_SET, /**< Set a BLE option. */ + SD_BLE_OPT_GET, /**< Get a BLE option. */ + SD_BLE_CFG_SET, /**< Add a configuration to the BLE stack. */ +}; + +/** + * @brief BLE Module Independent Event IDs. + */ +enum BLE_COMMON_EVTS +{ + BLE_EVT_USER_MEM_REQUEST = BLE_EVT_BASE + 0, /**< User Memory request. @ref ble_evt_user_mem_request_t */ + BLE_EVT_USER_MEM_RELEASE = BLE_EVT_BASE + 1, /**< User Memory release. @ref ble_evt_user_mem_release_t */ +}; + +/**@brief BLE Connection Configuration IDs. + * + * IDs that uniquely identify a connection configuration. + */ +enum BLE_CONN_CFGS +{ + BLE_CONN_CFG_GAP = BLE_CONN_CFG_BASE + 0, /**< BLE GAP specific connection configuration. */ + BLE_CONN_CFG_GATTC = BLE_CONN_CFG_BASE + 1, /**< BLE GATTC specific connection configuration. */ + BLE_CONN_CFG_GATTS = BLE_CONN_CFG_BASE + 2, /**< BLE GATTS specific connection configuration. */ + BLE_CONN_CFG_GATT = BLE_CONN_CFG_BASE + 3, /**< BLE GATT specific connection configuration. */ + BLE_CONN_CFG_L2CAP = BLE_CONN_CFG_BASE + 4, /**< BLE L2CAP specific connection configuration. */ +}; + +/**@brief BLE Common Configuration IDs. + * + * IDs that uniquely identify a common configuration. + */ +enum BLE_COMMON_CFGS +{ + BLE_COMMON_CFG_VS_UUID = BLE_CFG_BASE, /**< Vendor specific UUID configuration */ +}; + +/**@brief Common Option IDs. + * IDs that uniquely identify a common option. + */ +enum BLE_COMMON_OPTS +{ + BLE_COMMON_OPT_PA_LNA = BLE_OPT_BASE + 0, /**< PA and LNA options */ + BLE_COMMON_OPT_CONN_EVT_EXT = BLE_OPT_BASE + 1, /**< Extended connection events option */ +}; + +/** @} */ + +/** @addtogroup BLE_COMMON_DEFINES Defines + * @{ */ + +/** @brief Required pointer alignment for BLE Events. +*/ +#define BLE_EVT_PTR_ALIGNMENT 4 + +/** @brief Leaves the maximum of the two arguments. +*/ +#define BLE_MAX(a, b) ((a) < (b) ? (b) : (a)) + +/** @brief Maximum possible length for BLE Events. + * @note The highest value used for @ref ble_gatt_conn_cfg_t::att_mtu in any connection configuration shall be used as a parameter. + * If that value has not been configured for any connections then @ref BLE_GATT_ATT_MTU_DEFAULT must be used instead. +*/ +#define BLE_EVT_LEN_MAX(ATT_MTU) ( \ + offsetof(ble_evt_t, evt.gattc_evt.params.prim_srvc_disc_rsp.services) + ((ATT_MTU) - 1) / 4 * sizeof(ble_gattc_service_t) \ +) + +/** @defgroup BLE_USER_MEM_TYPES User Memory Types + * @{ */ +#define BLE_USER_MEM_TYPE_INVALID 0x00 /**< Invalid User Memory Types. */ +#define BLE_USER_MEM_TYPE_GATTS_QUEUED_WRITES 0x01 /**< User Memory for GATTS queued writes. */ +/** @} */ + +/** @defgroup BLE_UUID_VS_COUNTS Vendor Specific UUID counts + * @{ + */ +#define BLE_UUID_VS_COUNT_DEFAULT 10 /**< Default VS UUID count. */ +#define BLE_UUID_VS_COUNT_MAX 254 /**< Maximum VS UUID count. */ +/** @} */ + +/** @defgroup BLE_COMMON_CFG_DEFAULTS Configuration defaults. + * @{ + */ +#define BLE_CONN_CFG_TAG_DEFAULT 0 /**< Default configuration tag, SoftDevice default connection configuration. */ + +/** @} */ + +/** @} */ + +/** @addtogroup BLE_COMMON_STRUCTURES Structures + * @{ */ + +/**@brief User Memory Block. */ +typedef struct +{ + uint8_t *p_mem; /**< Pointer to the start of the user memory block. */ + uint16_t len; /**< Length in bytes of the user memory block. */ +} ble_user_mem_block_t; + +/**@brief Event structure for @ref BLE_EVT_USER_MEM_REQUEST. */ +typedef struct +{ + uint8_t type; /**< User memory type, see @ref BLE_USER_MEM_TYPES. */ +} ble_evt_user_mem_request_t; + +/**@brief Event structure for @ref BLE_EVT_USER_MEM_RELEASE. */ +typedef struct +{ + uint8_t type; /**< User memory type, see @ref BLE_USER_MEM_TYPES. */ + ble_user_mem_block_t mem_block; /**< User memory block */ +} ble_evt_user_mem_release_t; + +/**@brief Event structure for events not associated with a specific function module. */ +typedef struct +{ + uint16_t conn_handle; /**< Connection Handle on which this event occurred. */ + union + { + ble_evt_user_mem_request_t user_mem_request; /**< User Memory Request Event Parameters. */ + ble_evt_user_mem_release_t user_mem_release; /**< User Memory Release Event Parameters. */ + } params; /**< Event parameter union. */ +} ble_common_evt_t; + +/**@brief BLE Event header. */ +typedef struct +{ + uint16_t evt_id; /**< Value from a BLE_<module>_EVT series. */ + uint16_t evt_len; /**< Length in octets including this header. */ +} ble_evt_hdr_t; + +/**@brief Common BLE Event type, wrapping the module specific event reports. */ +typedef struct +{ + ble_evt_hdr_t header; /**< Event header. */ + union + { + ble_common_evt_t common_evt; /**< Common Event, evt_id in BLE_EVT_* series. */ + ble_gap_evt_t gap_evt; /**< GAP originated event, evt_id in BLE_GAP_EVT_* series. */ + ble_gattc_evt_t gattc_evt; /**< GATT client originated event, evt_id in BLE_GATTC_EVT* series. */ + ble_gatts_evt_t gatts_evt; /**< GATT server originated event, evt_id in BLE_GATTS_EVT* series. */ + ble_l2cap_evt_t l2cap_evt; /**< L2CAP originated event, evt_id in BLE_L2CAP_EVT* series. */ + } evt; /**< Event union. */ +} ble_evt_t; + + +/** + * @brief Version Information. + */ +typedef struct +{ + uint8_t version_number; /**< Link Layer Version number. See https://www.bluetooth.org/en-us/specification/assigned-numbers/link-layer for assigned values. */ + uint16_t company_id; /**< Company ID, Nordic Semiconductor's company ID is 89 (0x0059) (https://www.bluetooth.org/apps/content/Default.aspx?doc_id=49708). */ + uint16_t subversion_number; /**< Link Layer Sub Version number, corresponds to the SoftDevice Config ID or Firmware ID (FWID). */ +} ble_version_t; + +/** + * @brief Configuration parameters for the PA and LNA. + */ +typedef struct +{ + uint8_t enable :1; /**< Enable toggling for this amplifier */ + uint8_t active_high :1; /**< Set the pin to be active high */ + uint8_t gpio_pin :6; /**< The GPIO pin to toggle for this amplifier */ +} ble_pa_lna_cfg_t; + +/** + * @brief PA & LNA GPIO toggle configuration + * + * This option configures the SoftDevice to toggle pins when the radio is active for use with a power amplifier and/or + * a low noise amplifier. + * + * Toggling the pins is achieved by using two PPI channels and a GPIOTE channel. The hardware channel IDs are provided + * by the application and should be regarded as reserved as long as any PA/LNA toggling is enabled. + * + * @note @ref sd_ble_opt_get is not supported for this option. + * @note Setting this option while the radio is in use (i.e. any of the roles are active) may have undefined consequences + * and must be avoided by the application. + */ +typedef struct +{ + ble_pa_lna_cfg_t pa_cfg; /**< Power Amplifier configuration */ + ble_pa_lna_cfg_t lna_cfg; /**< Low Noise Amplifier configuration */ + + uint8_t ppi_ch_id_set; /**< PPI channel used for radio pin setting */ + uint8_t ppi_ch_id_clr; /**< PPI channel used for radio pin clearing */ + uint8_t gpiote_ch_id; /**< GPIOTE channel used for radio pin toggling */ +} ble_common_opt_pa_lna_t; + +/** + * @brief Configuration of extended BLE connection events. + * + * When enabled the SoftDevice will dynamically extend the connection event when possible. + * + * The connection event length is controlled by the connection configuration as set by @ref ble_gap_conn_cfg_t::event_length. + * The connection event can be extended if there is time to send another packet pair before the start of the next connection interval, + * and if there are no conflicts with other BLE roles requesting radio time. + * + * @note @ref sd_ble_opt_get is not supported for this option. + */ +typedef struct +{ + uint8_t enable : 1; /**< Enable extended BLE connection events, disabled by default. */ +} ble_common_opt_conn_evt_ext_t; + +/**@brief Option structure for common options. */ +typedef union +{ + ble_common_opt_pa_lna_t pa_lna; /**< Parameters for controlling PA and LNA pin toggling. */ + ble_common_opt_conn_evt_ext_t conn_evt_ext; /**< Parameters for enabling extended connection events. */ +} ble_common_opt_t; + +/**@brief Common BLE Option type, wrapping the module specific options. */ +typedef union +{ + ble_common_opt_t common_opt; /**< COMMON options, opt_id in @ref BLE_COMMON_OPTS series. */ + ble_gap_opt_t gap_opt; /**< GAP option, opt_id in @ref BLE_GAP_OPTS series. */ +} ble_opt_t; + +/**@brief BLE connection configuration type, wrapping the module specific configurations, set with + * @ref sd_ble_cfg_set. + * + * @note Connection configurations don't have to be set. + * In the case that no configurations has been set, or fewer connection configurations has been set than enabled connections, + * the default connection configuration will be automatically added for the remaining connections. + * When creating connections with the default configuration, @ref BLE_CONN_CFG_TAG_DEFAULT should be used in + * place of @ref ble_conn_cfg_t::conn_cfg_tag. + * + * @sa sd_ble_gap_adv_start() + * @sa sd_ble_gap_connect() + * + * @mscs + * @mmsc{@ref BLE_CONN_CFG} + * @endmscs + + */ +typedef struct +{ + uint8_t conn_cfg_tag; /**< The application chosen tag it can use with the + @ref sd_ble_gap_adv_start() and @ref sd_ble_gap_connect() calls + to select this configuration when creating a connection. + Must be different for all connection configurations added and not @ref BLE_CONN_CFG_TAG_DEFAULT. */ + union { + ble_gap_conn_cfg_t gap_conn_cfg; /**< GAP connection configuration, cfg_id is @ref BLE_CONN_CFG_GAP. */ + ble_gattc_conn_cfg_t gattc_conn_cfg; /**< GATTC connection configuration, cfg_id is @ref BLE_CONN_CFG_GATTC. */ + ble_gatts_conn_cfg_t gatts_conn_cfg; /**< GATTS connection configuration, cfg_id is @ref BLE_CONN_CFG_GATTS. */ + ble_gatt_conn_cfg_t gatt_conn_cfg; /**< GATT connection configuration, cfg_id is @ref BLE_CONN_CFG_GATT. */ + ble_l2cap_conn_cfg_t l2cap_conn_cfg; /**< L2CAP connection configuration, cfg_id is @ref BLE_CONN_CFG_L2CAP. */ + } params; /**< Connection configuration union. */ +} ble_conn_cfg_t; + +/** + * @brief Configuration of Vendor Specific UUIDs, set with @ref sd_ble_cfg_set. + * + * @retval ::NRF_ERROR_INVALID_PARAM Too many UUIDs configured. + */ +typedef struct +{ + uint8_t vs_uuid_count; /**< Number of 128-bit Vendor Specific UUID bases to allocate memory for. + Default value is @ref BLE_UUID_VS_COUNT_DEFAULT. Maximum value is + @ref BLE_UUID_VS_COUNT_MAX. */ +} ble_common_cfg_vs_uuid_t; + +/**@brief Common BLE Configuration type, wrapping the common configurations. */ +typedef union +{ + ble_common_cfg_vs_uuid_t vs_uuid_cfg; /**< Vendor specific UUID configuration, cfg_id is @ref BLE_COMMON_CFG_VS_UUID. */ +} ble_common_cfg_t; + +/**@brief BLE Configuration type, wrapping the module specific configurations. */ +typedef union +{ + ble_conn_cfg_t conn_cfg; /**< Connection specific configurations, cfg_id in @ref BLE_CONN_CFGS series. */ + ble_common_cfg_t common_cfg; /**< Global common configurations, cfg_id in @ref BLE_COMMON_CFGS series. */ + ble_gap_cfg_t gap_cfg; /**< Global GAP configurations, cfg_id in @ref BLE_GAP_CFGS series. */ + ble_gatts_cfg_t gatts_cfg; /**< Global GATTS configuration, cfg_id in @ref BLE_GATTS_CFGS series. */ +} ble_cfg_t; + +/** @} */ + +/** @addtogroup BLE_COMMON_FUNCTIONS Functions + * @{ */ + +/**@brief Enable the BLE stack + * + * @param[in, out] p_app_ram_base Pointer to a variable containing the start address of the + * application RAM region (APP_RAM_BASE). On return, this will + * contain the minimum start address of the application RAM region + * required by the SoftDevice for this configuration. + * + * @note The memory requirement for a specific configuration will not increase between SoftDevices + * with the same major version number. + * + * @note The value of *p_app_ram_base when the app has done no custom configuration of the + * SoftDevice, i.e. the app has not called @ref sd_ble_cfg_set before @ref sd_ble_enable, can + * be found in the release notes. + * + * @note At runtime the IC's RAM is split into 2 regions: The SoftDevice RAM region is located + * between 0x20000000 and APP_RAM_BASE-1 and the application's RAM region is located between + * APP_RAM_BASE and the start of the call stack. + * + * @details This call initializes the BLE stack, no BLE related function other than @ref + * sd_ble_cfg_set can be called before this one. + * + * @mscs + * @mmsc{@ref BLE_COMMON_ENABLE} + * @endmscs + * + * @retval ::NRF_SUCCESS The BLE stack has been initialized successfully. + * @retval ::NRF_ERROR_INVALID_STATE The BLE stack had already been initialized and cannot be reinitialized. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid or not sufficiently aligned pointer supplied. + * @retval ::NRF_ERROR_NO_MEM The amount of memory assigned to the SoftDevice by *p_app_ram_base is not + * large enough to fit this configuration's memory requirement. Check *p_app_ram_base + * and set the start address of the application RAM region accordingly. + */ +SVCALL(SD_BLE_ENABLE, uint32_t, sd_ble_enable(uint32_t * p_app_ram_base)); + +/**@brief Add configurations for the BLE stack + * + * @param[in] cfg_id Config ID, see @ref BLE_CONN_CFGS, @ref BLE_COMMON_CFGS, @ref + * BLE_GAP_CFGS or @ref BLE_GATTS_CFGS. + * @param[in] p_cfg Pointer to a ble_cfg_t structure containing the configuration value. + * @param[in] app_ram_base The start address of the application RAM region (APP_RAM_BASE). + * See @ref sd_ble_enable for details about APP_RAM_BASE. + * + * @note The memory requirement for a specific configuration will not increase between SoftDevices + * with the same major version number. + * + * @note If a configuration is set more than once, the last one set is the one that takes effect on + * @ref sd_ble_enable. + * + * @note Any part of the BLE stack that is NOT configured with @ref sd_ble_cfg_set will have default + * configuration. + * + * @note @ref sd_ble_cfg_set may be called at any time when the SoftDevice is enabled (see @ref + * sd_softdevice_enable) while the BLE part of the SoftDevice is not enabled (see @ref + * sd_ble_enable). + * + * @note Error codes for the configurations are described in the configuration structs. + * + * @mscs + * @mmsc{@ref BLE_COMMON_ENABLE} + * @endmscs + * + * @retval ::NRF_SUCCESS The configuration has been added successfully. + * @retval ::NRF_ERROR_INVALID_STATE The BLE stack had already been initialized. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid or not sufficiently aligned pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid cfg_id supplied. + * @retval ::NRF_ERROR_NO_MEM The amount of memory assigned to the SoftDevice by app_ram_base is not + * large enough to fit this configuration's memory requirement. + */ +SVCALL(SD_BLE_CFG_SET, uint32_t, sd_ble_cfg_set(uint32_t cfg_id, ble_cfg_t const * p_cfg, uint32_t app_ram_base)); + +/**@brief Get an event from the pending events queue. + * + * @param[out] p_dest Pointer to buffer to be filled in with an event, or NULL to retrieve the event length. + * This buffer <b>must be aligned to the extend defined by @ref BLE_EVT_PTR_ALIGNMENT</b>. + * The buffer should be interpreted as a @ref ble_evt_t struct. + * @param[in, out] p_len Pointer the length of the buffer, on return it is filled with the event length. + * + * @details This call allows the application to pull a BLE event from the BLE stack. The application is signaled that + * an event is available from the BLE stack by the triggering of the SD_EVT_IRQn interrupt. + * The application is free to choose whether to call this function from thread mode (main context) or directly from the + * Interrupt Service Routine that maps to SD_EVT_IRQn. In any case however, and because the BLE stack runs at a higher + * priority than the application, this function should be called in a loop (until @ref NRF_ERROR_NOT_FOUND is returned) + * every time SD_EVT_IRQn is raised to ensure that all available events are pulled from the BLE stack. Failure to do so + * could potentially leave events in the internal queue without the application being aware of this fact. + * + * Sizing the p_dest buffer is equally important, since the application needs to provide all the memory necessary for the event to + * be copied into application memory. If the buffer provided is not large enough to fit the entire contents of the event, + * @ref NRF_ERROR_DATA_SIZE will be returned and the application can then call again with a larger buffer size. + * The maximum possible event length is defined by @ref BLE_EVT_LEN_MAX. The application may also "peek" the event length + * by providing p_dest as a NULL pointer and inspecting the value of *p_len upon return: + * + * \code + * uint16_t len; + * errcode = sd_ble_evt_get(NULL, &len); + * \endcode + * + * @mscs + * @mmsc{@ref BLE_COMMON_IRQ_EVT_MSC} + * @mmsc{@ref BLE_COMMON_THREAD_EVT_MSC} + * @endmscs + * + * @retval ::NRF_SUCCESS Event pulled and stored into the supplied buffer. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid or not sufficiently aligned pointer supplied. + * @retval ::NRF_ERROR_NOT_FOUND No events ready to be pulled. + * @retval ::NRF_ERROR_DATA_SIZE Event ready but could not fit into the supplied buffer. + */ +SVCALL(SD_BLE_EVT_GET, uint32_t, sd_ble_evt_get(uint8_t *p_dest, uint16_t *p_len)); + + +/**@brief Add a Vendor Specific base UUID. + * + * @details This call enables the application to add a vendor specific base UUID to the BLE stack's table, for later + * use with all other modules and APIs. This then allows the application to use the shorter, 24-bit @ref ble_uuid_t + * format when dealing with both 16-bit and 128-bit UUIDs without having to check for lengths and having split code + * paths. This is accomplished by extending the grouping mechanism that the Bluetooth SIG standard base UUID uses + * for all other 128-bit UUIDs. The type field in the @ref ble_uuid_t structure is an index (relative to + * @ref BLE_UUID_TYPE_VENDOR_BEGIN) to the table populated by multiple calls to this function, and the UUID field + * in the same structure contains the 2 bytes at indexes 12 and 13. The number of possible 128-bit UUIDs available to + * the application is therefore the number of Vendor Specific UUIDs added with the help of this function times 65536, + * although restricted to modifying bytes 12 and 13 for each of the entries in the supplied array. + * + * @note Bytes 12 and 13 of the provided UUID will not be used internally, since those are always replaced by + * the 16-bit uuid field in @ref ble_uuid_t. + * + * @note If a UUID is already present in the BLE stack's internal table, the corresponding index will be returned in + * p_uuid_type along with an @ref NRF_SUCCESS error code. + * + * @param[in] p_vs_uuid Pointer to a 16-octet (128-bit) little endian Vendor Specific UUID disregarding + * bytes 12 and 13. + * @param[out] p_uuid_type Pointer to a uint8_t where the type field in @ref ble_uuid_t corresponding to this UUID will be stored. + * + * @retval ::NRF_SUCCESS Successfully added the Vendor Specific UUID. + * @retval ::NRF_ERROR_INVALID_ADDR If p_vs_uuid or p_uuid_type is NULL or invalid. + * @retval ::NRF_ERROR_NO_MEM If there are no more free slots for VS UUIDs. + */ +SVCALL(SD_BLE_UUID_VS_ADD, uint32_t, sd_ble_uuid_vs_add(ble_uuid128_t const *p_vs_uuid, uint8_t *p_uuid_type)); + + +/** @brief Decode little endian raw UUID bytes (16-bit or 128-bit) into a 24 bit @ref ble_uuid_t structure. + * + * @details The raw UUID bytes excluding bytes 12 and 13 (i.e. bytes 0-11 and 14-15) of p_uuid_le are compared + * to the corresponding ones in each entry of the table of vendor specific UUIDs populated with @ref sd_ble_uuid_vs_add + * to look for a match. If there is such a match, bytes 12 and 13 are returned as p_uuid->uuid and the index + * relative to @ref BLE_UUID_TYPE_VENDOR_BEGIN as p_uuid->type. + * + * @note If the UUID length supplied is 2, then the type set by this call will always be @ref BLE_UUID_TYPE_BLE. + * + * @param[in] uuid_le_len Length in bytes of the buffer pointed to by p_uuid_le (must be 2 or 16 bytes). + * @param[in] p_uuid_le Pointer pointing to little endian raw UUID bytes. + * @param[out] p_uuid Pointer to a @ref ble_uuid_t structure to be filled in. + * + * @retval ::NRF_SUCCESS Successfully decoded into the @ref ble_uuid_t structure. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_LENGTH Invalid UUID length. + * @retval ::NRF_ERROR_NOT_FOUND For a 128-bit UUID, no match in the populated table of UUIDs. + */ +SVCALL(SD_BLE_UUID_DECODE, uint32_t, sd_ble_uuid_decode(uint8_t uuid_le_len, uint8_t const *p_uuid_le, ble_uuid_t *p_uuid)); + + +/** @brief Encode a @ref ble_uuid_t structure into little endian raw UUID bytes (16-bit or 128-bit). + * + * @note The pointer to the destination buffer p_uuid_le may be NULL, in which case only the validity and size of p_uuid is computed. + * + * @param[in] p_uuid Pointer to a @ref ble_uuid_t structure that will be encoded into bytes. + * @param[out] p_uuid_le_len Pointer to a uint8_t that will be filled with the encoded length (2 or 16 bytes). + * @param[out] p_uuid_le Pointer to a buffer where the little endian raw UUID bytes (2 or 16) will be stored. + * + * @retval ::NRF_SUCCESS Successfully encoded into the buffer. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid UUID type. + */ +SVCALL(SD_BLE_UUID_ENCODE, uint32_t, sd_ble_uuid_encode(ble_uuid_t const *p_uuid, uint8_t *p_uuid_le_len, uint8_t *p_uuid_le)); + + +/**@brief Get Version Information. + * + * @details This call allows the application to get the BLE stack version information. + * + * @param[out] p_version Pointer to a ble_version_t structure to be filled in. + * + * @retval ::NRF_SUCCESS Version information stored successfully. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_BUSY The BLE stack is busy (typically doing a locally-initiated disconnection procedure). + */ +SVCALL(SD_BLE_VERSION_GET, uint32_t, sd_ble_version_get(ble_version_t *p_version)); + + +/**@brief Provide a user memory block. + * + * @note This call can only be used as a response to a @ref BLE_EVT_USER_MEM_REQUEST event issued to the application. + * + * @param[in] conn_handle Connection handle. + * @param[in] p_block Pointer to a user memory block structure or NULL if memory is managed by the application. + * + * @mscs + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_PEER_CANCEL_MSC} + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_NOBUF_AUTH_MSC} + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_NOBUF_NOAUTH_MSC} + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_BUF_AUTH_MSC} + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_BUF_NOAUTH_MSC} + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_QUEUE_FULL_MSC} + * @endmscs + * + * @retval ::NRF_SUCCESS Successfully queued a response to the peer. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_BUSY The stack is busy, process pending events and retry. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_LENGTH Invalid user memory block length supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection state or no user memory request pending. + */ +SVCALL(SD_BLE_USER_MEM_REPLY, uint32_t, sd_ble_user_mem_reply(uint16_t conn_handle, ble_user_mem_block_t const *p_block)); + +/**@brief Set a BLE option. + * + * @details This call allows the application to set the value of an option. + * + * @mscs + * @mmsc{@ref BLE_GAP_PERIPH_BONDING_STATIC_PK_MSC} + * @endmscs + * + * @param[in] opt_id Option ID, see @ref BLE_COMMON_OPTS and @ref BLE_GAP_OPTS. + * @param[in] p_opt Pointer to a ble_opt_t structure containing the option value. + * + * @retval ::NRF_SUCCESS Option set successfully. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied, check parameter limits and constraints. + * @retval ::NRF_ERROR_INVALID_STATE Unable to set the parameter at this time. + * @retval ::NRF_ERROR_BUSY The BLE stack is busy or the previous procedure has not completed. + */ +SVCALL(SD_BLE_OPT_SET, uint32_t, sd_ble_opt_set(uint32_t opt_id, ble_opt_t const *p_opt)); + + +/**@brief Get a BLE option. + * + * @details This call allows the application to retrieve the value of an option. + * + * @param[in] opt_id Option ID, see @ref BLE_COMMON_OPTS and @ref BLE_GAP_OPTS. + * @param[out] p_opt Pointer to a ble_opt_t structure to be filled in. + * + * @retval ::NRF_SUCCESS Option retrieved successfully. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied, check parameter limits and constraints. + * @retval ::NRF_ERROR_INVALID_STATE Unable to retrieve the parameter at this time. + * @retval ::NRF_ERROR_BUSY The BLE stack is busy or the previous procedure has not completed. + * @retval ::NRF_ERROR_NOT_SUPPORTED This option is not supported. + * + */ +SVCALL(SD_BLE_OPT_GET, uint32_t, sd_ble_opt_get(uint32_t opt_id, ble_opt_t *p_opt)); + +/** @} */ +#ifdef __cplusplus +} +#endif +#endif /* BLE_H__ */ + +/** + @} + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_err.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_err.h new file mode 100644 index 0000000..1b4820d --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_err.h @@ -0,0 +1,93 @@ +/* + * Copyright (c) 2012 - 2018, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup BLE_COMMON + @{ + @addtogroup nrf_error + @{ + @ingroup BLE_COMMON + @} + + @defgroup ble_err General error codes + @{ + + @brief General error code definitions for the BLE API. + + @ingroup BLE_COMMON +*/ +#ifndef NRF_BLE_ERR_H__ +#define NRF_BLE_ERR_H__ + +#include "nrf_error.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/* @defgroup BLE_ERRORS Error Codes + * @{ */ +#define BLE_ERROR_NOT_ENABLED (NRF_ERROR_STK_BASE_NUM+0x001) /**< @ref sd_ble_enable has not been called. */ +#define BLE_ERROR_INVALID_CONN_HANDLE (NRF_ERROR_STK_BASE_NUM+0x002) /**< Invalid connection handle. */ +#define BLE_ERROR_INVALID_ATTR_HANDLE (NRF_ERROR_STK_BASE_NUM+0x003) /**< Invalid attribute handle. */ +#define BLE_ERROR_INVALID_ADV_HANDLE (NRF_ERROR_STK_BASE_NUM+0x004) /**< Invalid advertising handle. */ +#define BLE_ERROR_INVALID_ROLE (NRF_ERROR_STK_BASE_NUM+0x005) /**< Invalid role. */ +#define BLE_ERROR_BLOCKED_BY_OTHER_LINKS (NRF_ERROR_STK_BASE_NUM+0x006) /**< The attempt to change link settings failed due to the scheduling of other links. */ +/** @} */ + + +/** @defgroup BLE_ERROR_SUBRANGES Module specific error code subranges + * @brief Assignment of subranges for module specific error codes. + * @note For specific error codes, see ble_<module>.h or ble_error_<module>.h. + * @{ */ +#define NRF_L2CAP_ERR_BASE (NRF_ERROR_STK_BASE_NUM+0x100) /**< L2CAP specific errors. */ +#define NRF_GAP_ERR_BASE (NRF_ERROR_STK_BASE_NUM+0x200) /**< GAP specific errors. */ +#define NRF_GATTC_ERR_BASE (NRF_ERROR_STK_BASE_NUM+0x300) /**< GATT client specific errors. */ +#define NRF_GATTS_ERR_BASE (NRF_ERROR_STK_BASE_NUM+0x400) /**< GATT server specific errors. */ +/** @} */ + +#ifdef __cplusplus +} +#endif +#endif + + +/** + @} + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gap.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gap.h new file mode 100644 index 0000000..8b13816 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gap.h @@ -0,0 +1,2653 @@ +/* + * Copyright (c) 2011 - 2018, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup BLE_GAP Generic Access Profile (GAP) + @{ + @brief Definitions and prototypes for the GAP interface. + */ + +#ifndef BLE_GAP_H__ +#define BLE_GAP_H__ + +#include <stdint.h> +#include "nrf_svc.h" +#include "nrf_error.h" +#include "ble_hci.h" +#include "ble_ranges.h" +#include "ble_types.h" +#include "ble_err.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/**@addtogroup BLE_GAP_ENUMERATIONS Enumerations + * @{ */ + +/**@brief GAP API SVC numbers. + */ +enum BLE_GAP_SVCS +{ + SD_BLE_GAP_ADDR_SET = BLE_GAP_SVC_BASE, /**< Set own Bluetooth Address. */ + SD_BLE_GAP_ADDR_GET = BLE_GAP_SVC_BASE + 1, /**< Get own Bluetooth Address. */ + SD_BLE_GAP_WHITELIST_SET = BLE_GAP_SVC_BASE + 2, /**< Set active whitelist. */ + SD_BLE_GAP_DEVICE_IDENTITIES_SET = BLE_GAP_SVC_BASE + 3, /**< Set device identity list. */ + SD_BLE_GAP_PRIVACY_SET = BLE_GAP_SVC_BASE + 4, /**< Set Privacy settings*/ + SD_BLE_GAP_PRIVACY_GET = BLE_GAP_SVC_BASE + 5, /**< Get Privacy settings*/ + SD_BLE_GAP_ADV_SET_CONFIGURE = BLE_GAP_SVC_BASE + 6, /**< Configure an advertising set. */ + SD_BLE_GAP_ADV_START = BLE_GAP_SVC_BASE + 7, /**< Start Advertising. */ + SD_BLE_GAP_ADV_STOP = BLE_GAP_SVC_BASE + 8, /**< Stop Advertising. */ + SD_BLE_GAP_CONN_PARAM_UPDATE = BLE_GAP_SVC_BASE + 9, /**< Connection Parameter Update. */ + SD_BLE_GAP_DISCONNECT = BLE_GAP_SVC_BASE + 10, /**< Disconnect. */ + SD_BLE_GAP_TX_POWER_SET = BLE_GAP_SVC_BASE + 11, /**< Set TX Power. */ + SD_BLE_GAP_APPEARANCE_SET = BLE_GAP_SVC_BASE + 12, /**< Set Appearance. */ + SD_BLE_GAP_APPEARANCE_GET = BLE_GAP_SVC_BASE + 13, /**< Get Appearance. */ + SD_BLE_GAP_PPCP_SET = BLE_GAP_SVC_BASE + 14, /**< Set PPCP. */ + SD_BLE_GAP_PPCP_GET = BLE_GAP_SVC_BASE + 15, /**< Get PPCP. */ + SD_BLE_GAP_DEVICE_NAME_SET = BLE_GAP_SVC_BASE + 16, /**< Set Device Name. */ + SD_BLE_GAP_DEVICE_NAME_GET = BLE_GAP_SVC_BASE + 17, /**< Get Device Name. */ + SD_BLE_GAP_AUTHENTICATE = BLE_GAP_SVC_BASE + 18, /**< Initiate Pairing/Bonding. */ + SD_BLE_GAP_SEC_PARAMS_REPLY = BLE_GAP_SVC_BASE + 19, /**< Reply with Security Parameters. */ + SD_BLE_GAP_AUTH_KEY_REPLY = BLE_GAP_SVC_BASE + 20, /**< Reply with an authentication key. */ + SD_BLE_GAP_LESC_DHKEY_REPLY = BLE_GAP_SVC_BASE + 21, /**< Reply with an LE Secure Connections DHKey. */ + SD_BLE_GAP_KEYPRESS_NOTIFY = BLE_GAP_SVC_BASE + 22, /**< Notify of a keypress during an authentication procedure. */ + SD_BLE_GAP_LESC_OOB_DATA_GET = BLE_GAP_SVC_BASE + 23, /**< Get the local LE Secure Connections OOB data. */ + SD_BLE_GAP_LESC_OOB_DATA_SET = BLE_GAP_SVC_BASE + 24, /**< Set the remote LE Secure Connections OOB data. */ + SD_BLE_GAP_ENCRYPT = BLE_GAP_SVC_BASE + 25, /**< Initiate encryption procedure. */ + SD_BLE_GAP_SEC_INFO_REPLY = BLE_GAP_SVC_BASE + 26, /**< Reply with Security Information. */ + SD_BLE_GAP_CONN_SEC_GET = BLE_GAP_SVC_BASE + 27, /**< Obtain connection security level. */ + SD_BLE_GAP_RSSI_START = BLE_GAP_SVC_BASE + 28, /**< Start reporting of changes in RSSI. */ + SD_BLE_GAP_RSSI_STOP = BLE_GAP_SVC_BASE + 29, /**< Stop reporting of changes in RSSI. */ + SD_BLE_GAP_SCAN_START = BLE_GAP_SVC_BASE + 30, /**< Start Scanning. */ + SD_BLE_GAP_SCAN_STOP = BLE_GAP_SVC_BASE + 31, /**< Stop Scanning. */ + SD_BLE_GAP_CONNECT = BLE_GAP_SVC_BASE + 32, /**< Connect. */ + SD_BLE_GAP_CONNECT_CANCEL = BLE_GAP_SVC_BASE + 33, /**< Cancel ongoing connection procedure. */ + SD_BLE_GAP_RSSI_GET = BLE_GAP_SVC_BASE + 34, /**< Get the last RSSI sample. */ + SD_BLE_GAP_PHY_UPDATE = BLE_GAP_SVC_BASE + 35, /**< Initiate or respond to a PHY Update Procedure. */ + SD_BLE_GAP_DATA_LENGTH_UPDATE = BLE_GAP_SVC_BASE + 36, /**< Initiate or respond to a Data Length Update Procedure. */ + SD_BLE_GAP_QOS_CHANNEL_SURVEY_START = BLE_GAP_SVC_BASE + 37, /**< Start Quality of Service (QoS) channel survey module. */ + SD_BLE_GAP_QOS_CHANNEL_SURVEY_STOP = BLE_GAP_SVC_BASE + 38, /**< Stop Quality of Service (QoS) channel survey module. */ +}; + +/**@brief GAP Event IDs. + * IDs that uniquely identify an event coming from the stack to the application. + */ +enum BLE_GAP_EVTS +{ + BLE_GAP_EVT_CONNECTED = BLE_GAP_EVT_BASE, + BLE_GAP_EVT_DISCONNECTED = BLE_GAP_EVT_BASE + 1, /**< Disconnected from peer. \n See @ref ble_gap_evt_disconnected_t. */ + BLE_GAP_EVT_CONN_PARAM_UPDATE = BLE_GAP_EVT_BASE + 2, /**< Connection Parameters updated. \n See @ref ble_gap_evt_conn_param_update_t. */ + BLE_GAP_EVT_SEC_PARAMS_REQUEST = BLE_GAP_EVT_BASE + 3, /**< Request to provide security parameters. \n Reply with @ref sd_ble_gap_sec_params_reply. \n See @ref ble_gap_evt_sec_params_request_t. */ + BLE_GAP_EVT_SEC_INFO_REQUEST = BLE_GAP_EVT_BASE + 4, /**< Request to provide security information. \n Reply with @ref sd_ble_gap_sec_info_reply. \n See @ref ble_gap_evt_sec_info_request_t. */ + BLE_GAP_EVT_PASSKEY_DISPLAY = BLE_GAP_EVT_BASE + 5, /**< Request to display a passkey to the user. \n In LESC Numeric Comparison, reply with @ref sd_ble_gap_auth_key_reply. \n See @ref ble_gap_evt_passkey_display_t. */ + BLE_GAP_EVT_KEY_PRESSED = BLE_GAP_EVT_BASE + 6, /**< Notification of a keypress on the remote device.\n See @ref ble_gap_evt_key_pressed_t */ + BLE_GAP_EVT_AUTH_KEY_REQUEST = BLE_GAP_EVT_BASE + 7, /**< Request to provide an authentication key. \n Reply with @ref sd_ble_gap_auth_key_reply. \n See @ref ble_gap_evt_auth_key_request_t. */ + BLE_GAP_EVT_LESC_DHKEY_REQUEST = BLE_GAP_EVT_BASE + 8, /**< Request to calculate an LE Secure Connections DHKey. \n Reply with @ref sd_ble_gap_lesc_dhkey_reply. \n See @ref ble_gap_evt_lesc_dhkey_request_t */ + BLE_GAP_EVT_AUTH_STATUS = BLE_GAP_EVT_BASE + 9, /**< Authentication procedure completed with status. \n See @ref ble_gap_evt_auth_status_t. */ + BLE_GAP_EVT_CONN_SEC_UPDATE = BLE_GAP_EVT_BASE + 10, /**< Connection security updated. \n See @ref ble_gap_evt_conn_sec_update_t. */ + BLE_GAP_EVT_TIMEOUT = BLE_GAP_EVT_BASE + 11, /**< Timeout expired. \n See @ref ble_gap_evt_timeout_t. */ + BLE_GAP_EVT_RSSI_CHANGED = BLE_GAP_EVT_BASE + 12, /**< RSSI report. \n See @ref ble_gap_evt_rssi_changed_t. */ + BLE_GAP_EVT_ADV_REPORT = BLE_GAP_EVT_BASE + 13, /**< Advertising report. \n See @ref ble_gap_evt_adv_report_t. */ + BLE_GAP_EVT_SEC_REQUEST = BLE_GAP_EVT_BASE + 14, /**< Security Request. \n See @ref ble_gap_evt_sec_request_t. */ + BLE_GAP_EVT_CONN_PARAM_UPDATE_REQUEST = BLE_GAP_EVT_BASE + 15, /**< Connection Parameter Update Request. \n Reply with @ref sd_ble_gap_conn_param_update. \n See @ref ble_gap_evt_conn_param_update_request_t. */ + BLE_GAP_EVT_SCAN_REQ_REPORT = BLE_GAP_EVT_BASE + 16, /**< Scan request report. \n See @ref ble_gap_evt_scan_req_report_t. */ + BLE_GAP_EVT_PHY_UPDATE_REQUEST = BLE_GAP_EVT_BASE + 17, /**< PHY Update Request. \n Reply with @ref sd_ble_gap_phy_update. \n See @ref ble_gap_evt_phy_update_request_t. */ + BLE_GAP_EVT_PHY_UPDATE = BLE_GAP_EVT_BASE + 18, /**< PHY Update Procedure is complete. \n See @ref ble_gap_evt_phy_update_t. */ + BLE_GAP_EVT_DATA_LENGTH_UPDATE_REQUEST = BLE_GAP_EVT_BASE + 19, /**< Data Length Update Request. \n Reply with @ref sd_ble_gap_data_length_update.\n See @ref ble_gap_evt_data_length_update_request_t. */ + BLE_GAP_EVT_DATA_LENGTH_UPDATE = BLE_GAP_EVT_BASE + 20, /**< LL Data Channel PDU payload length updated. \n See @ref ble_gap_evt_data_length_update_t. */ + BLE_GAP_EVT_QOS_CHANNEL_SURVEY_REPORT = BLE_GAP_EVT_BASE + 21, /**< Channel survey report. \n See @ref ble_gap_evt_qos_channel_survey_report_t. */ + BLE_GAP_EVT_ADV_SET_TERMINATED = BLE_GAP_EVT_BASE + 22, /**< Advertising set terminated. \n See @ref ble_gap_evt_adv_set_terminated_t. */ +}; + +/**@brief GAP Option IDs. + * IDs that uniquely identify a GAP option. + */ +enum BLE_GAP_OPTS +{ + BLE_GAP_OPT_CH_MAP = BLE_GAP_OPT_BASE, /**< Channel Map. @ref ble_gap_opt_ch_map_t */ + BLE_GAP_OPT_LOCAL_CONN_LATENCY = BLE_GAP_OPT_BASE + 1, /**< Local connection latency. @ref ble_gap_opt_local_conn_latency_t */ + BLE_GAP_OPT_PASSKEY = BLE_GAP_OPT_BASE + 2, /**< Set passkey. @ref ble_gap_opt_passkey_t */ + BLE_GAP_OPT_COMPAT_MODE_1 = BLE_GAP_OPT_BASE + 3, /**< Compatibility mode. @ref ble_gap_opt_compat_mode_1_t */ + BLE_GAP_OPT_AUTH_PAYLOAD_TIMEOUT = BLE_GAP_OPT_BASE + 4, /**< Set Authenticated payload timeout. @ref ble_gap_opt_auth_payload_timeout_t */ + BLE_GAP_OPT_SLAVE_LATENCY_DISABLE = BLE_GAP_OPT_BASE + 5, /**< Disable slave latency. @ref ble_gap_opt_slave_latency_disable_t */ +}; + +/**@brief GAP Configuration IDs. + * + * IDs that uniquely identify a GAP configuration. + */ +enum BLE_GAP_CFGS +{ + BLE_GAP_CFG_ROLE_COUNT = BLE_GAP_CFG_BASE, /**< Role count configuration. */ + BLE_GAP_CFG_DEVICE_NAME = BLE_GAP_CFG_BASE + 1, /**< Device name configuration. */ +}; + +/**@brief GAP TX Power roles. + */ +enum BLE_GAP_TX_POWER_ROLES +{ + BLE_GAP_TX_POWER_ROLE_ADV = 1, /**< Advertiser role. */ + BLE_GAP_TX_POWER_ROLE_SCAN_INIT = 2, /**< Scanner and initiator role. */ + BLE_GAP_TX_POWER_ROLE_CONN = 3, /**< Connection role. */ +}; + +/** @} */ + +/**@addtogroup BLE_GAP_DEFINES Defines + * @{ */ + +/**@defgroup BLE_ERRORS_GAP SVC return values specific to GAP + * @{ */ +#define BLE_ERROR_GAP_UUID_LIST_MISMATCH (NRF_GAP_ERR_BASE + 0x000) /**< UUID list does not contain an integral number of UUIDs. */ +#define BLE_ERROR_GAP_DISCOVERABLE_WITH_WHITELIST (NRF_GAP_ERR_BASE + 0x001) /**< Use of Whitelist not permitted with discoverable advertising. */ +#define BLE_ERROR_GAP_INVALID_BLE_ADDR (NRF_GAP_ERR_BASE + 0x002) /**< The upper two bits of the address do not correspond to the specified address type. */ +#define BLE_ERROR_GAP_WHITELIST_IN_USE (NRF_GAP_ERR_BASE + 0x003) /**< Attempt to modify the whitelist while already in use by another operation. */ +#define BLE_ERROR_GAP_DEVICE_IDENTITIES_IN_USE (NRF_GAP_ERR_BASE + 0x004) /**< Attempt to modify the device identity list while already in use by another operation. */ +#define BLE_ERROR_GAP_DEVICE_IDENTITIES_DUPLICATE (NRF_GAP_ERR_BASE + 0x005) /**< The device identity list contains entries with duplicate identity addresses. */ +/**@} */ + + +/**@defgroup BLE_GAP_ROLES GAP Roles + * @{ */ +#define BLE_GAP_ROLE_INVALID 0x0 /**< Invalid Role. */ +#define BLE_GAP_ROLE_PERIPH 0x1 /**< Peripheral Role. */ +#define BLE_GAP_ROLE_CENTRAL 0x2 /**< Central Role. */ +/**@} */ + + +/**@defgroup BLE_GAP_TIMEOUT_SOURCES GAP Timeout sources + * @{ */ +#define BLE_GAP_TIMEOUT_SRC_SCAN 0x01 /**< Scanning timeout. */ +#define BLE_GAP_TIMEOUT_SRC_CONN 0x02 /**< Connection timeout. */ +#define BLE_GAP_TIMEOUT_SRC_AUTH_PAYLOAD 0x03 /**< Authenticated payload timeout. */ +/**@} */ + + +/**@defgroup BLE_GAP_ADDR_TYPES GAP Address types + * @{ */ +#define BLE_GAP_ADDR_TYPE_PUBLIC 0x00 /**< Public (identity) address.*/ +#define BLE_GAP_ADDR_TYPE_RANDOM_STATIC 0x01 /**< Random static (identity) address. */ +#define BLE_GAP_ADDR_TYPE_RANDOM_PRIVATE_RESOLVABLE 0x02 /**< Random private resolvable address. */ +#define BLE_GAP_ADDR_TYPE_RANDOM_PRIVATE_NON_RESOLVABLE 0x03 /**< Random private non-resolvable address. */ +#define BLE_GAP_ADDR_TYPE_ANONYMOUS 0x7F /**< An advertiser may advertise without its address. + This type of advertising is called anonymous. */ +/**@} */ + + +/**@brief The default interval in seconds at which a private address is refreshed. */ +#define BLE_GAP_DEFAULT_PRIVATE_ADDR_CYCLE_INTERVAL_S (900) /* 15 minutes. */ +/**@brief The maximum interval in seconds at which a private address can be refreshed. */ +#define BLE_GAP_MAX_PRIVATE_ADDR_CYCLE_INTERVAL_S (41400) /* 11 hours 30 minutes. */ + + +/** @brief BLE address length. */ +#define BLE_GAP_ADDR_LEN (6) + +/**@defgroup BLE_GAP_PRIVACY_MODES Privacy modes + * @{ */ +#define BLE_GAP_PRIVACY_MODE_OFF 0x00 /**< Device will send and accept its identity address for its own address. */ +#define BLE_GAP_PRIVACY_MODE_DEVICE_PRIVACY 0x01 /**< Device will send and accept only private addresses for its own address. */ +#define BLE_GAP_PRIVACY_MODE_NETWORK_PRIVACY 0x02 /**< Device will send and accept only private addresses for its own address, + and will not accept a peer using identity address as sender address when + the peer IRK is exchanged, non-zero and added to the identity list. */ +/**@} */ + +/** @brief Invalid power level. */ +#define BLE_GAP_POWER_LEVEL_INVALID 127 + +/** @brief Advertising set handle not set. */ +#define BLE_GAP_ADV_SET_HANDLE_NOT_SET (0xFF) + +/** @brief The default number of advertising sets. */ +#define BLE_GAP_ADV_SET_COUNT_DEFAULT (1) + +/** @brief The maximum number of advertising sets supported by this SoftDevice. */ +#define BLE_GAP_ADV_SET_COUNT_MAX (1) + +/**@defgroup BLE_GAP_ADV_SET_DATA_SIZES Advertising data sizes. + * @{ */ +#define BLE_GAP_ADV_SET_DATA_SIZE_MAX (31) /**< Maximum data length for an advertising set. */ +/**@}. */ + +/** @brief Set ID not available in advertising report. */ +#define BLE_GAP_ADV_REPORT_SET_ID_NOT_AVAILABLE 0xFF + +/**@defgroup BLE_GAP_EVT_ADV_SET_TERMINATED_REASON GAP Advertising Set Terminated reasons + * @{ */ +#define BLE_GAP_EVT_ADV_SET_TERMINATED_REASON_TIMEOUT 0x01 /**< Timeout value reached. */ +#define BLE_GAP_EVT_ADV_SET_TERMINATED_REASON_LIMIT_REACHED 0x02 /**< @ref ble_gap_adv_params_t::max_adv_evts was reached. */ +/**@} */ + +/**@defgroup BLE_GAP_AD_TYPE_DEFINITIONS GAP Advertising and Scan Response Data format + * @note Found at https://www.bluetooth.org/Technical/AssignedNumbers/generic_access_profile.htm + * @{ */ +#define BLE_GAP_AD_TYPE_FLAGS 0x01 /**< Flags for discoverability. */ +#define BLE_GAP_AD_TYPE_16BIT_SERVICE_UUID_MORE_AVAILABLE 0x02 /**< Partial list of 16 bit service UUIDs. */ +#define BLE_GAP_AD_TYPE_16BIT_SERVICE_UUID_COMPLETE 0x03 /**< Complete list of 16 bit service UUIDs. */ +#define BLE_GAP_AD_TYPE_32BIT_SERVICE_UUID_MORE_AVAILABLE 0x04 /**< Partial list of 32 bit service UUIDs. */ +#define BLE_GAP_AD_TYPE_32BIT_SERVICE_UUID_COMPLETE 0x05 /**< Complete list of 32 bit service UUIDs. */ +#define BLE_GAP_AD_TYPE_128BIT_SERVICE_UUID_MORE_AVAILABLE 0x06 /**< Partial list of 128 bit service UUIDs. */ +#define BLE_GAP_AD_TYPE_128BIT_SERVICE_UUID_COMPLETE 0x07 /**< Complete list of 128 bit service UUIDs. */ +#define BLE_GAP_AD_TYPE_SHORT_LOCAL_NAME 0x08 /**< Short local device name. */ +#define BLE_GAP_AD_TYPE_COMPLETE_LOCAL_NAME 0x09 /**< Complete local device name. */ +#define BLE_GAP_AD_TYPE_TX_POWER_LEVEL 0x0A /**< Transmit power level. */ +#define BLE_GAP_AD_TYPE_CLASS_OF_DEVICE 0x0D /**< Class of device. */ +#define BLE_GAP_AD_TYPE_SIMPLE_PAIRING_HASH_C 0x0E /**< Simple Pairing Hash C. */ +#define BLE_GAP_AD_TYPE_SIMPLE_PAIRING_RANDOMIZER_R 0x0F /**< Simple Pairing Randomizer R. */ +#define BLE_GAP_AD_TYPE_SECURITY_MANAGER_TK_VALUE 0x10 /**< Security Manager TK Value. */ +#define BLE_GAP_AD_TYPE_SECURITY_MANAGER_OOB_FLAGS 0x11 /**< Security Manager Out Of Band Flags. */ +#define BLE_GAP_AD_TYPE_SLAVE_CONNECTION_INTERVAL_RANGE 0x12 /**< Slave Connection Interval Range. */ +#define BLE_GAP_AD_TYPE_SOLICITED_SERVICE_UUIDS_16BIT 0x14 /**< List of 16-bit Service Solicitation UUIDs. */ +#define BLE_GAP_AD_TYPE_SOLICITED_SERVICE_UUIDS_128BIT 0x15 /**< List of 128-bit Service Solicitation UUIDs. */ +#define BLE_GAP_AD_TYPE_SERVICE_DATA 0x16 /**< Service Data - 16-bit UUID. */ +#define BLE_GAP_AD_TYPE_PUBLIC_TARGET_ADDRESS 0x17 /**< Public Target Address. */ +#define BLE_GAP_AD_TYPE_RANDOM_TARGET_ADDRESS 0x18 /**< Random Target Address. */ +#define BLE_GAP_AD_TYPE_APPEARANCE 0x19 /**< Appearance. */ +#define BLE_GAP_AD_TYPE_ADVERTISING_INTERVAL 0x1A /**< Advertising Interval. */ +#define BLE_GAP_AD_TYPE_LE_BLUETOOTH_DEVICE_ADDRESS 0x1B /**< LE Bluetooth Device Address. */ +#define BLE_GAP_AD_TYPE_LE_ROLE 0x1C /**< LE Role. */ +#define BLE_GAP_AD_TYPE_SIMPLE_PAIRING_HASH_C256 0x1D /**< Simple Pairing Hash C-256. */ +#define BLE_GAP_AD_TYPE_SIMPLE_PAIRING_RANDOMIZER_R256 0x1E /**< Simple Pairing Randomizer R-256. */ +#define BLE_GAP_AD_TYPE_SERVICE_DATA_32BIT_UUID 0x20 /**< Service Data - 32-bit UUID. */ +#define BLE_GAP_AD_TYPE_SERVICE_DATA_128BIT_UUID 0x21 /**< Service Data - 128-bit UUID. */ +#define BLE_GAP_AD_TYPE_LESC_CONFIRMATION_VALUE 0x22 /**< LE Secure Connections Confirmation Value */ +#define BLE_GAP_AD_TYPE_LESC_RANDOM_VALUE 0x23 /**< LE Secure Connections Random Value */ +#define BLE_GAP_AD_TYPE_URI 0x24 /**< URI */ +#define BLE_GAP_AD_TYPE_3D_INFORMATION_DATA 0x3D /**< 3D Information Data. */ +#define BLE_GAP_AD_TYPE_MANUFACTURER_SPECIFIC_DATA 0xFF /**< Manufacturer Specific Data. */ +/**@} */ + + +/**@defgroup BLE_GAP_ADV_FLAGS GAP Advertisement Flags + * @{ */ +#define BLE_GAP_ADV_FLAG_LE_LIMITED_DISC_MODE (0x01) /**< LE Limited Discoverable Mode. */ +#define BLE_GAP_ADV_FLAG_LE_GENERAL_DISC_MODE (0x02) /**< LE General Discoverable Mode. */ +#define BLE_GAP_ADV_FLAG_BR_EDR_NOT_SUPPORTED (0x04) /**< BR/EDR not supported. */ +#define BLE_GAP_ADV_FLAG_LE_BR_EDR_CONTROLLER (0x08) /**< Simultaneous LE and BR/EDR, Controller. */ +#define BLE_GAP_ADV_FLAG_LE_BR_EDR_HOST (0x10) /**< Simultaneous LE and BR/EDR, Host. */ +#define BLE_GAP_ADV_FLAGS_LE_ONLY_LIMITED_DISC_MODE (BLE_GAP_ADV_FLAG_LE_LIMITED_DISC_MODE | BLE_GAP_ADV_FLAG_BR_EDR_NOT_SUPPORTED) /**< LE Limited Discoverable Mode, BR/EDR not supported. */ +#define BLE_GAP_ADV_FLAGS_LE_ONLY_GENERAL_DISC_MODE (BLE_GAP_ADV_FLAG_LE_GENERAL_DISC_MODE | BLE_GAP_ADV_FLAG_BR_EDR_NOT_SUPPORTED) /**< LE General Discoverable Mode, BR/EDR not supported. */ +/**@} */ + + +/**@defgroup BLE_GAP_ADV_INTERVALS GAP Advertising interval max and min + * @{ */ +#define BLE_GAP_ADV_INTERVAL_MIN 0x000020 /**< Minimum Advertising interval in 625 us units, i.e. 20 ms. */ +#define BLE_GAP_ADV_INTERVAL_MAX 0x004000 /**< Maximum Advertising interval in 625 us units, i.e. 10.24 s. + @note Support for values above @ref BLE_GAP_ADV_INTERVAL_MAX + is experimental. Values above 0xFFFFFF, i.e 10,485.759375 s + are not supported. */ + /**@} */ + + +/**@defgroup BLE_GAP_SCAN_INTERVALS GAP Scan interval max and min + * @{ */ +#define BLE_GAP_SCAN_INTERVAL_MIN 0x0004 /**< Minimum Scan interval in 625 us units, i.e. 2.5 ms. */ +#define BLE_GAP_SCAN_INTERVAL_MAX 0xFFFF /**< Maximum Scan interval in 625 us units, i.e. 40,959.375 s. */ + /** @} */ + + +/**@defgroup BLE_GAP_SCAN_WINDOW GAP Scan window max and min + * @{ */ +#define BLE_GAP_SCAN_WINDOW_MIN 0x0004 /**< Minimum Scan window in 625 us units, i.e. 2.5 ms. */ +#define BLE_GAP_SCAN_WINDOW_MAX 0xFFFF /**< Maximum Scan window in 625 us units, i.e. 40,959.375 s. */ + /** @} */ + + +/**@defgroup BLE_GAP_SCAN_TIMEOUT GAP Scan timeout max and min + * @{ */ +#define BLE_GAP_SCAN_TIMEOUT_MIN 0x0001 /**< Minimum Scan timeout in 10 ms units, i.e 10 ms. */ +#define BLE_GAP_SCAN_TIMEOUT_UNLIMITED 0x0000 /**< Continue to scan forever. */ + /** @} */ + +/**@defgroup BLE_GAP_SCAN_BUFFER_SIZE GAP Minimum scanner buffer size + * + * Scan buffers are used for storing advertising data received from an advertiser. + * If ble_gap_scan_params_t::extended is set to 0, @ref BLE_GAP_SCAN_BUFFER_MIN is the minimum scan buffer length. + * else the minimum scan buffer size is @ref BLE_GAP_SCAN_BUFFER_EXTENDED_MIN. + * @{ */ +#define BLE_GAP_SCAN_BUFFER_MIN (31) /**< Minimum data length for an + advertising set. */ +#define BLE_GAP_SCAN_BUFFER_MAX (31) /**< Maximum data length for an + advertising set. */ +#define BLE_GAP_SCAN_BUFFER_EXTENDED_MIN (255) /**< Minimum data length for an + extended advertising set. */ +#define BLE_GAP_SCAN_BUFFER_EXTENDED_MAX (1650) /**< Maximum data length for an + extended advertising set. + @note Extended scanning is only + supported as an experimental + feature in this SoftDevice. + The scanner will only receive + advertising data up to 31 bytes. */ +/** @} */ + +/**@defgroup BLE_GAP_ADV_TYPES GAP Advertising types + * + * Advertising types defined in Bluetooth Core Specification v5.0, Vol 6, Part B, Section 4.4.2. + * + * The maximum advertising data length is defined by @ref BLE_GAP_ADV_SET_DATA_SIZE_MAX. + * Note that some of the advertising types do not support advertising data. Non-scannable types do not support + * scan response data. + * + * @{ */ +#define BLE_GAP_ADV_TYPE_CONNECTABLE_SCANNABLE_UNDIRECTED 0x01 /**< Connectable and scannable undirected + advertising events. */ +#define BLE_GAP_ADV_TYPE_CONNECTABLE_NONSCANNABLE_DIRECTED_HIGH_DUTY_CYCLE 0x02 /**< Connectable non-scannable directed advertising + events. Advertising interval is less that 3.75 ms. + Use this type for fast reconnections. + @note Advertising data is not supported. */ +#define BLE_GAP_ADV_TYPE_CONNECTABLE_NONSCANNABLE_DIRECTED 0x03 /**< Connectable non-scannable directed advertising + events. + @note Advertising data is not supported. */ +#define BLE_GAP_ADV_TYPE_NONCONNECTABLE_SCANNABLE_UNDIRECTED 0x04 /**< Non-connectable scannable undirected + advertising events. */ +#define BLE_GAP_ADV_TYPE_NONCONNECTABLE_NONSCANNABLE_UNDIRECTED 0x05 /**< Non-connectable non-scannable undirected + advertising events. */ +#define BLE_GAP_ADV_TYPE_EXTENDED_CONNECTABLE_NONSCANNABLE_UNDIRECTED 0x06 /**< Connectable non-scannable undirected advertising + events using extended advertising PDUs. + @note Extended advertising types are only + supported as experimental features in this + SoftDevice. */ +#define BLE_GAP_ADV_TYPE_EXTENDED_CONNECTABLE_NONSCANNABLE_DIRECTED 0x07 /**< Connectable non-scannable directed advertising + events using extended advertising PDUs. + @note Extended advertising types are only + supported as experimental features in this + SoftDevice. */ +#define BLE_GAP_ADV_TYPE_EXTENDED_NONCONNECTABLE_SCANNABLE_UNDIRECTED 0x08 /**< Non-connectable scannable undirected advertising + events using extended advertising PDUs. + @note Only scan response data is supported. + @note Extended advertising types are only + supported as experimental features in this + SoftDevice. */ +#define BLE_GAP_ADV_TYPE_EXTENDED_NONCONNECTABLE_SCANNABLE_DIRECTED 0x09 /**< Non-connectable scannable directed advertising + events using extended advertising PDUs. + @note Only scan response data is supported. + @note Extended advertising types are only + supported as experimental features in this + SoftDevice. */ +#define BLE_GAP_ADV_TYPE_EXTENDED_NONCONNECTABLE_NONSCANNABLE_UNDIRECTED 0x0A /**< Non-connectable non-scannable undirected advertising + events using extended advertising PDUs. + @note Extended advertising types are only + supported as experimental features in this + SoftDevice. */ +#define BLE_GAP_ADV_TYPE_EXTENDED_NONCONNECTABLE_NONSCANNABLE_DIRECTED 0x0B /**< Non-connectable non-scannable directed advertising + events using extended advertising PDUs. + @note Extended advertising types are only + supported as experimental features in this + SoftDevice. */ +/**@} */ + +/**@defgroup BLE_GAP_ADV_FILTER_POLICIES GAP Advertising filter policies + * @{ */ +#define BLE_GAP_ADV_FP_ANY 0x00 /**< Allow scan requests and connect requests from any device. */ +#define BLE_GAP_ADV_FP_FILTER_SCANREQ 0x01 /**< Filter scan requests with whitelist. */ +#define BLE_GAP_ADV_FP_FILTER_CONNREQ 0x02 /**< Filter connect requests with whitelist. */ +#define BLE_GAP_ADV_FP_FILTER_BOTH 0x03 /**< Filter both scan and connect requests with whitelist. */ +/**@} */ + +/**@defgroup BLE_GAP_ADV_DATA_STATUS GAP Advertising data status + * @{ */ +#define BLE_GAP_ADV_DATA_STATUS_COMPLETE 0x00 /**< All data in the advertising event have been received. */ +#define BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_MORE_DATA 0x01 /**< More data to be received. */ +#define BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_TRUNCATED 0x02 /**< Incomplete data. Buffer size insufficient to receive more. */ +#define BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_MISSED 0x03 /**< Failed to receive the remaining data. */ +/**@} */ + +/**@defgroup BLE_GAP_SCAN_FILTER_POLICIES GAP Scanner filter policies + * @{ */ +#define BLE_GAP_SCAN_FP_ACCEPT_ALL 0x00 /**< Accept all advertising packets except directed advertising packets + not addressed to this device. */ +#define BLE_GAP_SCAN_FP_WHITELIST 0x01 /**< Accept advertising packets from devices in the whitelist except directed + packets not addressed to this device. */ +#define BLE_GAP_SCAN_FP_ALL_NOT_RESOLVED_DIRECTED 0x02 /**< Accept all advertising packets specified in @ref BLE_GAP_SCAN_FP_ACCEPT_ALL. + In addition, accept directed advertising packets, where the advertiser's + address is a resolvable private address that cannot be resolved. */ +#define BLE_GAP_SCAN_FP_WHITELIST_NOT_RESOLVED_DIRECTED 0x03 /**< Accept all advertising packets specified in @ref BLE_GAP_SCAN_FP_WHITELIST. + In addition, accept directed advertising packets, where the advertiser's + address is a resolvable private address that cannot be resolved. */ +/**@} */ + +/**@defgroup BLE_GAP_ADV_TIMEOUT_VALUES GAP Advertising timeout values in 10 ms units + * @{ */ +#define BLE_GAP_ADV_TIMEOUT_HIGH_DUTY_MAX (128) /**< Maximum high duty advertising time in 10 ms units. Corresponds to 1.28 s. */ +#define BLE_GAP_ADV_TIMEOUT_LIMITED_MAX (18000) /**< Maximum advertising time in 10 ms units corresponding to TGAP(lim_adv_timeout) = 180 s in limited discoverable mode. */ +#define BLE_GAP_ADV_TIMEOUT_GENERAL_UNLIMITED (0) /**< Unlimited advertising in general discoverable mode. + For high duty cycle advertising, this corresponds to @ref BLE_GAP_ADV_TIMEOUT_HIGH_DUTY_MAX. */ +/**@} */ + + +/**@defgroup BLE_GAP_DISC_MODES GAP Discovery modes + * @{ */ +#define BLE_GAP_DISC_MODE_NOT_DISCOVERABLE 0x00 /**< Not discoverable discovery Mode. */ +#define BLE_GAP_DISC_MODE_LIMITED 0x01 /**< Limited Discovery Mode. */ +#define BLE_GAP_DISC_MODE_GENERAL 0x02 /**< General Discovery Mode. */ +/**@} */ + + +/**@defgroup BLE_GAP_IO_CAPS GAP IO Capabilities + * @{ */ +#define BLE_GAP_IO_CAPS_DISPLAY_ONLY 0x00 /**< Display Only. */ +#define BLE_GAP_IO_CAPS_DISPLAY_YESNO 0x01 /**< Display and Yes/No entry. */ +#define BLE_GAP_IO_CAPS_KEYBOARD_ONLY 0x02 /**< Keyboard Only. */ +#define BLE_GAP_IO_CAPS_NONE 0x03 /**< No I/O capabilities. */ +#define BLE_GAP_IO_CAPS_KEYBOARD_DISPLAY 0x04 /**< Keyboard and Display. */ +/**@} */ + + +/**@defgroup BLE_GAP_AUTH_KEY_TYPES GAP Authentication Key Types + * @{ */ +#define BLE_GAP_AUTH_KEY_TYPE_NONE 0x00 /**< No key (may be used to reject). */ +#define BLE_GAP_AUTH_KEY_TYPE_PASSKEY 0x01 /**< 6-digit Passkey. */ +#define BLE_GAP_AUTH_KEY_TYPE_OOB 0x02 /**< Out Of Band data. */ +/**@} */ + + +/**@defgroup BLE_GAP_KP_NOT_TYPES GAP Keypress Notification Types + * @{ */ +#define BLE_GAP_KP_NOT_TYPE_PASSKEY_START 0x00 /**< Passkey entry started. */ +#define BLE_GAP_KP_NOT_TYPE_PASSKEY_DIGIT_IN 0x01 /**< Passkey digit entered. */ +#define BLE_GAP_KP_NOT_TYPE_PASSKEY_DIGIT_OUT 0x02 /**< Passkey digit erased. */ +#define BLE_GAP_KP_NOT_TYPE_PASSKEY_CLEAR 0x03 /**< Passkey cleared. */ +#define BLE_GAP_KP_NOT_TYPE_PASSKEY_END 0x04 /**< Passkey entry completed. */ +/**@} */ + + +/**@defgroup BLE_GAP_SEC_STATUS GAP Security status + * @{ */ +#define BLE_GAP_SEC_STATUS_SUCCESS 0x00 /**< Procedure completed with success. */ +#define BLE_GAP_SEC_STATUS_TIMEOUT 0x01 /**< Procedure timed out. */ +#define BLE_GAP_SEC_STATUS_PDU_INVALID 0x02 /**< Invalid PDU received. */ +#define BLE_GAP_SEC_STATUS_RFU_RANGE1_BEGIN 0x03 /**< Reserved for Future Use range #1 begin. */ +#define BLE_GAP_SEC_STATUS_RFU_RANGE1_END 0x80 /**< Reserved for Future Use range #1 end. */ +#define BLE_GAP_SEC_STATUS_PASSKEY_ENTRY_FAILED 0x81 /**< Passkey entry failed (user canceled or other). */ +#define BLE_GAP_SEC_STATUS_OOB_NOT_AVAILABLE 0x82 /**< Out of Band Key not available. */ +#define BLE_GAP_SEC_STATUS_AUTH_REQ 0x83 /**< Authentication requirements not met. */ +#define BLE_GAP_SEC_STATUS_CONFIRM_VALUE 0x84 /**< Confirm value failed. */ +#define BLE_GAP_SEC_STATUS_PAIRING_NOT_SUPP 0x85 /**< Pairing not supported. */ +#define BLE_GAP_SEC_STATUS_ENC_KEY_SIZE 0x86 /**< Encryption key size. */ +#define BLE_GAP_SEC_STATUS_SMP_CMD_UNSUPPORTED 0x87 /**< Unsupported SMP command. */ +#define BLE_GAP_SEC_STATUS_UNSPECIFIED 0x88 /**< Unspecified reason. */ +#define BLE_GAP_SEC_STATUS_REPEATED_ATTEMPTS 0x89 /**< Too little time elapsed since last attempt. */ +#define BLE_GAP_SEC_STATUS_INVALID_PARAMS 0x8A /**< Invalid parameters. */ +#define BLE_GAP_SEC_STATUS_DHKEY_FAILURE 0x8B /**< DHKey check failure. */ +#define BLE_GAP_SEC_STATUS_NUM_COMP_FAILURE 0x8C /**< Numeric Comparison failure. */ +#define BLE_GAP_SEC_STATUS_BR_EDR_IN_PROG 0x8D /**< BR/EDR pairing in progress. */ +#define BLE_GAP_SEC_STATUS_X_TRANS_KEY_DISALLOWED 0x8E /**< BR/EDR Link Key cannot be used for LE keys. */ +#define BLE_GAP_SEC_STATUS_RFU_RANGE2_BEGIN 0x8F /**< Reserved for Future Use range #2 begin. */ +#define BLE_GAP_SEC_STATUS_RFU_RANGE2_END 0xFF /**< Reserved for Future Use range #2 end. */ +/**@} */ + + +/**@defgroup BLE_GAP_SEC_STATUS_SOURCES GAP Security status sources + * @{ */ +#define BLE_GAP_SEC_STATUS_SOURCE_LOCAL 0x00 /**< Local failure. */ +#define BLE_GAP_SEC_STATUS_SOURCE_REMOTE 0x01 /**< Remote failure. */ +/**@} */ + + +/**@defgroup BLE_GAP_CP_LIMITS GAP Connection Parameters Limits + * @{ */ +#define BLE_GAP_CP_MIN_CONN_INTVL_NONE 0xFFFF /**< No new minimum connection interval specified in connect parameters. */ +#define BLE_GAP_CP_MIN_CONN_INTVL_MIN 0x0006 /**< Lowest minimum connection interval permitted, in units of 1.25 ms, i.e. 7.5 ms. */ +#define BLE_GAP_CP_MIN_CONN_INTVL_MAX 0x0C80 /**< Highest minimum connection interval permitted, in units of 1.25 ms, i.e. 4 s. */ +#define BLE_GAP_CP_MAX_CONN_INTVL_NONE 0xFFFF /**< No new maximum connection interval specified in connect parameters. */ +#define BLE_GAP_CP_MAX_CONN_INTVL_MIN 0x0006 /**< Lowest maximum connection interval permitted, in units of 1.25 ms, i.e. 7.5 ms. */ +#define BLE_GAP_CP_MAX_CONN_INTVL_MAX 0x0C80 /**< Highest maximum connection interval permitted, in units of 1.25 ms, i.e. 4 s. */ +#define BLE_GAP_CP_SLAVE_LATENCY_MAX 0x01F3 /**< Highest slave latency permitted, in connection events. */ +#define BLE_GAP_CP_CONN_SUP_TIMEOUT_NONE 0xFFFF /**< No new supervision timeout specified in connect parameters. */ +#define BLE_GAP_CP_CONN_SUP_TIMEOUT_MIN 0x000A /**< Lowest supervision timeout permitted, in units of 10 ms, i.e. 100 ms. */ +#define BLE_GAP_CP_CONN_SUP_TIMEOUT_MAX 0x0C80 /**< Highest supervision timeout permitted, in units of 10 ms, i.e. 32 s. */ +/**@} */ + + +/**@defgroup BLE_GAP_DEVNAME GAP device name defines. + * @{ */ +#define BLE_GAP_DEVNAME_DEFAULT "nRF5x" /**< Default device name value. */ +#define BLE_GAP_DEVNAME_DEFAULT_LEN 31 /**< Default number of octets in device name. */ +#define BLE_GAP_DEVNAME_MAX_LEN 248 /**< Maximum number of octets in device name. */ +/**@} */ + + +/**@brief Disable RSSI events for connections */ +#define BLE_GAP_RSSI_THRESHOLD_INVALID 0xFF + +/**@defgroup BLE_GAP_PHYS GAP PHYs + * @{ */ +#define BLE_GAP_PHY_AUTO 0x00 /**< Automatic PHY selection. Refer @ref sd_ble_gap_phy_update for more information.*/ +#define BLE_GAP_PHY_1MBPS 0x01 /**< 1 Mbps PHY. */ +#define BLE_GAP_PHY_2MBPS 0x02 /**< 2 Mbps PHY. */ +#define BLE_GAP_PHY_CODED 0x04 /**< Coded PHY. */ +#define BLE_GAP_PHY_NOT_SET 0xFF /**< PHY is not configured. */ + +/**@brief Supported PHYs in connections, for scanning, and for advertising. */ +#define BLE_GAP_PHYS_SUPPORTED (BLE_GAP_PHY_1MBPS | BLE_GAP_PHY_2MBPS) /**< All PHYs except @ref BLE_GAP_PHY_CODED are supported. */ + +/**@} */ + +/**@defgroup BLE_GAP_CONN_SEC_MODE_SET_MACROS GAP attribute security requirement setters + * + * See @ref ble_gap_conn_sec_mode_t. + * @{ */ +/**@brief Set sec_mode pointed to by ptr to have no access rights.*/ +#define BLE_GAP_CONN_SEC_MODE_SET_NO_ACCESS(ptr) do {(ptr)->sm = 0; (ptr)->lv = 0;} while(0) +/**@brief Set sec_mode pointed to by ptr to require no protection, open link.*/ +#define BLE_GAP_CONN_SEC_MODE_SET_OPEN(ptr) do {(ptr)->sm = 1; (ptr)->lv = 1;} while(0) +/**@brief Set sec_mode pointed to by ptr to require encryption, but no MITM protection.*/ +#define BLE_GAP_CONN_SEC_MODE_SET_ENC_NO_MITM(ptr) do {(ptr)->sm = 1; (ptr)->lv = 2;} while(0) +/**@brief Set sec_mode pointed to by ptr to require encryption and MITM protection.*/ +#define BLE_GAP_CONN_SEC_MODE_SET_ENC_WITH_MITM(ptr) do {(ptr)->sm = 1; (ptr)->lv = 3;} while(0) +/**@brief Set sec_mode pointed to by ptr to require LESC encryption and MITM protection.*/ +#define BLE_GAP_CONN_SEC_MODE_SET_LESC_ENC_WITH_MITM(ptr) do {(ptr)->sm = 1; (ptr)->lv = 4;} while(0) +/**@brief Set sec_mode pointed to by ptr to require signing or encryption, no MITM protection needed.*/ +#define BLE_GAP_CONN_SEC_MODE_SET_SIGNED_NO_MITM(ptr) do {(ptr)->sm = 2; (ptr)->lv = 1;} while(0) +/**@brief Set sec_mode pointed to by ptr to require signing or encryption with MITM protection.*/ +#define BLE_GAP_CONN_SEC_MODE_SET_SIGNED_WITH_MITM(ptr) do {(ptr)->sm = 2; (ptr)->lv = 2;} while(0) +/**@} */ + + +/**@brief GAP Security Random Number Length. */ +#define BLE_GAP_SEC_RAND_LEN 8 + + +/**@brief GAP Security Key Length. */ +#define BLE_GAP_SEC_KEY_LEN 16 + + +/**@brief GAP LE Secure Connections Elliptic Curve Diffie-Hellman P-256 Public Key Length. */ +#define BLE_GAP_LESC_P256_PK_LEN 64 + + +/**@brief GAP LE Secure Connections Elliptic Curve Diffie-Hellman DHKey Length. */ +#define BLE_GAP_LESC_DHKEY_LEN 32 + + +/**@brief GAP Passkey Length. */ +#define BLE_GAP_PASSKEY_LEN 6 + + +/**@brief Maximum amount of addresses in the whitelist. */ +#define BLE_GAP_WHITELIST_ADDR_MAX_COUNT (8) + + +/**@brief Maximum amount of identities in the device identities list. */ +#define BLE_GAP_DEVICE_IDENTITIES_MAX_COUNT (8) + + +/**@brief Default connection count for a configuration. */ +#define BLE_GAP_CONN_COUNT_DEFAULT (1) + + +/**@defgroup BLE_GAP_EVENT_LENGTH GAP event length defines. + * @{ */ +#define BLE_GAP_EVENT_LENGTH_MIN (2) /**< Minimum event length, in 1.25 ms units. */ +#define BLE_GAP_EVENT_LENGTH_DEFAULT (3) /**< Default event length, in 1.25 ms units. */ +/**@} */ + + +/**@defgroup BLE_GAP_ROLE_COUNT GAP concurrent connection count defines. + * @{ */ +#define BLE_GAP_ROLE_COUNT_PERIPH_DEFAULT (1) /**< Default maximum number of connections concurrently acting as peripherals. */ +#define BLE_GAP_ROLE_COUNT_CENTRAL_DEFAULT (3) /**< Default maximum number of connections concurrently acting as centrals. */ +#define BLE_GAP_ROLE_COUNT_CENTRAL_SEC_DEFAULT (1) /**< Default number of SMP instances shared between all connections acting as centrals. */ +#define BLE_GAP_ROLE_COUNT_COMBINED_MAX (20) /**< Maximum supported number of concurrent connections in the peripheral and central roles combined. */ + +/**@} */ + +/**@brief Automatic data length parameter. */ +#define BLE_GAP_DATA_LENGTH_AUTO 0 + +/**@defgroup BLE_GAP_AUTH_PAYLOAD_TIMEOUT Authenticated payload timeout defines. + * @{ */ +#define BLE_GAP_AUTH_PAYLOAD_TIMEOUT_MAX (48000) /**< Maximum authenticated payload timeout in 10 ms units, i.e. 8 minutes. */ +#define BLE_GAP_AUTH_PAYLOAD_TIMEOUT_MIN (1) /**< Minimum authenticated payload timeout in 10 ms units, i.e. 10 ms. */ +/**@} */ + +/**@defgroup GAP_SEC_MODES GAP Security Modes + * @{ */ +#define BLE_GAP_SEC_MODE 0x00 /**< No key (may be used to reject). */ +/**@} */ + +/**@brief The total number of channels in Bluetooth Low Energy. */ +#define BLE_GAP_CHANNEL_COUNT (40) + +/**@defgroup BLE_GAP_QOS_CHANNEL_SURVEY_INTERVALS Quality of Service (QoS) Channel survey interval defines + * @{ */ +#define BLE_GAP_QOS_CHANNEL_SURVEY_INTERVAL_CONTINUOUS (0) /**< Continuous channel survey. */ +#define BLE_GAP_QOS_CHANNEL_SURVEY_INTERVAL_MIN_US (7500) /**< Minimum channel survey interval in microseconds (7.5 ms). */ +#define BLE_GAP_QOS_CHANNEL_SURVEY_INTERVAL_MAX_US (4000000) /**< Maximum channel survey interval in microseconds (4 s). */ + /**@} */ + +/** @} */ + + +/**@addtogroup BLE_GAP_STRUCTURES Structures + * @{ */ + +/**@brief Advertising event properties. */ +typedef struct +{ + uint8_t type; /**< Advertising type. See @ref BLE_GAP_ADV_TYPES. */ + uint8_t anonymous : 1; /**< Omit advertiser's address from all PDUs. + @note Anonymous advertising is only available for + @ref BLE_GAP_ADV_TYPE_EXTENDED_NONCONNECTABLE_NONSCANNABLE_UNDIRECTED and + @ref BLE_GAP_ADV_TYPE_EXTENDED_NONCONNECTABLE_NONSCANNABLE_DIRECTED. */ + uint8_t include_tx_power : 1; /**< Include TxPower set by @ref sd_ble_gap_tx_power_set in the extended header + of the advertising PDU. + @note TxPower can only be added to the extended header when @ref type is an extended advertising type. */ +} ble_gap_adv_properties_t; + + +/**@brief Advertising report type. */ +typedef struct +{ + uint16_t connectable : 1; /**< Connectable advertising event type. */ + uint16_t scannable : 1; /**< Scannable advertising event type. */ + uint16_t directed : 1; /**< Directed advertising event type. */ + uint16_t scan_response : 1; /**< Received a scan response. */ + uint16_t extended_pdu : 1; /**< Received an extended advertising set. */ + uint16_t status : 2; /**< Data status. See @ref BLE_GAP_ADV_DATA_STATUS. */ + uint16_t reserved : 9; /**< Reserved for future use. */ +} ble_gap_adv_report_type_t; + +/**@brief Advertising Auxiliary Pointer. */ +typedef struct +{ + uint16_t aux_offset; /**< Time offset from the beginning of advertising packet to the auxiliary packet in 100 us units. */ + uint8_t aux_phy; /**< Indicates the PHY on which the auxiliary advertising packet is sent. See @ref BLE_GAP_PHYS. */ +} ble_gap_aux_pointer_t; + +/**@brief Bluetooth Low Energy address. */ +typedef struct +{ + uint8_t addr_id_peer : 1; /**< Only valid for peer addresses. + Reference to peer in device identities list (as set with @ref sd_ble_gap_device_identities_set) when peer is using privacy. */ + uint8_t addr_type : 7; /**< See @ref BLE_GAP_ADDR_TYPES. */ + uint8_t addr[BLE_GAP_ADDR_LEN]; /**< 48-bit address, LSB format. + addr is not used if addr_type is @ref BLE_GAP_ADDR_TYPE_ANONYMOUS. */ +} ble_gap_addr_t; + + +/**@brief GAP connection parameters. + * + * @note When ble_conn_params_t is received in an event, both min_conn_interval and + * max_conn_interval will be equal to the connection interval set by the central. + * + * @note If both conn_sup_timeout and max_conn_interval are specified, then the following constraint applies: + * conn_sup_timeout * 4 > (1 + slave_latency) * max_conn_interval + * that corresponds to the following Bluetooth Spec requirement: + * The Supervision_Timeout in milliseconds shall be larger than + * (1 + Conn_Latency) * Conn_Interval_Max * 2, where Conn_Interval_Max is given in milliseconds. + */ +typedef struct +{ + uint16_t min_conn_interval; /**< Minimum Connection Interval in 1.25 ms units, see @ref BLE_GAP_CP_LIMITS.*/ + uint16_t max_conn_interval; /**< Maximum Connection Interval in 1.25 ms units, see @ref BLE_GAP_CP_LIMITS.*/ + uint16_t slave_latency; /**< Slave Latency in number of connection events, see @ref BLE_GAP_CP_LIMITS.*/ + uint16_t conn_sup_timeout; /**< Connection Supervision Timeout in 10 ms units, see @ref BLE_GAP_CP_LIMITS.*/ +} ble_gap_conn_params_t; + + +/**@brief GAP connection security modes. + * + * Security Mode 0 Level 0: No access permissions at all (this level is not defined by the Bluetooth Core specification).\n + * Security Mode 1 Level 1: No security is needed (aka open link).\n + * Security Mode 1 Level 2: Encrypted link required, MITM protection not necessary.\n + * Security Mode 1 Level 3: MITM protected encrypted link required.\n + * Security Mode 1 Level 4: LESC MITM protected encrypted link using a 128-bit strength encryption key required.\n + * Security Mode 2 Level 1: Signing or encryption required, MITM protection not necessary.\n + * Security Mode 2 Level 2: MITM protected signing required, unless link is MITM protected encrypted.\n + */ +typedef struct +{ + uint8_t sm : 4; /**< Security Mode (1 or 2), 0 for no permissions at all. */ + uint8_t lv : 4; /**< Level (1, 2, 3 or 4), 0 for no permissions at all. */ + +} ble_gap_conn_sec_mode_t; + + +/**@brief GAP connection security status.*/ +typedef struct +{ + ble_gap_conn_sec_mode_t sec_mode; /**< Currently active security mode for this connection.*/ + uint8_t encr_key_size; /**< Length of currently active encryption key, 7 to 16 octets (only applicable for bonding procedures). */ +} ble_gap_conn_sec_t; + +/**@brief Identity Resolving Key. */ +typedef struct +{ + uint8_t irk[BLE_GAP_SEC_KEY_LEN]; /**< Array containing IRK. */ +} ble_gap_irk_t; + + +/**@brief Channel mask (40 bits). + * Every channel is represented with a bit positioned as per channel index defined in Bluetooth Core Specification v5.0, + * Vol 6, Part B, Section 1.4.1. The LSB contained in array element 0 represents channel index 0, and bit 39 represents + * channel index 39. If a bit is set to 1, the channel is not used. + */ +typedef uint8_t ble_gap_ch_mask_t[5]; + + +/**@brief GAP advertising parameters. */ +typedef struct +{ + ble_gap_adv_properties_t properties; /**< The properties of the advertising events. */ + ble_gap_addr_t const *p_peer_addr; /**< Address of a known peer. + @note ble_gap_addr_t::addr_type cannot be + @ref BLE_GAP_ADDR_TYPE_ANONYMOUS. + - When privacy is enabled and the local device uses + @ref BLE_GAP_ADDR_TYPE_RANDOM_PRIVATE_RESOLVABLE addresses, + the device identity list is searched for a matching entry. If + the local IRK for that device identity is set, the local IRK + for that device will be used to generate the advertiser address + field in the advertising packet. + - If @ref ble_gap_adv_properties_t::type is directed, this must be + set to the targeted scanner or initiator. If the peer address is + in the device identity list, the peer IRK for that device will be + used to generate @ref BLE_GAP_ADDR_TYPE_RANDOM_PRIVATE_RESOLVABLE + target addresses used in the advertising event PDUs. */ + uint32_t interval; /**< Advertising interval in 625 us units. @sa BLE_GAP_ADV_INTERVALS. + @note If @ref ble_gap_adv_properties_t::type is set to + @ref BLE_GAP_ADV_TYPE_CONNECTABLE_NONSCANNABLE_DIRECTED_HIGH_DUTY_CYCLE + advertising, this parameter is ignored. */ + uint16_t duration; /**< Advertising duration in 10 ms units. When timeout is reached, + an event of type @ref BLE_GAP_EVT_ADV_SET_TERMINATED is raised. + @sa BLE_GAP_ADV_TIMEOUT_VALUES. */ + uint8_t max_adv_evts; /**< Maximum advertising events that shall be sent prior to disabling + advertising. Setting the value to 0 disables the limitation. When + the count of advertising events specified by this parameter + (if not 0) is reached, advertising will be automatically stopped + and an event of type @ref BLE_GAP_EVT_ADV_SET_TERMINATED is raised + @note If @ref ble_gap_adv_properties_t::type is set to + @ref BLE_GAP_ADV_TYPE_CONNECTABLE_NONSCANNABLE_DIRECTED_HIGH_DUTY_CYCLE, + this parameter is ignored. + @note Setting max_adv_evts to a values not equal to 0 is only supported + as an experimental feature in this SoftDevice. */ + ble_gap_ch_mask_t channel_mask; /**< Channel mask for primary and secondary advertising channels. + At least one of the primary channels, that is channel index 37-39, must be used. + Masking away secondary advertising channels is not supported. */ + uint8_t filter_policy; /**< Filter Policy. @sa BLE_GAP_ADV_FILTER_POLICIES. */ + uint8_t primary_phy; /**< Indicates the PHY on which the primary advertising channel packets + are transmitted. If set to @ref BLE_GAP_PHY_AUTO, @ref BLE_GAP_PHY_1MBPS + will be used. + The only supported value by this SoftDevice is @ref BLE_GAP_PHY_1MBPS. */ + uint8_t secondary_phy; /**< Indicates the PHY on which the secondary advertising channel packets + are transmitted. + If set to @ref BLE_GAP_PHY_AUTO, @ref BLE_GAP_PHY_1MBPS will be used. + Valid values are + @ref BLE_GAP_PHY_1MBPS and @ref BLE_GAP_PHY_2MBPS. @ref BLE_GAP_PHY_CODED + is not supported by this SoftDevice. + If @ref ble_gap_adv_properties_t::type is an extended advertising type + and connectable, this is the PHY that will be used to establish a + connection and send AUX_ADV_IND packets on. + @note This parameter will be ignored when + @ref ble_gap_adv_properties_t::type is not an extended advertising type. */ + uint8_t set_id:4; /**< The advertising set identifier distinguishes this advertising set from other + advertising sets transmitted by this and other devices. + @note This parameter will be ignored when + @ref ble_gap_adv_properties_t::type is not an extended advertising type. */ + uint8_t scan_req_notification:1; /**< Enable scan request notifications for this advertising set. When a + scan request is received and the scanner address is allowed + by the filter policy, @ref BLE_GAP_EVT_SCAN_REQ_REPORT is raised. + @note This parameter will be ignored when + @ref ble_gap_adv_properties_t::type is a non-scannable + advertising type. */ +} ble_gap_adv_params_t; + + +/**@brief GAP advertising data buffers. + * + * The application must provide the buffers for advertisement. The memory shall reside in application RAM, and + * shall never be modified while advertising. The data shall be kept alive until either: + * - @ref BLE_GAP_EVT_ADV_SET_TERMINATED is raised. + * - @ref BLE_GAP_EVT_CONNECTED is raised with @ref ble_gap_evt_connected_t::adv_handle set to the corresponding + * advertising handle. + * - Advertising is stopped. + * - Advertising data is changed. + * To update advertising data while advertising, provide new buffers to @ref sd_ble_gap_adv_set_configure. */ +typedef struct +{ + ble_data_t adv_data; /**< Advertising data. + @note + Advertising data can only be specified for a @ref ble_gap_adv_properties_t::type + that is allowed to contain advertising data. */ + ble_data_t scan_rsp_data; /**< Scan response data. + @note + Scan response data can only be specified for a @ref ble_gap_adv_properties_t::type + that is scannable. */ +} ble_gap_adv_data_t; + + +/**@brief GAP scanning parameters. */ +typedef struct +{ + uint8_t extended : 1; /**< If 1, the scanner will accept extended advertising packets. + If set to 0, the scanner will not receive advertising packets + on secondary advertising channels, and will not be able + to receive long advertising PDUs. + @note Extended scanning is only supported as an experimental feature in this + SoftDevice. */ + uint8_t report_incomplete_evts : 1; /**< If 1, events of type @ref ble_gap_evt_adv_report_t may have + @ref ble_gap_adv_report_type_t::status set to + @ref BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_MORE_DATA. + This parameter is ignored when used with @ref sd_ble_gap_connect + @note This may be used to abort receiving more packets from an extended + advertising event, and is only available for extended + scanning, see @ref sd_ble_gap_scan_start. + @note This feature is not supported by this SoftDevice. */ + uint8_t active : 1; /**< If 1, perform active scanning by sending scan requests. + This parameter is ignored when used with @ref sd_ble_gap_connect. */ + uint8_t filter_policy : 2; /**< Scanning filter policy. @sa BLE_GAP_SCAN_FILTER_POLICIES. + @note Only @ref BLE_GAP_SCAN_FP_ACCEPT_ALL and + @ref BLE_GAP_SCAN_FP_WHITELIST are valid when used with + @ref sd_ble_gap_connect */ + uint8_t scan_phys; /**< Bitfield of PHYs to scan on. If set to @ref BLE_GAP_PHY_AUTO, + scan_phys will default to @ref BLE_GAP_PHY_1MBPS. + - If @ref ble_gap_scan_params_t::extended is set to 0, the only + supported PHY is @ref BLE_GAP_PHY_1MBPS. + - When used with @ref sd_ble_gap_scan_start, + the bitfield indicates the PHYs the scanner will use for scanning + on primary advertising channels. The scanner will accept + @ref BLE_GAP_PHYS_SUPPORTED as secondary advertising channel PHYs. + - When used with @ref sd_ble_gap_connect, the + bitfield indicates the PHYs on where a connection may be initiated. + If scan_phys contains @ref BLE_GAP_PHY_1MBPS and/or @ref BLE_GAP_PHY_2MBPS, + the primary scan PHY is @ref BLE_GAP_PHY_1MBPS. */ + uint16_t interval; /**< Scan interval in 625 us units. @sa BLE_GAP_SCAN_INTERVALS. */ + uint16_t window; /**< Scan window in 625 us units. @sa BLE_GAP_SCAN_WINDOW. */ + uint16_t timeout; /**< Scan timeout in 10 ms units. @sa BLE_GAP_SCAN_TIMEOUT. */ + ble_gap_ch_mask_t channel_mask; /**< Channel mask for primary and secondary advertising channels. + At least one of the primary channels, that is channel index 37-39, must be + set to 0. + Masking away secondary channels is not supported. */ +} ble_gap_scan_params_t; + + +/**@brief Privacy. + * + * The privacy feature provides a way for the device to avoid being tracked over a period of time. + * The privacy feature, when enabled, hides the local device identity and replaces it with a private address + * that is automatically refreshed at a specified interval. + * + * If a device still wants to be recognized by other peers, it needs to share it's Identity Resolving Key (IRK). + * With this key, a device can generate a random private address that can only be recognized by peers in possession of that key, + * and devices can establish connections without revealing their real identities. + * + * Both network privacy (@ref BLE_GAP_PRIVACY_MODE_NETWORK_PRIVACY) and device privacy (@ref BLE_GAP_PRIVACY_MODE_DEVICE_PRIVACY) + * are supported. + * + * @note If the device IRK is updated, the new IRK becomes the one to be distributed in all + * bonding procedures performed after @ref sd_ble_gap_privacy_set returns. + * The IRK distributed during bonding procedure is the device IRK that is active when @ref sd_ble_gap_sec_params_reply is called. + */ +typedef struct +{ + uint8_t privacy_mode; /**< Privacy mode, see @ref BLE_GAP_PRIVACY_MODES. Default is @ref BLE_GAP_PRIVACY_MODE_OFF. */ + uint8_t private_addr_type; /**< The private address type must be either @ref BLE_GAP_ADDR_TYPE_RANDOM_PRIVATE_RESOLVABLE or @ref BLE_GAP_ADDR_TYPE_RANDOM_PRIVATE_NON_RESOLVABLE. */ + uint16_t private_addr_cycle_s; /**< Private address cycle interval in seconds. Providing an address cycle value of 0 will use the default value defined by @ref BLE_GAP_DEFAULT_PRIVATE_ADDR_CYCLE_INTERVAL_S. */ + ble_gap_irk_t *p_device_irk; /**< When used as input, pointer to IRK structure that will be used as the default IRK. If NULL, the device default IRK will be used. + When used as output, pointer to IRK structure where the current default IRK will be written to. If NULL, this argument is ignored. + By default, the default IRK is used to generate random private resolvable addresses for the local device unless instructed otherwise. */ +} ble_gap_privacy_params_t; + + +/**@brief PHY preferences for TX and RX + * @note tx_phys and rx_phys are bit fields. Multiple bits can be set in them to indicate multiple preferred PHYs for each direction. + * @code + * p_gap_phys->tx_phys = BLE_GAP_PHY_1MBPS | BLE_GAP_PHY_2MBPS; + * p_gap_phys->rx_phys = BLE_GAP_PHY_1MBPS | BLE_GAP_PHY_2MBPS; + * @endcode + * + */ +typedef struct +{ + uint8_t tx_phys; /**< Preferred transmit PHYs, see @ref BLE_GAP_PHYS. */ + uint8_t rx_phys; /**< Preferred receive PHYs, see @ref BLE_GAP_PHYS. */ +} ble_gap_phys_t; + +/** @brief Keys that can be exchanged during a bonding procedure. */ +typedef struct +{ + uint8_t enc : 1; /**< Long Term Key and Master Identification. */ + uint8_t id : 1; /**< Identity Resolving Key and Identity Address Information. */ + uint8_t sign : 1; /**< Connection Signature Resolving Key. */ + uint8_t link : 1; /**< Derive the Link Key from the LTK. */ +} ble_gap_sec_kdist_t; + + +/**@brief GAP security parameters. */ +typedef struct +{ + uint8_t bond : 1; /**< Perform bonding. */ + uint8_t mitm : 1; /**< Enable Man In The Middle protection. */ + uint8_t lesc : 1; /**< Enable LE Secure Connection pairing. */ + uint8_t keypress : 1; /**< Enable generation of keypress notifications. */ + uint8_t io_caps : 3; /**< IO capabilities, see @ref BLE_GAP_IO_CAPS. */ + uint8_t oob : 1; /**< The OOB data flag. + - In LE legacy pairing, this flag is set if a device has out of band authentication data. + The OOB method is used if both of the devices have out of band authentication data. + - In LE Secure Connections pairing, this flag is set if a device has the peer device's out of band authentication data. + The OOB method is used if at least one device has the peer device's OOB data available. */ + uint8_t min_key_size; /**< Minimum encryption key size in octets between 7 and 16. If 0 then not applicable in this instance. */ + uint8_t max_key_size; /**< Maximum encryption key size in octets between min_key_size and 16. */ + ble_gap_sec_kdist_t kdist_own; /**< Key distribution bitmap: keys that the local device will distribute. */ + ble_gap_sec_kdist_t kdist_peer; /**< Key distribution bitmap: keys that the remote device will distribute. */ +} ble_gap_sec_params_t; + + +/**@brief GAP Encryption Information. */ +typedef struct +{ + uint8_t ltk[BLE_GAP_SEC_KEY_LEN]; /**< Long Term Key. */ + uint8_t lesc : 1; /**< Key generated using LE Secure Connections. */ + uint8_t auth : 1; /**< Authenticated Key. */ + uint8_t ltk_len : 6; /**< LTK length in octets. */ +} ble_gap_enc_info_t; + + +/**@brief GAP Master Identification. */ +typedef struct +{ + uint16_t ediv; /**< Encrypted Diversifier. */ + uint8_t rand[BLE_GAP_SEC_RAND_LEN]; /**< Random Number. */ +} ble_gap_master_id_t; + + +/**@brief GAP Signing Information. */ +typedef struct +{ + uint8_t csrk[BLE_GAP_SEC_KEY_LEN]; /**< Connection Signature Resolving Key. */ +} ble_gap_sign_info_t; + + +/**@brief GAP LE Secure Connections P-256 Public Key. */ +typedef struct +{ + uint8_t pk[BLE_GAP_LESC_P256_PK_LEN]; /**< LE Secure Connections Elliptic Curve Diffie-Hellman P-256 Public Key. Stored in the standard SMP protocol format: {X,Y} both in little-endian. */ +} ble_gap_lesc_p256_pk_t; + + +/**@brief GAP LE Secure Connections DHKey. */ +typedef struct +{ + uint8_t key[BLE_GAP_LESC_DHKEY_LEN]; /**< LE Secure Connections Elliptic Curve Diffie-Hellman Key. Stored in little-endian. */ +} ble_gap_lesc_dhkey_t; + + +/**@brief GAP LE Secure Connections OOB data. */ +typedef struct +{ + ble_gap_addr_t addr; /**< Bluetooth address of the device. */ + uint8_t r[BLE_GAP_SEC_KEY_LEN]; /**< Random Number. */ + uint8_t c[BLE_GAP_SEC_KEY_LEN]; /**< Confirm Value. */ +} ble_gap_lesc_oob_data_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_CONNECTED. */ +typedef struct +{ + ble_gap_addr_t peer_addr; /**< Bluetooth address of the peer device. If the peer_addr resolved: @ref ble_gap_addr_t::addr_id_peer is set to 1 + and the address is the device's identity address. */ + uint8_t role; /**< BLE role for this connection, see @ref BLE_GAP_ROLES */ + ble_gap_conn_params_t conn_params; /**< GAP Connection Parameters. */ + uint8_t adv_handle; /**< Advertising handle in which advertising has ended. + This variable is only set if role is set to @ref BLE_GAP_ROLE_PERIPH. */ + ble_gap_adv_data_t adv_data; /**< Advertising buffers corresponding to the terminated + advertising set. The advertising buffers provided in + @ref sd_ble_gap_adv_set_configure are now released. + This variable is only set if role is set to @ref BLE_GAP_ROLE_PERIPH. */ +} ble_gap_evt_connected_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_DISCONNECTED. */ +typedef struct +{ + uint8_t reason; /**< HCI error code, see @ref BLE_HCI_STATUS_CODES. */ +} ble_gap_evt_disconnected_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_CONN_PARAM_UPDATE. */ +typedef struct +{ + ble_gap_conn_params_t conn_params; /**< GAP Connection Parameters. */ +} ble_gap_evt_conn_param_update_t; + +/**@brief Event structure for @ref BLE_GAP_EVT_PHY_UPDATE_REQUEST. */ +typedef struct +{ + ble_gap_phys_t peer_preferred_phys; /**< The PHYs the peer prefers to use. */ +} ble_gap_evt_phy_update_request_t; + +/**@brief Event Structure for @ref BLE_GAP_EVT_PHY_UPDATE. */ +typedef struct +{ + uint8_t status; /**< Status of the procedure, see @ref BLE_HCI_STATUS_CODES.*/ + uint8_t tx_phy; /**< TX PHY for this connection, see @ref BLE_GAP_PHYS. */ + uint8_t rx_phy; /**< RX PHY for this connection, see @ref BLE_GAP_PHYS. */ +} ble_gap_evt_phy_update_t; + +/**@brief Event structure for @ref BLE_GAP_EVT_SEC_PARAMS_REQUEST. */ +typedef struct +{ + ble_gap_sec_params_t peer_params; /**< Initiator Security Parameters. */ +} ble_gap_evt_sec_params_request_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_SEC_INFO_REQUEST. */ +typedef struct +{ + ble_gap_addr_t peer_addr; /**< Bluetooth address of the peer device. */ + ble_gap_master_id_t master_id; /**< Master Identification for LTK lookup. */ + uint8_t enc_info : 1; /**< If 1, Encryption Information required. */ + uint8_t id_info : 1; /**< If 1, Identity Information required. */ + uint8_t sign_info : 1; /**< If 1, Signing Information required. */ +} ble_gap_evt_sec_info_request_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_PASSKEY_DISPLAY. */ +typedef struct +{ + uint8_t passkey[BLE_GAP_PASSKEY_LEN]; /**< 6-digit passkey in ASCII ('0'-'9' digits only). */ + uint8_t match_request : 1; /**< If 1 requires the application to report the match using @ref sd_ble_gap_auth_key_reply + with either @ref BLE_GAP_AUTH_KEY_TYPE_NONE if there is no match or + @ref BLE_GAP_AUTH_KEY_TYPE_PASSKEY if there is a match. */ +} ble_gap_evt_passkey_display_t; + +/**@brief Event structure for @ref BLE_GAP_EVT_KEY_PRESSED. */ +typedef struct +{ + uint8_t kp_not; /**< Keypress notification type, see @ref BLE_GAP_KP_NOT_TYPES. */ +} ble_gap_evt_key_pressed_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_AUTH_KEY_REQUEST. */ +typedef struct +{ + uint8_t key_type; /**< See @ref BLE_GAP_AUTH_KEY_TYPES. */ +} ble_gap_evt_auth_key_request_t; + +/**@brief Event structure for @ref BLE_GAP_EVT_LESC_DHKEY_REQUEST. */ +typedef struct +{ + ble_gap_lesc_p256_pk_t *p_pk_peer; /**< LE Secure Connections remote P-256 Public Key. This will point to the application-supplied memory + inside the keyset during the call to @ref sd_ble_gap_sec_params_reply. */ + uint8_t oobd_req :1; /**< LESC OOB data required. A call to @ref sd_ble_gap_lesc_oob_data_set is required to complete the procedure. */ +} ble_gap_evt_lesc_dhkey_request_t; + + +/**@brief Security levels supported. + * @note See Bluetooth Specification Version 4.2 Volume 3, Part C, Chapter 10, Section 10.2.1. +*/ +typedef struct +{ + uint8_t lv1 : 1; /**< If 1: Level 1 is supported. */ + uint8_t lv2 : 1; /**< If 1: Level 2 is supported. */ + uint8_t lv3 : 1; /**< If 1: Level 3 is supported. */ + uint8_t lv4 : 1; /**< If 1: Level 4 is supported. */ +} ble_gap_sec_levels_t; + + +/**@brief Encryption Key. */ +typedef struct +{ + ble_gap_enc_info_t enc_info; /**< Encryption Information. */ + ble_gap_master_id_t master_id; /**< Master Identification. */ +} ble_gap_enc_key_t; + + +/**@brief Identity Key. */ +typedef struct +{ + ble_gap_irk_t id_info; /**< Identity Resolving Key. */ + ble_gap_addr_t id_addr_info; /**< Identity Address. */ +} ble_gap_id_key_t; + + +/**@brief Security Keys. */ +typedef struct +{ + ble_gap_enc_key_t *p_enc_key; /**< Encryption Key, or NULL. */ + ble_gap_id_key_t *p_id_key; /**< Identity Key, or NULL. */ + ble_gap_sign_info_t *p_sign_key; /**< Signing Key, or NULL. */ + ble_gap_lesc_p256_pk_t *p_pk; /**< LE Secure Connections P-256 Public Key. When in debug mode the application must use the value defined + in the Core Bluetooth Specification v4.2 Vol.3, Part H, Section 2.3.5.6.1 */ +} ble_gap_sec_keys_t; + + +/**@brief Security key set for both local and peer keys. */ +typedef struct +{ + ble_gap_sec_keys_t keys_own; /**< Keys distributed by the local device. For LE Secure Connections the encryption key will be generated locally and will always be stored if bonding. */ + ble_gap_sec_keys_t keys_peer; /**< Keys distributed by the remote device. For LE Secure Connections, p_enc_key must always be NULL. */ +} ble_gap_sec_keyset_t; + + +/**@brief Data Length Update Procedure parameters. */ +typedef struct +{ + uint16_t max_tx_octets; /**< Maximum number of payload octets that a Controller supports for transmission of a single Link Layer Data Channel PDU. */ + uint16_t max_rx_octets; /**< Maximum number of payload octets that a Controller supports for reception of a single Link Layer Data Channel PDU. */ + uint16_t max_tx_time_us; /**< Maximum time, in microseconds, that a Controller supports for transmission of a single Link Layer Data Channel PDU. */ + uint16_t max_rx_time_us; /**< Maximum time, in microseconds, that a Controller supports for reception of a single Link Layer Data Channel PDU. */ +} ble_gap_data_length_params_t; + + +/**@brief Data Length Update Procedure local limitation. */ +typedef struct +{ + uint16_t tx_payload_limited_octets; /**< If > 0, the requested TX packet length is too long by this many octets. */ + uint16_t rx_payload_limited_octets; /**< If > 0, the requested RX packet length is too long by this many octets. */ + uint16_t tx_rx_time_limited_us; /**< If > 0, the requested combination of TX and RX packet lengths is too long by this many microseconds. */ +} ble_gap_data_length_limitation_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_AUTH_STATUS. */ +typedef struct +{ + uint8_t auth_status; /**< Authentication status, see @ref BLE_GAP_SEC_STATUS. */ + uint8_t error_src : 2; /**< On error, source that caused the failure, see @ref BLE_GAP_SEC_STATUS_SOURCES. */ + uint8_t bonded : 1; /**< Procedure resulted in a bond. */ + uint8_t lesc : 1; /**< Procedure resulted in a LE Secure Connection. */ + ble_gap_sec_levels_t sm1_levels; /**< Levels supported in Security Mode 1. */ + ble_gap_sec_levels_t sm2_levels; /**< Levels supported in Security Mode 2. */ + ble_gap_sec_kdist_t kdist_own; /**< Bitmap stating which keys were exchanged (distributed) by the local device. If bonding with LE Secure Connections, the enc bit will be always set. */ + ble_gap_sec_kdist_t kdist_peer; /**< Bitmap stating which keys were exchanged (distributed) by the remote device. If bonding with LE Secure Connections, the enc bit will never be set. */ +} ble_gap_evt_auth_status_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_CONN_SEC_UPDATE. */ +typedef struct +{ + ble_gap_conn_sec_t conn_sec; /**< Connection security level. */ +} ble_gap_evt_conn_sec_update_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_TIMEOUT. */ +typedef struct +{ + uint8_t src; /**< Source of timeout event, see @ref BLE_GAP_TIMEOUT_SOURCES. */ + union + { + ble_data_t adv_report_buffer; /**< If source is set to @ref BLE_GAP_TIMEOUT_SRC_SCAN, the released + scan buffer is contained in this field. */ + } params; /**< Event Parameters. */ +} ble_gap_evt_timeout_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_RSSI_CHANGED. */ +typedef struct +{ + int8_t rssi; /**< Received Signal Strength Indication in dBm. */ + uint8_t ch_index; /**< Data Channel Index on which the Signal Strength is measured (0-36). */ +} ble_gap_evt_rssi_changed_t; + +/**@brief Event structure for @ref BLE_GAP_EVT_ADV_SET_TERMINATED */ +typedef struct +{ + uint8_t reason; /**< Reason for why the advertising set terminated. See + @ref BLE_GAP_EVT_ADV_SET_TERMINATED_REASON. */ + uint8_t adv_handle; /**< Advertising handle in which advertising has ended. */ + uint8_t num_completed_adv_events; /**< If @ref ble_gap_adv_params_t::max_adv_evts was not set to 0, + this field indicates the number of completed advertising events. */ + ble_gap_adv_data_t adv_data; /**< Advertising buffers corresponding to the terminated + advertising set. The advertising buffers provided in + @ref sd_ble_gap_adv_set_configure are now released. */ +} ble_gap_evt_adv_set_terminated_t; + +/**@brief Event structure for @ref BLE_GAP_EVT_ADV_REPORT. + * + * @note If @ref ble_gap_adv_report_type_t::status is set to @ref BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_MORE_DATA, + * not all fields in the advertising report may be available. + * + * @note When ble_gap_adv_report_type_t::status is not set to @ref BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_MORE_DATA, + * scanning will be paused. To continue scanning, call @ref sd_ble_gap_scan_start. + */ +typedef struct +{ + ble_gap_adv_report_type_t type; /**< Advertising report type. See @ref ble_gap_adv_report_type_t. */ + ble_gap_addr_t peer_addr; /**< Bluetooth address of the peer device. If the peer_addr is resolved: + @ref ble_gap_addr_t::addr_id_peer is set to 1 and the address is the + peer's identity address. */ + ble_gap_addr_t direct_addr; /**< Contains the target address of the advertising event if + @ref ble_gap_adv_report_type_t::directed is set to 1. If the + SoftDevice was able to resolve the address, + @ref ble_gap_addr_t::addr_id_peer is set to 1 and the direct_addr + contains the local identity address. If the target address of the + advertising event is @ref BLE_GAP_ADDR_TYPE_RANDOM_PRIVATE_RESOLVABLE, + and the SoftDevice was unable to resolve it, the application may try + to resolve this address to find out if the advertising event was + directed to us. */ + uint8_t primary_phy; /**< Indicates the PHY on which the primary advertising packet was received on. + See @ref BLE_GAP_PHYS. */ + uint8_t secondary_phy; /**< Indicates the PHY on which the secondary advertising packet was received on. + See @ref BLE_GAP_PHYS. This field is to 0 if no packets where received on + a secondary advertising channel. */ + int8_t tx_power; /**< TX Power reported by the advertiser in the last packet header received. + This field is set to @ref BLE_GAP_POWER_LEVEL_INVALID if the + last received packet did not contain the Tx Power field. + @note TX Power is only included in extended advertising packets. */ + int8_t rssi; /**< Received Signal Strength Indication in dBm of the last packet received. */ + uint8_t ch_index; /**< Channel Index on which the last advertising packet is received (0-39). */ + uint8_t set_id; /**< Set ID of the received advertising data. Set ID is not present + if set to @ref BLE_GAP_ADV_REPORT_SET_ID_NOT_AVAILABLE. */ + uint16_t data_id:12; /**< The advertising data ID of the received advertising data. Data ID + is not present if @ref ble_gap_evt_adv_report_t::set_id is set to + @ref BLE_GAP_ADV_REPORT_SET_ID_NOT_AVAILABLE. */ + ble_data_t data; /**< Received advertising or scan response data. If + @ref ble_gap_adv_report_type_t::status is not set to + @ref BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_MORE_DATA, the data buffer provided + in @ref sd_ble_gap_scan_start is now released. */ + ble_gap_aux_pointer_t aux_pointer; /**< The offset and PHY of the next advertising packet in this extended advertising + event. @note This field is only set if @ref ble_gap_adv_report_type_t::status + is set to @ref BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_MORE_DATA. */ +} ble_gap_evt_adv_report_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_SEC_REQUEST. */ +typedef struct +{ + uint8_t bond : 1; /**< Perform bonding. */ + uint8_t mitm : 1; /**< Man In The Middle protection requested. */ + uint8_t lesc : 1; /**< LE Secure Connections requested. */ + uint8_t keypress : 1; /**< Generation of keypress notifications requested. */ +} ble_gap_evt_sec_request_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_CONN_PARAM_UPDATE_REQUEST. */ +typedef struct +{ + ble_gap_conn_params_t conn_params; /**< GAP Connection Parameters. */ +} ble_gap_evt_conn_param_update_request_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_SCAN_REQ_REPORT. */ +typedef struct +{ + uint8_t adv_handle; /**< Advertising handle for the advertising set which received the Scan Request */ + int8_t rssi; /**< Received Signal Strength Indication in dBm. */ + ble_gap_addr_t peer_addr; /**< Bluetooth address of the peer device. If the peer_addr resolved: @ref ble_gap_addr_t::addr_id_peer is set to 1 + and the address is the device's identity address. */ +} ble_gap_evt_scan_req_report_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_DATA_LENGTH_UPDATE_REQUEST. */ +typedef struct +{ + ble_gap_data_length_params_t peer_params; /**< Peer data length parameters. */ +} ble_gap_evt_data_length_update_request_t; + +/**@brief Event structure for @ref BLE_GAP_EVT_DATA_LENGTH_UPDATE. */ +typedef struct +{ + ble_gap_data_length_params_t effective_params; /**< The effective data length parameters. */ +} ble_gap_evt_data_length_update_t; + + +/**@brief Event structure for @ref BLE_GAP_EVT_QOS_CHANNEL_SURVEY_REPORT. */ +typedef struct +{ + int8_t channel_energy[BLE_GAP_CHANNEL_COUNT]; /**< The measured energy on the Bluetooth Low Energy + channels, in dBm, indexed by Channel Index. + If no measurement is available for the given channel, channel_energy is set to + @ref BLE_GAP_POWER_LEVEL_INVALID. */ +} ble_gap_evt_qos_channel_survey_report_t; + +/**@brief GAP event structure. */ +typedef struct +{ + uint16_t conn_handle; /**< Connection Handle on which event occurred. */ + union /**< union alternative identified by evt_id in enclosing struct. */ + { + ble_gap_evt_connected_t connected; /**< Connected Event Parameters. */ + ble_gap_evt_disconnected_t disconnected; /**< Disconnected Event Parameters. */ + ble_gap_evt_conn_param_update_t conn_param_update; /**< Connection Parameter Update Parameters. */ + ble_gap_evt_sec_params_request_t sec_params_request; /**< Security Parameters Request Event Parameters. */ + ble_gap_evt_sec_info_request_t sec_info_request; /**< Security Information Request Event Parameters. */ + ble_gap_evt_passkey_display_t passkey_display; /**< Passkey Display Event Parameters. */ + ble_gap_evt_key_pressed_t key_pressed; /**< Key Pressed Event Parameters. */ + ble_gap_evt_auth_key_request_t auth_key_request; /**< Authentication Key Request Event Parameters. */ + ble_gap_evt_lesc_dhkey_request_t lesc_dhkey_request; /**< LE Secure Connections DHKey calculation request. */ + ble_gap_evt_auth_status_t auth_status; /**< Authentication Status Event Parameters. */ + ble_gap_evt_conn_sec_update_t conn_sec_update; /**< Connection Security Update Event Parameters. */ + ble_gap_evt_timeout_t timeout; /**< Timeout Event Parameters. */ + ble_gap_evt_rssi_changed_t rssi_changed; /**< RSSI Event Parameters. */ + ble_gap_evt_adv_report_t adv_report; /**< Advertising Report Event Parameters. */ + ble_gap_evt_adv_set_terminated_t adv_set_terminated; /**< Advertising Set Terminated Event Parameters. */ + ble_gap_evt_sec_request_t sec_request; /**< Security Request Event Parameters. */ + ble_gap_evt_conn_param_update_request_t conn_param_update_request; /**< Connection Parameter Update Parameters. */ + ble_gap_evt_scan_req_report_t scan_req_report; /**< Scan Request Report Parameters. */ + ble_gap_evt_phy_update_request_t phy_update_request; /**< PHY Update Request Event Parameters. */ + ble_gap_evt_phy_update_t phy_update; /**< PHY Update Parameters. */ + ble_gap_evt_data_length_update_request_t data_length_update_request; /**< Data Length Update Request Event Parameters. */ + ble_gap_evt_data_length_update_t data_length_update; /**< Data Length Update Event Parameters. */ + ble_gap_evt_qos_channel_survey_report_t qos_channel_survey_report; /**< Quality of Service (QoS) Channel Survey Report Parameters. */ + } params; /**< Event Parameters. */ +} ble_gap_evt_t; + + +/** + * @brief BLE GAP connection configuration parameters, set with @ref sd_ble_cfg_set. + * + * @retval ::NRF_ERROR_CONN_COUNT The connection count for the connection configurations is zero. + * @retval ::NRF_ERROR_INVALID_PARAM One or more of the following is true: + * - The sum of conn_count for all connection configurations combined exceeds UINT8_MAX. + * - The event length is smaller than @ref BLE_GAP_EVENT_LENGTH_MIN. + */ +typedef struct +{ + uint8_t conn_count; /**< The number of concurrent connections the application can create with this configuration. + The default and minimum value is @ref BLE_GAP_CONN_COUNT_DEFAULT. */ + uint16_t event_length; /**< The time set aside for this connection on every connection interval in 1.25 ms units. + The default value is @ref BLE_GAP_EVENT_LENGTH_DEFAULT, the minimum value is @ref BLE_GAP_EVENT_LENGTH_MIN. + The event length and the connection interval are the primary parameters + for setting the throughput of a connection. + See the SoftDevice Specification for details on throughput. */ +} ble_gap_conn_cfg_t; + + +/** + * @brief Configuration of maximum concurrent connections in the different connected roles, set with + * @ref sd_ble_cfg_set. + * + * @retval ::NRF_ERROR_CONN_COUNT The sum of periph_role_count and central_role_count is too + * large. The maximum supported sum of concurrent connections is + * @ref BLE_GAP_ROLE_COUNT_COMBINED_MAX. + * @retval ::NRF_ERROR_INVALID_PARAM central_sec_count is larger than central_role_count. + * @retval ::NRF_ERROR_RESOURCES The adv_set_count is too large. The maximum + * supported advertising handles is + * @ref BLE_GAP_ADV_SET_COUNT_MAX. + */ +typedef struct +{ + uint8_t adv_set_count; /**< Maximum number of advertising sets. Default value is @ref BLE_GAP_ADV_SET_COUNT_DEFAULT. */ + uint8_t periph_role_count; /**< Maximum number of connections concurrently acting as a peripheral. Default value is @ref BLE_GAP_ROLE_COUNT_PERIPH_DEFAULT. */ + uint8_t central_role_count; /**< Maximum number of connections concurrently acting as a central. Default value is @ref BLE_GAP_ROLE_COUNT_CENTRAL_DEFAULT. */ + uint8_t central_sec_count; /**< Number of SMP instances shared between all connections acting as a central. Default value is @ref BLE_GAP_ROLE_COUNT_CENTRAL_SEC_DEFAULT. */ + uint8_t qos_channel_survey_role_available:1; /**< If set, the Quality of Service (QoS) channel survey module is available to the + application using @ref sd_ble_gap_qos_channel_survey_start. */ +} ble_gap_cfg_role_count_t; + + +/** + * @brief Device name and its properties, set with @ref sd_ble_cfg_set. + * + * @note If the device name is not configured, the default device name will be + * @ref BLE_GAP_DEVNAME_DEFAULT, the maximum device name length will be + * @ref BLE_GAP_DEVNAME_DEFAULT_LEN, vloc will be set to @ref BLE_GATTS_VLOC_STACK and the device name + * will have no write access. + * + * @note If @ref max_len is more than @ref BLE_GAP_DEVNAME_DEFAULT_LEN and vloc is set to @ref BLE_GATTS_VLOC_STACK, + * the attribute table size must be increased to have room for the longer device name (see + * @ref sd_ble_cfg_set and @ref ble_gatts_cfg_attr_tab_size_t). + * + * @note If vloc is @ref BLE_GATTS_VLOC_STACK : + * - p_value must point to non-volatile memory (flash) or be NULL. + * - If p_value is NULL, the device name will initially be empty. + * + * @note If vloc is @ref BLE_GATTS_VLOC_USER : + * - p_value cannot be NULL. + * - If the device name is writable, p_value must point to volatile memory (RAM). + * + * @retval ::NRF_ERROR_INVALID_PARAM One or more of the following is true: + * - Invalid device name location (vloc). + * - Invalid device name security mode. + * @retval ::NRF_ERROR_INVALID_LENGTH One or more of the following is true: + * - The device name length is invalid (must be between 0 and @ref BLE_GAP_DEVNAME_MAX_LEN). + * - The device name length is too long for the given Attribute Table. + * @retval ::NRF_ERROR_NOT_SUPPORTED Device name security mode is not supported. + */ +typedef struct +{ + ble_gap_conn_sec_mode_t write_perm; /**< Write permissions. */ + uint8_t vloc:2; /**< Value location, see @ref BLE_GATTS_VLOCS.*/ + uint8_t *p_value; /**< Pointer to where the value (device name) is stored or will be stored. */ + uint16_t current_len; /**< Current length in bytes of the memory pointed to by p_value.*/ + uint16_t max_len; /**< Maximum length in bytes of the memory pointed to by p_value.*/ +} ble_gap_cfg_device_name_t; + + +/**@brief Configuration structure for GAP configurations. */ +typedef union +{ + ble_gap_cfg_role_count_t role_count_cfg; /**< Role count configuration, cfg_id is @ref BLE_GAP_CFG_ROLE_COUNT. */ + ble_gap_cfg_device_name_t device_name_cfg; /**< Device name configuration, cfg_id is @ref BLE_GAP_CFG_DEVICE_NAME. */ +} ble_gap_cfg_t; + + +/**@brief Channel Map option. + * + * @details Used with @ref sd_ble_opt_get to get the current channel map + * or @ref sd_ble_opt_set to set a new channel map. When setting the + * channel map, it applies to all current and future connections. When getting the + * current channel map, it applies to a single connection and the connection handle + * must be supplied. + * + * @note Setting the channel map may take some time, depending on connection parameters. + * The time taken may be different for each connection and the get operation will + * return the previous channel map until the new one has taken effect. + * + * @note After setting the channel map, by spec it can not be set again until at least 1 s has passed. + * See Bluetooth Specification Version 4.1 Volume 2, Part E, Section 7.3.46. + * + * @retval ::NRF_SUCCESS Get or set successful. + * @retval ::NRF_ERROR_INVALID_PARAM One or more of the following is true: + * - Less then two bits in @ref ch_map are set. + * - Bits for primary advertising channels (37-39) are set. + * @retval ::NRF_ERROR_BUSY Channel map was set again before enough time had passed. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied for get. + * + */ +typedef struct +{ + uint16_t conn_handle; /**< Connection Handle (only applicable for get) */ + uint8_t ch_map[5]; /**< Channel Map (37-bit). */ +} ble_gap_opt_ch_map_t; + + +/**@brief Local connection latency option. + * + * @details Local connection latency is a feature which enables the slave to improve + * current consumption by ignoring the slave latency set by the peer. The + * local connection latency can only be set to a multiple of the slave latency, + * and cannot be longer than half of the supervision timeout. + * + * @details Used with @ref sd_ble_opt_set to set the local connection latency. The + * @ref sd_ble_opt_get is not supported for this option, but the actual + * local connection latency (unless set to NULL) is set as a return parameter + * when setting the option. + * + * @note The latency set will be truncated down to the closest slave latency event + * multiple, or the nearest multiple before half of the supervision timeout. + * + * @note The local connection latency is disabled by default, and needs to be enabled for new + * connections and whenever the connection is updated. + * + * @retval ::NRF_SUCCESS Set successfully. + * @retval ::NRF_ERROR_NOT_SUPPORTED Get is not supported. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle parameter. + */ +typedef struct +{ + uint16_t conn_handle; /**< Connection Handle */ + uint16_t requested_latency; /**< Requested local connection latency. */ + uint16_t * p_actual_latency; /**< Pointer to storage for the actual local connection latency (can be set to NULL to skip return value). */ +} ble_gap_opt_local_conn_latency_t; + +/**@brief Disable slave latency + * + * @details Used with @ref sd_ble_opt_set to temporarily disable slave latency of a peripheral connection + * (see @ref ble_gap_conn_params_t::slave_latency). And to re-enable it again. When disabled, the + * peripheral will ignore the slave_latency set by the central. + * + * @note Shall only be called on peripheral links. + * + * @retval ::NRF_SUCCESS Set successfully. + * @retval ::NRF_ERROR_NOT_SUPPORTED Get is not supported. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle parameter. + */ +typedef struct +{ + uint16_t conn_handle; /**< Connection Handle */ + uint8_t disable : 1; /**< Set to 1 to disable slave latency. Set to 0 enable it again.*/ +} ble_gap_opt_slave_latency_disable_t; + +/**@brief Passkey Option. + * + * @details Structure containing the passkey to be used during pairing. This can be used with @ref + * sd_ble_opt_set to make the SoftDevice use a preprogrammed passkey for authentication + * instead of generating a random one. + * + * @note Repeated pairing attempts using the same preprogrammed passkey makes pairing vulnerable to MITM attacks. + * + * @note @ref sd_ble_opt_get is not supported for this option. + * + */ +typedef struct +{ + uint8_t const * p_passkey; /**< Pointer to 6-digit ASCII string (digit 0..9 only, no NULL termination) passkey to be used during pairing. If this is NULL, the SoftDevice will generate a random passkey if required.*/ +} ble_gap_opt_passkey_t; + + +/**@brief Compatibility mode 1 option. + * + * @details This can be used with @ref sd_ble_opt_set to enable and disable + * compatibility mode 1. Compatibility mode 1 is disabled by default. + * + * @note Compatibility mode 1 enables interoperability with devices that do not support a value of + * 0 for the WinOffset parameter in the Link Layer CONNECT_IND packet. This applies to a + * limited set of legacy peripheral devices from another vendor. Enabling this compatibility + * mode will only have an effect if the local device will act as a central device and + * initiate a connection to a peripheral device. In that case it may lead to the connection + * creation taking up to one connection interval longer to complete for all connections. + * + * @retval ::NRF_SUCCESS Set successfully. + * @retval ::NRF_ERROR_INVALID_STATE When connection creation is ongoing while mode 1 is set. + */ +typedef struct +{ + uint8_t enable : 1; /**< Enable compatibility mode 1.*/ +} ble_gap_opt_compat_mode_1_t; + + +/**@brief Authenticated payload timeout option. + * + * @details This can be used with @ref sd_ble_opt_set to change the Authenticated payload timeout to a value other + * than the default of @ref BLE_GAP_AUTH_PAYLOAD_TIMEOUT_MAX. + * + * @note The authenticated payload timeout event ::BLE_GAP_TIMEOUT_SRC_AUTH_PAYLOAD will be generated + * if auth_payload_timeout time has elapsed without receiving a packet with a valid MIC on an encrypted + * link. + * + * @note The LE ping procedure will be initiated before the timer expires to give the peer a chance + * to reset the timer. In addition the stack will try to prioritize running of LE ping over other + * activities to increase chances of finishing LE ping before timer expires. To avoid side-effects + * on other activities, it is recommended to use high timeout values. + * Recommended timeout > 2*(connInterval * (6 + connSlaveLatency)). + * + * @retval ::NRF_SUCCESS Set successfully. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. auth_payload_timeout was outside of allowed range. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle parameter. + */ +typedef struct +{ + uint16_t conn_handle; /**< Connection Handle */ + uint16_t auth_payload_timeout; /**< Requested timeout in 10 ms unit, see @ref BLE_GAP_AUTH_PAYLOAD_TIMEOUT. */ +} ble_gap_opt_auth_payload_timeout_t; + +/**@brief Option structure for GAP options. */ +typedef union +{ + ble_gap_opt_ch_map_t ch_map; /**< Parameters for the Channel Map option. */ + ble_gap_opt_local_conn_latency_t local_conn_latency; /**< Parameters for the Local connection latency option */ + ble_gap_opt_passkey_t passkey; /**< Parameters for the Passkey option.*/ + ble_gap_opt_compat_mode_1_t compat_mode_1; /**< Parameters for the compatibility mode 1 option.*/ + ble_gap_opt_auth_payload_timeout_t auth_payload_timeout; /**< Parameters for the authenticated payload timeout option.*/ + ble_gap_opt_slave_latency_disable_t slave_latency_disable; /**< Parameters for the Disable slave latency option */ +} ble_gap_opt_t; +/**@} */ + + +/**@addtogroup BLE_GAP_FUNCTIONS Functions + * @{ */ + +/**@brief Set the local Bluetooth identity address. + * + * The local Bluetooth identity address is the address that identifies this device to other peers. + * The address type must be either @ref BLE_GAP_ADDR_TYPE_PUBLIC or @ref BLE_GAP_ADDR_TYPE_RANDOM_STATIC. + * + * @note The identity address cannot be changed while advertising, scanning or creating a connection. + * + * @note This address will be distributed to the peer during bonding. + * If the address changes, the address stored in the peer device will not be valid and the ability to + * reconnect using the old address will be lost. + * + * @note By default the SoftDevice will set an address of type @ref BLE_GAP_ADDR_TYPE_RANDOM_STATIC upon being + * enabled. The address is a random number populated during the IC manufacturing process and remains unchanged + * for the lifetime of each IC. + * + * @mscs + * @mmsc{@ref BLE_GAP_ADV_MSC} + * @endmscs + * + * @param[in] p_addr Pointer to address structure. + * + * @retval ::NRF_SUCCESS Address successfully set. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_GAP_INVALID_BLE_ADDR Invalid address. + * @retval ::NRF_ERROR_BUSY The stack is busy, process pending events and retry. + * @retval ::NRF_ERROR_INVALID_STATE The identity address cannot be changed while advertising, + * scanning or creating a connection. + */ +SVCALL(SD_BLE_GAP_ADDR_SET, uint32_t, sd_ble_gap_addr_set(ble_gap_addr_t const *p_addr)); + + +/**@brief Get local Bluetooth identity address. + * + * @note This will always return the identity address irrespective of the privacy settings, + * i.e. the address type will always be either @ref BLE_GAP_ADDR_TYPE_PUBLIC or @ref BLE_GAP_ADDR_TYPE_RANDOM_STATIC. + * + * @param[out] p_addr Pointer to address structure to be filled in. + * + * @retval ::NRF_SUCCESS Address successfully retrieved. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid or NULL pointer supplied. + */ +SVCALL(SD_BLE_GAP_ADDR_GET, uint32_t, sd_ble_gap_addr_get(ble_gap_addr_t *p_addr)); + + +/**@brief Set the active whitelist in the SoftDevice. + * + * @note Only one whitelist can be used at a time and the whitelist is shared between the BLE roles. + * The whitelist cannot be set if a BLE role is using the whitelist. + * + * @note If an address is resolved using the information in the device identity list, then the whitelist + * filter policy applies to the peer identity address and not the resolvable address sent on air. + * + * @mscs + * @mmsc{@ref BLE_GAP_WL_SHARE_MSC} + * @mmsc{@ref BLE_GAP_PRIVACY_SCAN_PRIVATE_SCAN_MSC} + * @endmscs + * + * @param[in] pp_wl_addrs Pointer to a whitelist of peer addresses, if NULL the whitelist will be cleared. + * @param[in] len Length of the whitelist, maximum @ref BLE_GAP_WHITELIST_ADDR_MAX_COUNT. + * + * @retval ::NRF_SUCCESS The whitelist is successfully set/cleared. + * @retval ::NRF_ERROR_INVALID_ADDR The whitelist (or one of its entries) provided is invalid. + * @retval ::BLE_ERROR_GAP_WHITELIST_IN_USE The whitelist is in use by a BLE role and cannot be set or cleared. + * @retval ::BLE_ERROR_GAP_INVALID_BLE_ADDR Invalid address type is supplied. + * @retval ::NRF_ERROR_DATA_SIZE The given whitelist size is invalid (zero or too large); this can only return when + * pp_wl_addrs is not NULL. + */ +SVCALL(SD_BLE_GAP_WHITELIST_SET, uint32_t, sd_ble_gap_whitelist_set(ble_gap_addr_t const * const * pp_wl_addrs, uint8_t len)); + + +/**@brief Set device identity list. + * + * @note Only one device identity list can be used at a time and the list is shared between the BLE roles. + * The device identity list cannot be set if a BLE role is using the list. + * + * @param[in] pp_id_keys Pointer to an array of peer identity addresses and peer IRKs, if NULL the device identity list will be cleared. + * @param[in] pp_local_irks Pointer to an array of local IRKs. Each entry in the array maps to the entry in pp_id_keys at the same index. + * To fill in the list with the currently set device IRK for all peers, set to NULL. + * @param[in] len Length of the device identity list, maximum @ref BLE_GAP_DEVICE_IDENTITIES_MAX_COUNT. + * + * @mscs + * @mmsc{@ref BLE_GAP_PRIVACY_ADV_MSC} + * @mmsc{@ref BLE_GAP_PRIVACY_SCAN_MSC} + * @mmsc{@ref BLE_GAP_PRIVACY_SCAN_PRIVATE_SCAN_MSC} + * @mmsc{@ref BLE_GAP_PRIVACY_ADV_DIR_PRIV_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_CONN_PRIV_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_CONN_PRIV_MSC} + * @endmscs + * + * @retval ::NRF_SUCCESS The device identity list successfully set/cleared. + * @retval ::NRF_ERROR_INVALID_ADDR The device identity list (or one of its entries) provided is invalid. + * This code may be returned if the local IRK list also has an invalid entry. + * @retval ::BLE_ERROR_GAP_DEVICE_IDENTITIES_IN_USE The device identity list is in use and cannot be set or cleared. + * @retval ::BLE_ERROR_GAP_DEVICE_IDENTITIES_DUPLICATE The device identity list contains multiple entries with the same identity address. + * @retval ::BLE_ERROR_GAP_INVALID_BLE_ADDR Invalid address type is supplied. + * @retval ::NRF_ERROR_DATA_SIZE The given device identity list size invalid (zero or too large); this can + * only return when pp_id_keys is not NULL. + */ +SVCALL(SD_BLE_GAP_DEVICE_IDENTITIES_SET, uint32_t, sd_ble_gap_device_identities_set(ble_gap_id_key_t const * const * pp_id_keys, ble_gap_irk_t const * const * pp_local_irks, uint8_t len)); + + +/**@brief Set privacy settings. + * + * @note Privacy settings cannot be changed while advertising, scanning or creating a connection. + * + * @param[in] p_privacy_params Privacy settings. + * + * @mscs + * @mmsc{@ref BLE_GAP_PRIVACY_ADV_MSC} + * @mmsc{@ref BLE_GAP_PRIVACY_SCAN_MSC} + * @mmsc{@ref BLE_GAP_PRIVACY_ADV_DIR_PRIV_MSC} + * @endmscs + * + * @retval ::NRF_SUCCESS Set successfully. + * @retval ::NRF_ERROR_BUSY The stack is busy, process pending events and retry. + * @retval ::BLE_ERROR_GAP_INVALID_BLE_ADDR Invalid address type is supplied. + * @retval ::NRF_ERROR_INVALID_ADDR The pointer to privacy settings is NULL or invalid. + * Otherwise, the p_device_irk pointer in privacy parameter is an invalid pointer. + * @retval ::NRF_ERROR_INVALID_PARAM Out of range parameters are provided. + * @retval ::NRF_ERROR_INVALID_STATE Privacy settings cannot be changed while advertising, scanning + * or creating a connection. + */ +SVCALL(SD_BLE_GAP_PRIVACY_SET, uint32_t, sd_ble_gap_privacy_set(ble_gap_privacy_params_t const *p_privacy_params)); + + +/**@brief Get privacy settings. + * + * @note ::ble_gap_privacy_params_t::p_device_irk must be initialized to NULL or a valid address before this function is called. + * If it is initialized to a valid address, the address pointed to will contain the current device IRK on return. + * + * @param[in,out] p_privacy_params Privacy settings. + * + * @retval ::NRF_SUCCESS Privacy settings read. + * @retval ::NRF_ERROR_INVALID_ADDR The pointer given for returning the privacy settings may be NULL or invalid. + * Otherwise, the p_device_irk pointer in privacy parameter is an invalid pointer. + */ +SVCALL(SD_BLE_GAP_PRIVACY_GET, uint32_t, sd_ble_gap_privacy_get(ble_gap_privacy_params_t *p_privacy_params)); + + +/**@brief Configure an advertising set. Set, clear or update advertising and scan response data. + * + * @note The format of the advertising data will be checked by this call to ensure interoperability. + * Limitations imposed by this API call to the data provided include having a flags data type in the scan response data and + * duplicating the local name in the advertising data and scan response data. + * + * @note In order to update advertising data while advertising, new advertising buffers must be provided. + * + * @mscs + * @mmsc{@ref BLE_GAP_ADV_MSC} + * @mmsc{@ref BLE_GAP_WL_SHARE_MSC} + * @endmscs + * + * @param[in,out] p_adv_handle Provide a pointer to a handle containing @ref BLE_GAP_ADV_SET_HANDLE_NOT_SET to configure + * a new advertising set. On success, a new handle is then returned through the pointer. + * Provide a pointer to an existing advertising handle to configure an existing advertising set. + * @param[in] p_adv_data Advertising data. If set to NULL, no advertising data will be used. See @ref ble_gap_adv_data_t. + * @param[in] p_adv_params Advertising parameters. When this function is used to update advertising data while advertising, + * this parameter must be NULL. See @ref ble_gap_adv_params_t. + * + * @retval ::NRF_SUCCESS Advertising set successfully configured. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied: + * - Invalid advertising data configuration specified. See @ref ble_gap_adv_data_t. + * - Invalid configuration of p_adv_params. See @ref ble_gap_adv_params_t. + * - Use of whitelist requested but whitelist has not been set, + * see @ref sd_ble_gap_whitelist_set. + * @retval ::BLE_ERROR_GAP_INVALID_BLE_ADDR ble_gap_adv_params_t::p_peer_addr is invalid. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * - It is invalid to provide non-NULL advertising set parameters while advertising. + * - It is invalid to provide the same data buffers while advertising. To update + * advertising data, provide new advertising buffers. + * @retval ::BLE_ERROR_GAP_DISCOVERABLE_WITH_WHITELIST Discoverable mode and whitelist incompatible. + * @retval ::BLE_ERROR_INVALID_ADV_HANDLE The provided advertising handle was not found. Use @ref BLE_GAP_ADV_SET_HANDLE_NOT_SET to + * configure a new advertising handle. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_FLAGS Invalid combination of advertising flags supplied. + * @retval ::NRF_ERROR_INVALID_DATA Invalid data type(s) supplied. Check the advertising data format specification + * given in Bluetooth Specification Version 5.0, Volume 3, Part C, Chapter 11. + * @retval ::NRF_ERROR_INVALID_LENGTH Invalid data length(s) supplied. + * @retval ::NRF_ERROR_NOT_SUPPORTED Unsupported data length or advertising parameter configuration. + * @retval ::NRF_ERROR_NO_MEM Not enough memory to configure a new advertising handle. Update an + * existing advertising handle instead. + * @retval ::BLE_ERROR_GAP_UUID_LIST_MISMATCH Invalid UUID list supplied. + */ +SVCALL(SD_BLE_GAP_ADV_SET_CONFIGURE, uint32_t, sd_ble_gap_adv_set_configure(uint8_t *p_adv_handle, ble_gap_adv_data_t const *p_adv_data, ble_gap_adv_params_t const *p_adv_params)); + + +/**@brief Start advertising (GAP Discoverable, Connectable modes, Broadcast Procedure). + * + * @note Only one advertiser may be active at any time. + * + * @events + * @event{@ref BLE_GAP_EVT_CONNECTED, Generated after connection has been established through connectable advertising.} + * @event{@ref BLE_GAP_EVT_ADV_SET_TERMINATED, Advertising set has terminated.} + * @event{@ref BLE_GAP_EVT_SCAN_REQ_REPORT, A scan request was received.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_ADV_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_CONN_PRIV_MSC} + * @mmsc{@ref BLE_GAP_PRIVACY_ADV_DIR_PRIV_MSC} + * @mmsc{@ref BLE_GAP_WL_SHARE_MSC} + * @endmscs + * + * @param[in] adv_handle Advertising handle to advertise on, received from @ref sd_ble_gap_adv_set_configure. + * @param[in] conn_cfg_tag Tag identifying a configuration set by @ref sd_ble_cfg_set or + * @ref BLE_CONN_CFG_TAG_DEFAULT to use the default connection configuration. For non-connectable + * advertising, this is ignored. + * + * @retval ::NRF_SUCCESS The BLE stack has started advertising. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. adv_handle is not configured or already advertising. + * @retval ::NRF_ERROR_CONN_COUNT The limit of available connections has been reached; connectable advertiser cannot be started. + * @retval ::BLE_ERROR_INVALID_ADV_HANDLE Advertising handle not found. Configure a new adveriting handle with @ref sd_ble_gap_adv_set_configure. + * @retval ::NRF_ERROR_NOT_FOUND conn_cfg_tag not found. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied: + * - Invalid configuration of p_adv_params. See @ref ble_gap_adv_params_t. + * - Use of whitelist requested but whitelist has not been set, see @ref sd_ble_gap_whitelist_set. + * @retval ::NRF_ERROR_RESOURCES Either: + * - adv_handle is configured with connectable advertising, but the event_length parameter + * associated with conn_cfg_tag is too small to be able to establish a connection on + * the selected advertising phys. Use @ref sd_ble_cfg_set to increase the event length. + * - Not enough BLE role slots available. + Stop one or more currently active roles (Central, Peripheral, Broadcaster or Observer) and try again. + * - p_adv_params is configured with connectable advertising, but the event_length parameter + * associated with conn_cfg_tag is too small to be able to establish a connection on + * the selected advertising phys. Use @ref sd_ble_cfg_set to increase the event length. + * @retval ::NRF_ERROR_NOT_SUPPORTED Unsupported PHYs supplied to the call. + */ +SVCALL(SD_BLE_GAP_ADV_START, uint32_t, sd_ble_gap_adv_start(uint8_t adv_handle, uint8_t conn_cfg_tag)); + + +/**@brief Stop advertising (GAP Discoverable, Connectable modes, Broadcast Procedure). + * + * @mscs + * @mmsc{@ref BLE_GAP_ADV_MSC} + * @mmsc{@ref BLE_GAP_WL_SHARE_MSC} + * @endmscs + * + * @param[in] adv_handle The advertising handle that should stop advertising. + * + * @retval ::NRF_SUCCESS The BLE stack has stopped advertising. + * @retval ::BLE_ERROR_INVALID_ADV_HANDLE Invalid advertising handle. + * @retval ::NRF_ERROR_INVALID_STATE The advertising handle is not advertising. + */ +SVCALL(SD_BLE_GAP_ADV_STOP, uint32_t, sd_ble_gap_adv_stop(uint8_t adv_handle)); + + + +/**@brief Update connection parameters. + * + * @details In the central role this will initiate a Link Layer connection parameter update procedure, + * otherwise in the peripheral role, this will send the corresponding L2CAP request and wait for + * the central to perform the procedure. In both cases, and regardless of success or failure, the application + * will be informed of the result with a @ref BLE_GAP_EVT_CONN_PARAM_UPDATE event. + * + * @details This function can be used as a central both to reply to a @ref BLE_GAP_EVT_CONN_PARAM_UPDATE_REQUEST or to start the procedure unrequested. + * + * @events + * @event{@ref BLE_GAP_EVT_CONN_PARAM_UPDATE, Result of the connection parameter update procedure.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_CPU_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_ENC_AUTH_MUTEX_MSC} + * @mmsc{@ref BLE_GAP_MULTILINK_CPU_MSC} + * @mmsc{@ref BLE_GAP_MULTILINK_CTRL_PROC_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_CPU_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] p_conn_params Pointer to desired connection parameters. If NULL is provided on a peripheral role, + * the parameters in the PPCP characteristic of the GAP service will be used instead. + * If NULL is provided on a central role and in response to a @ref BLE_GAP_EVT_CONN_PARAM_UPDATE_REQUEST, the peripheral request will be rejected + * + * @retval ::NRF_SUCCESS The Connection Update procedure has been started successfully. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied, check parameter limits and constraints. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::NRF_ERROR_BUSY Procedure already in progress, wait for pending procedures to complete and retry. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + * @retval ::NRF_ERROR_NO_MEM Not enough memory to complete operation. + */ +SVCALL(SD_BLE_GAP_CONN_PARAM_UPDATE, uint32_t, sd_ble_gap_conn_param_update(uint16_t conn_handle, ble_gap_conn_params_t const *p_conn_params)); + + +/**@brief Disconnect (GAP Link Termination). + * + * @details This call initiates the disconnection procedure, and its completion will be communicated to the application + * with a @ref BLE_GAP_EVT_DISCONNECTED event. + * + * @events + * @event{@ref BLE_GAP_EVT_DISCONNECTED, Generated when disconnection procedure is complete.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_CONN_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] hci_status_code HCI status code, see @ref BLE_HCI_STATUS_CODES (accepted values are @ref BLE_HCI_REMOTE_USER_TERMINATED_CONNECTION and @ref BLE_HCI_CONN_INTERVAL_UNACCEPTABLE). + * + * @retval ::NRF_SUCCESS The disconnection procedure has been started successfully. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation (disconnection is already in progress). + */ +SVCALL(SD_BLE_GAP_DISCONNECT, uint32_t, sd_ble_gap_disconnect(uint16_t conn_handle, uint8_t hci_status_code)); + + +/**@brief Set the radio's transmit power. + * + * @param[in] role The role to set the transmit power for, see @ref BLE_GAP_TX_POWER_ROLES for + * possible roles. + * @param[in] handle The handle parameter is interpreted depending on role: + * - If role is @ref BLE_GAP_TX_POWER_ROLE_CONN, this value is the specific connection handle. + * - If role is @ref BLE_GAP_TX_POWER_ROLE_ADV, the advertising set identified with the advertising handle, + * will use the specified transmit power, and include it in the advertising packet headers if + * @ref ble_gap_adv_properties_t::include_tx_power set. + * - For all other roles handle is ignored. + * @param[in] tx_power Radio transmit power in dBm (see note for accepted values). + * + * @note Supported tx_power values: -40dBm, -20dBm, -16dBm, -12dBm, -8dBm, -4dBm, 0dBm, +3dBm and +4dBm. + * @note The initiator will have the same transmit power as the scanner. + * @note When a connection is created it will inherit the transmit power from the initiator or + * advertiser leading to the connection. + * + * @retval ::NRF_SUCCESS Successfully changed the transmit power. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::BLE_ERROR_INVALID_ADV_HANDLE Advertising handle not found. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + */ +SVCALL(SD_BLE_GAP_TX_POWER_SET, uint32_t, sd_ble_gap_tx_power_set(uint8_t role, uint16_t handle, int8_t tx_power)); + + +/**@brief Set GAP Appearance value. + * + * @param[in] appearance Appearance (16-bit), see @ref BLE_APPEARANCES. + * + * @retval ::NRF_SUCCESS Appearance value set successfully. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + */ +SVCALL(SD_BLE_GAP_APPEARANCE_SET, uint32_t, sd_ble_gap_appearance_set(uint16_t appearance)); + + +/**@brief Get GAP Appearance value. + * + * @param[out] p_appearance Pointer to appearance (16-bit) to be filled in, see @ref BLE_APPEARANCES. + * + * @retval ::NRF_SUCCESS Appearance value retrieved successfully. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + */ +SVCALL(SD_BLE_GAP_APPEARANCE_GET, uint32_t, sd_ble_gap_appearance_get(uint16_t *p_appearance)); + + +/**@brief Set GAP Peripheral Preferred Connection Parameters. + * + * @param[in] p_conn_params Pointer to a @ref ble_gap_conn_params_t structure with the desired parameters. + * + * @retval ::NRF_SUCCESS Peripheral Preferred Connection Parameters set successfully. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + */ +SVCALL(SD_BLE_GAP_PPCP_SET, uint32_t, sd_ble_gap_ppcp_set(ble_gap_conn_params_t const *p_conn_params)); + + +/**@brief Get GAP Peripheral Preferred Connection Parameters. + * + * @param[out] p_conn_params Pointer to a @ref ble_gap_conn_params_t structure where the parameters will be stored. + * + * @retval ::NRF_SUCCESS Peripheral Preferred Connection Parameters retrieved successfully. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + */ +SVCALL(SD_BLE_GAP_PPCP_GET, uint32_t, sd_ble_gap_ppcp_get(ble_gap_conn_params_t *p_conn_params)); + + +/**@brief Set GAP device name. + * + * @note If the device name is located in application flash memory (see @ref ble_gap_cfg_device_name_t), + * it cannot be changed. Then @ref NRF_ERROR_FORBIDDEN will be returned. + * + * @param[in] p_write_perm Write permissions for the Device Name characteristic, see @ref ble_gap_conn_sec_mode_t. + * @param[in] p_dev_name Pointer to a UTF-8 encoded, <b>non NULL-terminated</b> string. + * @param[in] len Length of the UTF-8, <b>non NULL-terminated</b> string pointed to by p_dev_name in octets (must be smaller or equal than @ref BLE_GAP_DEVNAME_MAX_LEN). + * + * @retval ::NRF_SUCCESS GAP device name and permissions set successfully. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_DATA_SIZE Invalid data size(s) supplied. + * @retval ::NRF_ERROR_FORBIDDEN Device name is not writable. + */ +SVCALL(SD_BLE_GAP_DEVICE_NAME_SET, uint32_t, sd_ble_gap_device_name_set(ble_gap_conn_sec_mode_t const *p_write_perm, uint8_t const *p_dev_name, uint16_t len)); + + +/**@brief Get GAP device name. + * + * @note If the device name is longer than the size of the supplied buffer, + * p_len will return the complete device name length, + * and not the number of bytes actually returned in p_dev_name. + * The application may use this information to allocate a suitable buffer size. + * + * @param[out] p_dev_name Pointer to an empty buffer where the UTF-8 <b>non NULL-terminated</b> string will be placed. Set to NULL to obtain the complete device name length. + * @param[in,out] p_len Length of the buffer pointed by p_dev_name, complete device name length on output. + * + * @retval ::NRF_SUCCESS GAP device name retrieved successfully. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_DATA_SIZE Invalid data size(s) supplied. + */ +SVCALL(SD_BLE_GAP_DEVICE_NAME_GET, uint32_t, sd_ble_gap_device_name_get(uint8_t *p_dev_name, uint16_t *p_len)); + + +/**@brief Initiate the GAP Authentication procedure. + * + * @details In the central role, this function will send an SMP Pairing Request (or an SMP Pairing Failed if rejected), + * otherwise in the peripheral role, an SMP Security Request will be sent. + * + * @events + * @event{Depending on the security parameters set and the packet exchanges with the peer\, the following events may be generated:} + * @event{@ref BLE_GAP_EVT_SEC_PARAMS_REQUEST} + * @event{@ref BLE_GAP_EVT_SEC_INFO_REQUEST} + * @event{@ref BLE_GAP_EVT_PASSKEY_DISPLAY} + * @event{@ref BLE_GAP_EVT_KEY_PRESSED} + * @event{@ref BLE_GAP_EVT_AUTH_KEY_REQUEST} + * @event{@ref BLE_GAP_EVT_LESC_DHKEY_REQUEST} + * @event{@ref BLE_GAP_EVT_CONN_SEC_UPDATE} + * @event{@ref BLE_GAP_EVT_AUTH_STATUS} + * @event{@ref BLE_GAP_EVT_TIMEOUT} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_PERIPH_SEC_REQ_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_SEC_REQ_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_ENC_AUTH_MUTEX_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_PAIRING_JW_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_BONDING_JW_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_BONDING_PK_PERIPH_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_BONDING_PK_PERIPH_OOB_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_PAIRING_JW_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_NC_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_PKE_PD_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_PKE_CD_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_OOB_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] p_sec_params Pointer to the @ref ble_gap_sec_params_t structure with the security parameters to be used during the pairing or bonding procedure. + * In the peripheral role, only the bond, mitm, lesc and keypress fields of this structure are used. + * In the central role, this pointer may be NULL to reject a Security Request. + * + * @retval ::NRF_SUCCESS Successfully initiated authentication procedure. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::NRF_ERROR_NO_MEM The maximum number of authentication procedures that can run in parallel for the given role is reached. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + * @retval ::NRF_ERROR_NOT_SUPPORTED Setting of sign or link fields in @ref ble_gap_sec_kdist_t not supported. + * @retval ::NRF_ERROR_TIMEOUT A SMP timeout has occurred, and further SMP operations on this link is prohibited. + */ +SVCALL(SD_BLE_GAP_AUTHENTICATE, uint32_t, sd_ble_gap_authenticate(uint16_t conn_handle, ble_gap_sec_params_t const *p_sec_params)); + + +/**@brief Reply with GAP security parameters. + * + * @details This function is only used to reply to a @ref BLE_GAP_EVT_SEC_PARAMS_REQUEST, calling it at other times will result in an @ref NRF_ERROR_INVALID_STATE. + * @note If the call returns an error code, the request is still pending, and the reply call may be repeated with corrected parameters. + * + * @events + * @event{This function is used during authentication procedures\, see the list of events in the documentation of @ref sd_ble_gap_authenticate.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_PERIPH_PAIRING_JW_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_BONDING_JW_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_BONDING_PK_PERIPH_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_BONDING_PK_CENTRAL_OOB_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_BONDING_STATIC_PK_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_PAIRING_CONFIRM_FAIL_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_PAIRING_JW_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_NC_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_PKE_PD_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_PKE_CD_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_OOB_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_PAIRING_KS_TOO_SMALL_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_PAIRING_APP_ERROR_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_PAIRING_REMOTE_PAIRING_FAIL_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_PAIRING_TIMEOUT_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_PAIRING_JW_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_BONDING_JW_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_BONDING_PK_PERIPH_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_BONDING_PK_PERIPH_OOB_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_PAIRING_JW_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_NC_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_PKE_PD_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_PKE_CD_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_OOB_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] sec_status Security status, see @ref BLE_GAP_SEC_STATUS. + * @param[in] p_sec_params Pointer to a @ref ble_gap_sec_params_t security parameters structure. In the central role this must be set to NULL, as the parameters have + * already been provided during a previous call to @ref sd_ble_gap_authenticate. + * @param[in,out] p_sec_keyset Pointer to a @ref ble_gap_sec_keyset_t security keyset structure. Any keys generated and/or distributed as a result of the ongoing security procedure + * will be stored into the memory referenced by the pointers inside this structure. The keys will be stored and available to the application + * upon reception of a @ref BLE_GAP_EVT_AUTH_STATUS event. + * Note that the SoftDevice expects the application to provide memory for storing the + * peer's keys. So it must be ensured that the relevant pointers inside this structure are not NULL. The pointers to the local key + * can, however, be NULL, in which case, the local key data will not be available to the application upon reception of the + * @ref BLE_GAP_EVT_AUTH_STATUS event. + * + * @retval ::NRF_SUCCESS Successfully accepted security parameter from the application. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_BUSY The stack is busy, process pending events and retry. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + * @retval ::NRF_ERROR_NOT_SUPPORTED Setting of sign or link fields in @ref ble_gap_sec_kdist_t not supported. + */ +SVCALL(SD_BLE_GAP_SEC_PARAMS_REPLY, uint32_t, sd_ble_gap_sec_params_reply(uint16_t conn_handle, uint8_t sec_status, ble_gap_sec_params_t const *p_sec_params, ble_gap_sec_keyset_t const *p_sec_keyset)); + + +/**@brief Reply with an authentication key. + * + * @details This function is only used to reply to a @ref BLE_GAP_EVT_AUTH_KEY_REQUEST or a @ref BLE_GAP_EVT_PASSKEY_DISPLAY, calling it at other times will result in an @ref NRF_ERROR_INVALID_STATE. + * @note If the call returns an error code, the request is still pending, and the reply call may be repeated with corrected parameters. + * + * @events + * @event{This function is used during authentication procedures\, see the list of events in the documentation of @ref sd_ble_gap_authenticate.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_PERIPH_BONDING_PK_CENTRAL_OOB_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_NC_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_PKE_CD_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_BONDING_PK_PERIPH_OOB_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_NC_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_PKE_CD_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] key_type See @ref BLE_GAP_AUTH_KEY_TYPES. + * @param[in] p_key If key type is @ref BLE_GAP_AUTH_KEY_TYPE_NONE, then NULL. + * If key type is @ref BLE_GAP_AUTH_KEY_TYPE_PASSKEY, then a 6-byte ASCII string (digit 0..9 only, no NULL termination) + * or NULL when confirming LE Secure Connections Numeric Comparison. + * If key type is @ref BLE_GAP_AUTH_KEY_TYPE_OOB, then a 16-byte OOB key value in little-endian format. + * + * @retval ::NRF_SUCCESS Authentication key successfully set. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + */ +SVCALL(SD_BLE_GAP_AUTH_KEY_REPLY, uint32_t, sd_ble_gap_auth_key_reply(uint16_t conn_handle, uint8_t key_type, uint8_t const *p_key)); + + +/**@brief Reply with an LE Secure connections DHKey. + * + * @details This function is only used to reply to a @ref BLE_GAP_EVT_LESC_DHKEY_REQUEST, calling it at other times will result in an @ref NRF_ERROR_INVALID_STATE. + * @note If the call returns an error code, the request is still pending, and the reply call may be repeated with corrected parameters. + * + * @events + * @event{This function is used during authentication procedures\, see the list of events in the documentation of @ref sd_ble_gap_authenticate.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_PERIPH_LESC_PAIRING_JW_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_NC_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_PKE_PD_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_PKE_CD_MSC} + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_OOB_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_PAIRING_JW_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_NC_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_PKE_PD_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_PKE_CD_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_OOB_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] p_dhkey LE Secure Connections DHKey. + * + * @retval ::NRF_SUCCESS DHKey successfully set. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + */ +SVCALL(SD_BLE_GAP_LESC_DHKEY_REPLY, uint32_t, sd_ble_gap_lesc_dhkey_reply(uint16_t conn_handle, ble_gap_lesc_dhkey_t const *p_dhkey)); + + +/**@brief Notify the peer of a local keypress. + * + * @mscs + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_PKE_CD_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_PKE_CD_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] kp_not See @ref BLE_GAP_KP_NOT_TYPES. + * + * @retval ::NRF_SUCCESS Keypress notification successfully queued for transmission. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. Either not entering a passkey or keypresses have not been enabled by both peers. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + * @retval ::NRF_ERROR_BUSY The BLE stack is busy. Retry at later time. + */ +SVCALL(SD_BLE_GAP_KEYPRESS_NOTIFY, uint32_t, sd_ble_gap_keypress_notify(uint16_t conn_handle, uint8_t kp_not)); + + +/**@brief Generate a set of OOB data to send to a peer out of band. + * + * @note The @ref ble_gap_addr_t included in the OOB data returned will be the currently active one (or, if a connection has already been established, + * the one used during connection setup). The application may manually overwrite it with an updated value. + * + * @mscs + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_OOB_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_OOB_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. Can be @ref BLE_CONN_HANDLE_INVALID if a BLE connection has not been established yet. + * @param[in] p_pk_own LE Secure Connections local P-256 Public Key. + * @param[out] p_oobd_own The OOB data to be sent out of band to a peer. + * + * @retval ::NRF_SUCCESS OOB data successfully generated. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + */ +SVCALL(SD_BLE_GAP_LESC_OOB_DATA_GET, uint32_t, sd_ble_gap_lesc_oob_data_get(uint16_t conn_handle, ble_gap_lesc_p256_pk_t const *p_pk_own, ble_gap_lesc_oob_data_t *p_oobd_own)); + +/**@brief Provide the OOB data sent/received out of band. + * + * @note An authentication procedure with OOB selected as an algorithm must be in progress when calling this function. + * @note A @ref BLE_GAP_EVT_LESC_DHKEY_REQUEST event with the oobd_req set to 1 must have been received prior to calling this function. + * + * @events + * @event{This function is used during authentication procedures\, see the list of events in the documentation of @ref sd_ble_gap_authenticate.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_PERIPH_LESC_BONDING_OOB_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_LESC_BONDING_OOB_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] p_oobd_own The OOB data sent out of band to a peer or NULL if the peer has not received OOB data. + * Must correspond to @ref ble_gap_sec_params_t::oob flag in @ref BLE_GAP_EVT_SEC_PARAMS_REQUEST. + * @param[in] p_oobd_peer The OOB data received out of band from a peer or NULL if none received. + * Must correspond to @ref ble_gap_sec_params_t::oob flag in @ref sd_ble_gap_authenticate in the central role + * or @ref sd_ble_gap_sec_params_reply in the peripheral role. + * + * @retval ::NRF_SUCCESS OOB data accepted. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + */ +SVCALL(SD_BLE_GAP_LESC_OOB_DATA_SET, uint32_t, sd_ble_gap_lesc_oob_data_set(uint16_t conn_handle, ble_gap_lesc_oob_data_t const *p_oobd_own, ble_gap_lesc_oob_data_t const *p_oobd_peer)); + + +/**@brief Initiate GAP Encryption procedure. + * + * @details In the central role, this function will initiate the encryption procedure using the encryption information provided. + * + * @events + * @event{@ref BLE_GAP_EVT_CONN_SEC_UPDATE, The connection security has been updated.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_CENTRAL_ENC_AUTH_MUTEX_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_ENC_MSC} + * @mmsc{@ref BLE_GAP_MULTILINK_CTRL_PROC_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_SEC_REQ_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] p_master_id Pointer to a @ref ble_gap_master_id_t master identification structure. + * @param[in] p_enc_info Pointer to a @ref ble_gap_enc_info_t encryption information structure. + * + * @retval ::NRF_SUCCESS Successfully initiated authentication procedure. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + * @retval ::BLE_ERROR_INVALID_ROLE Operation is not supported in the Peripheral role. + * @retval ::NRF_ERROR_BUSY Procedure already in progress or not allowed at this time, wait for pending procedures to complete and retry. + */ +SVCALL(SD_BLE_GAP_ENCRYPT, uint32_t, sd_ble_gap_encrypt(uint16_t conn_handle, ble_gap_master_id_t const *p_master_id, ble_gap_enc_info_t const *p_enc_info)); + + +/**@brief Reply with GAP security information. + * + * @details This function is only used to reply to a @ref BLE_GAP_EVT_SEC_INFO_REQUEST, calling it at other times will result in @ref NRF_ERROR_INVALID_STATE. + * @note If the call returns an error code, the request is still pending, and the reply call may be repeated with corrected parameters. + * @note Data signing is not yet supported, and p_sign_info must therefore be NULL. + * + * @mscs + * @mmsc{@ref BLE_GAP_PERIPH_ENC_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] p_enc_info Pointer to a @ref ble_gap_enc_info_t encryption information structure. May be NULL to signal none is available. + * @param[in] p_id_info Pointer to a @ref ble_gap_irk_t identity information structure. May be NULL to signal none is available. + * @param[in] p_sign_info Pointer to a @ref ble_gap_sign_info_t signing information structure. May be NULL to signal none is available. + * + * @retval ::NRF_SUCCESS Successfully accepted security information. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + */ +SVCALL(SD_BLE_GAP_SEC_INFO_REPLY, uint32_t, sd_ble_gap_sec_info_reply(uint16_t conn_handle, ble_gap_enc_info_t const *p_enc_info, ble_gap_irk_t const *p_id_info, ble_gap_sign_info_t const *p_sign_info)); + + +/**@brief Get the current connection security. + * + * @param[in] conn_handle Connection handle. + * @param[out] p_conn_sec Pointer to a @ref ble_gap_conn_sec_t structure to be filled in. + * + * @retval ::NRF_SUCCESS Current connection security successfully retrieved. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + */ +SVCALL(SD_BLE_GAP_CONN_SEC_GET, uint32_t, sd_ble_gap_conn_sec_get(uint16_t conn_handle, ble_gap_conn_sec_t *p_conn_sec)); + + +/**@brief Start reporting the received signal strength to the application. + * + * A new event is reported whenever the RSSI value changes, until @ref sd_ble_gap_rssi_stop is called. + * + * @events + * @event{@ref BLE_GAP_EVT_RSSI_CHANGED, New RSSI data available. How often the event is generated is + * dependent on the settings of the <code>threshold_dbm</code> + * and <code>skip_count</code> input parameters.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_CENTRAL_RSSI_READ_MSC} + * @mmsc{@ref BLE_GAP_RSSI_FILT_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] threshold_dbm Minimum change in dBm before triggering the @ref BLE_GAP_EVT_RSSI_CHANGED event. Events are disabled if threshold_dbm equals @ref BLE_GAP_RSSI_THRESHOLD_INVALID. + * @param[in] skip_count Number of RSSI samples with a change of threshold_dbm or more before sending a new @ref BLE_GAP_EVT_RSSI_CHANGED event. + * + * @retval ::NRF_SUCCESS Successfully activated RSSI reporting. + * @retval ::NRF_ERROR_INVALID_STATE RSSI reporting is already ongoing. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + */ +SVCALL(SD_BLE_GAP_RSSI_START, uint32_t, sd_ble_gap_rssi_start(uint16_t conn_handle, uint8_t threshold_dbm, uint8_t skip_count)); + + +/**@brief Stop reporting the received signal strength. + * + * @note An RSSI change detected before the call but not yet received by the application + * may be reported after @ref sd_ble_gap_rssi_stop has been called. + * + * @mscs + * @mmsc{@ref BLE_GAP_CENTRAL_RSSI_READ_MSC} + * @mmsc{@ref BLE_GAP_RSSI_FILT_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * + * @retval ::NRF_SUCCESS Successfully deactivated RSSI reporting. + * @retval ::NRF_ERROR_INVALID_STATE RSSI reporting is not ongoing. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + */ +SVCALL(SD_BLE_GAP_RSSI_STOP, uint32_t, sd_ble_gap_rssi_stop(uint16_t conn_handle)); + + +/**@brief Get the received signal strength for the last connection event. + * + * @ref sd_ble_gap_rssi_start must be called to start reporting RSSI before using this function. @ref NRF_ERROR_NOT_FOUND + * will be returned until RSSI was sampled for the first time after calling @ref sd_ble_gap_rssi_start. + * @mscs + * @mmsc{@ref BLE_GAP_CENTRAL_RSSI_READ_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[out] p_rssi Pointer to the location where the RSSI measurement shall be stored. + * @param[out] p_ch_index Pointer to the location where Channel Index for the RSSI measurement shall be stored. + * + * @retval ::NRF_SUCCESS Successfully read the RSSI. + * @retval ::NRF_ERROR_NOT_FOUND No sample is available. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + * @retval ::NRF_ERROR_INVALID_STATE RSSI reporting is not ongoing. + */ +SVCALL(SD_BLE_GAP_RSSI_GET, uint32_t, sd_ble_gap_rssi_get(uint16_t conn_handle, int8_t *p_rssi, uint8_t *p_ch_index)); + + +/**@brief Start or continue scanning (GAP Discovery procedure, Observer Procedure). + * + * @note A call to this function will require the application to keep the memory pointed by + * p_adv_report_buffer alive until the buffer is released. The buffer is released when the scanner is stopped + * or when this function is called with another buffer. + * + * @note The scanner will automatically stop in the following cases: + * - @ref sd_ble_gap_scan_stop is called. + * - @ref sd_ble_gap_connect is called. + * - A @ref BLE_GAP_EVT_TIMEOUT with source set to @ref BLE_GAP_TIMEOUT_SRC_SCAN is received. + * - When a @ref BLE_GAP_EVT_ADV_REPORT event is received and @ref ble_gap_adv_report_type_t::status is not set to + * @ref BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_MORE_DATA. In this case scanning is only paused to let the application + * access received data. The application must call this function to continue scanning, or call @ref sd_ble_gap_scan_stop + * to stop scanning. + * + * @note If a @ref BLE_GAP_EVT_ADV_REPORT event is received with @ref ble_gap_adv_report_type_t::status set to + * @ref BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_MORE_DATA, the scanner will continue scanning, and the application will + * receive more reports from this advertising event. The following reports will include the old and new received data. + * The application can stop the scanner from receiving more packets from this advertising event by calling this function. + * This might be useful when receiving data from extended advertising events where @ref ble_gap_evt_adv_report_t::aux_pointer + * is large. + * + * @events + * @event{@ref BLE_GAP_EVT_ADV_REPORT, An advertising or scan response packet has been received.} + * @event{@ref BLE_GAP_EVT_TIMEOUT, Scanner has timed out.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_SCAN_MSC} + * @mmsc{@ref BLE_GAP_WL_SHARE_MSC} + * @endmscs + * + * @param[in] p_scan_params Pointer to scan parameters structure. When this function is used to continue + * scanning, this parameter must be NULL. + * @param[in] p_adv_report_buffer Pointer to buffer used to store incoming advertising data. + * The memory pointed to should be kept alive until the scanning is stopped. + * See @ref BLE_GAP_SCAN_BUFFER_SIZE for minimum and maximum buffer size. + * If the scanner receives advertising data larger than can be stored in the buffer, + * a @ref BLE_GAP_EVT_ADV_REPORT will be raised with @ref ble_gap_adv_report_type_t::status + * set to @ref BLE_GAP_ADV_DATA_STATUS_INCOMPLETE_TRUNCATED. + * + * @retval ::NRF_SUCCESS Successfully initiated scanning procedure. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. Either: + * - Scanning is already ongoing and p_scan_params was not NULL + * - Scanning is not running and p_scan_params was NULL. + * - The scanner has timed out when this function is called to continue scanning. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. See @ref ble_gap_scan_params_t. + * @retval ::NRF_ERROR_NOT_SUPPORTED Unsupported parameters supplied. See @ref ble_gap_scan_params_t. + * @retval ::NRF_ERROR_INVALID_LENGTH The provided buffer length is invalid. See @ref BLE_GAP_SCAN_BUFFER_MIN. + * @retval ::NRF_ERROR_RESOURCES Not enough BLE role slots available. + * Stop one or more currently active roles (Central, Peripheral or Broadcaster) and try again + * @retval ::NRF_ERROR_NOT_SUPPORTED Unsupported PHYs supplied to the call. + */ +SVCALL(SD_BLE_GAP_SCAN_START, uint32_t, sd_ble_gap_scan_start(ble_gap_scan_params_t const *p_scan_params, ble_data_t const * p_adv_report_buffer)); + + +/**@brief Stop scanning (GAP Discovery procedure, Observer Procedure). + * + * @note The buffer provided in @ref sd_ble_gap_scan_start is released. + * + * @mscs + * @mmsc{@ref BLE_GAP_SCAN_MSC} + * @mmsc{@ref BLE_GAP_WL_SHARE_MSC} + * @endmscs + * + * @retval ::NRF_SUCCESS Successfully stopped scanning procedure. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. Not in the scanning state. + */ +SVCALL(SD_BLE_GAP_SCAN_STOP, uint32_t, sd_ble_gap_scan_stop(void)); + + +/**@brief Create a connection (GAP Link Establishment). + * + * @note If a scanning procedure is currently in progress it will be automatically stopped when calling this function. + * The scanning procedure will be stopped even if the function returns an error. + * + * @mscs + * @mmsc{@ref BLE_GAP_WL_SHARE_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_CONN_PRIV_MSC} + * @mmsc{@ref BLE_GAP_CENTRAL_CONN_MSC} + * @endmscs + * + * @param[in] p_peer_addr Pointer to peer identity address. If @ref ble_gap_scan_params_t::filter_policy is set to use + * whitelist, then p_peer_addr is ignored. + * @param[in] p_scan_params Pointer to scan parameters structure. + * @param[in] p_conn_params Pointer to desired connection parameters. + * @param[in] conn_cfg_tag Tag identifying a configuration set by @ref sd_ble_cfg_set or + * @ref BLE_CONN_CFG_TAG_DEFAULT to use the default connection configuration. + * + * @retval ::NRF_SUCCESS Successfully initiated connection procedure. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid parameter(s) pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * - Invalid parameter(s) in p_scan_params or p_conn_params. + * - Use of whitelist requested but whitelist has not been set, see @ref sd_ble_gap_whitelist_set. + * - Peer address was not present in the device identity list, see @ref sd_ble_gap_device_identities_set. + * @retval ::NRF_ERROR_NOT_FOUND conn_cfg_tag not found. + * @retval ::NRF_ERROR_INVALID_STATE The SoftDevice is in an invalid state to perform this operation. This may be due to an + * existing locally initiated connect procedure, which must complete before initiating again. + * @retval ::BLE_ERROR_GAP_INVALID_BLE_ADDR Invalid Peer address. + * @retval ::NRF_ERROR_CONN_COUNT The limit of available connections has been reached. + * @retval ::NRF_ERROR_RESOURCES Either: + * - Not enough BLE role slots available. + * Stop one or more currently active roles (Central, Peripheral or Observer) and try again. + * - The event_length parameter associated with conn_cfg_tag is too small to be able to + * establish a connection on the selected @ref ble_gap_scan_params_t::scan_phys. + * Use @ref sd_ble_cfg_set to increase the event length. + * @retval ::NRF_ERROR_NOT_SUPPORTED Unsupported PHYs supplied to the call. + */ +SVCALL(SD_BLE_GAP_CONNECT, uint32_t, sd_ble_gap_connect(ble_gap_addr_t const *p_peer_addr, ble_gap_scan_params_t const *p_scan_params, ble_gap_conn_params_t const *p_conn_params, uint8_t conn_cfg_tag)); + + +/**@brief Cancel a connection establishment. + * + * @mscs + * @mmsc{@ref BLE_GAP_CENTRAL_CONN_MSC} + * @endmscs + * + * @retval ::NRF_SUCCESS Successfully canceled an ongoing connection procedure. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + */ +SVCALL(SD_BLE_GAP_CONNECT_CANCEL, uint32_t, sd_ble_gap_connect_cancel(void)); + + +/**@brief Initiate or respond to a PHY Update Procedure + * + * @details This function is used to initiate or respond to a PHY Update Procedure. It will always + * generate a @ref BLE_GAP_EVT_PHY_UPDATE event if successfully executed. + * If this function is used to initiate a PHY Update procedure and the only option + * provided in @ref ble_gap_phys_t::tx_phys and @ref ble_gap_phys_t::rx_phys is the + * currently active PHYs in the respective directions, the SoftDevice will generate a + * @ref BLE_GAP_EVT_PHY_UPDATE with the current PHYs set and will not initiate the + * procedure in the Link Layer. + * + * If @ref ble_gap_phys_t::tx_phys or @ref ble_gap_phys_t::rx_phys is @ref BLE_GAP_PHY_AUTO, + * then the stack will select PHYs based on the peer's PHY preferences and the local link + * configuration. The PHY Update procedure will for this case result in a PHY combination + * that respects the time constraints configured with @ref sd_ble_cfg_set and the current + * link layer data length. + * + * When acting as a central, the SoftDevice will select the fastest common PHY in each direction. + * + * If the peer does not support the PHY Update Procedure, then the resulting + * @ref BLE_GAP_EVT_PHY_UPDATE event will have a status set to + * @ref BLE_HCI_UNSUPPORTED_REMOTE_FEATURE. + * + * If the PHY procedure was rejected by the peer due to a procedure collision, the status + * will be @ref BLE_HCI_STATUS_CODE_LMP_ERROR_TRANSACTION_COLLISION or + * @ref BLE_HCI_DIFFERENT_TRANSACTION_COLLISION. + * If the peer responds to the PHY Update procedure with invalid parameters, the status + * will be @ref BLE_HCI_STATUS_CODE_INVALID_LMP_PARAMETERS. + * If the PHY procedure was rejected by the peer for a different reason, the status will + * contain the reason as specified by the peer. + * + * @events + * @event{@ref BLE_GAP_EVT_PHY_UPDATE, Result of the PHY Update Procedure.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GAP_CENTRAL_PHY_UPDATE} + * @mmsc{@ref BLE_GAP_PERIPHERAL_PHY_UPDATE} + * @endmscs + * + * @param[in] conn_handle Connection handle to indicate the connection for which the PHY Update is requested. + * @param[in] p_gap_phys Pointer to PHY structure. + * + * @retval ::NRF_SUCCESS Successfully requested a PHY Update. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_NOT_SUPPORTED Unsupported PHYs supplied to the call. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::NRF_ERROR_BUSY Procedure is already in progress or not allowed at this time. Process pending events and wait for the pending procedure to complete and retry. + * + */ +SVCALL(SD_BLE_GAP_PHY_UPDATE, uint32_t, sd_ble_gap_phy_update(uint16_t conn_handle, ble_gap_phys_t const *p_gap_phys)); + + +/**@brief Initiate or respond to a Data Length Update Procedure. + * + * @note If the application uses @ref BLE_GAP_DATA_LENGTH_AUTO for one or more members of + * p_dl_params, the SoftDevice will choose the highest value supported in current + * configuration and connection parameters. + * + * @param[in] conn_handle Connection handle. + * @param[in] p_dl_params Pointer to local parameters to be used in Data Length Update + * Procedure. Set any member to @ref BLE_GAP_DATA_LENGTH_AUTO to let + * the SoftDevice automatically decide the value for that member. + * Set to NULL to use automatic values for all members. + * @param[out] p_dl_limitation Pointer to limitation to be written when local device does not + * have enough resources or does not support the requested Data Length + * Update parameters. Ignored if NULL. + * + * @mscs + * @mmsc{@ref BLE_GAP_DATA_LENGTH_UPDATE_PROCEDURE_MSC} + * @endmscs + * + * @retval ::NRF_SUCCESS Successfully set Data Length Extension initiation/response parameters. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle parameter supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameters supplied. + * @retval ::NRF_ERROR_NOT_SUPPORTED The requested parameters are not supported by the SoftDevice. Inspect + * p_dl_limitation to see which parameter is not supported. + * @retval ::NRF_ERROR_RESOURCES The connection event length configured for this link is not sufficient for the requested parameters. + * Use @ref sd_ble_cfg_set with @ref BLE_CONN_CFG_GAP to increase the connection event length. + * Inspect p_dl_limitation to see where the limitation is. + * @retval ::NRF_ERROR_BUSY Peer has already initiated a Data Length Update Procedure. Process the + * pending @ref BLE_GAP_EVT_DATA_LENGTH_UPDATE_REQUEST event to respond. + */ +SVCALL(SD_BLE_GAP_DATA_LENGTH_UPDATE, uint32_t, sd_ble_gap_data_length_update(uint16_t conn_handle, ble_gap_data_length_params_t const *p_dl_params, ble_gap_data_length_limitation_t *p_dl_limitation)); + +/**@brief Start the Quality of Service (QoS) channel survey module. + * + * @details The channel survey module provides measurements of the energy levels on + * the Bluetooth Low Energy channels. When the module is enabled, @ref BLE_GAP_EVT_QOS_CHANNEL_SURVEY_REPORT + * events will periodically report the measured energy levels for each channel. + * + * @note The measurements are scheduled with lower priority than other Bluetooth Low Energy roles, + * Radio Timeslot API events and Flash API events. + * + * @note The channel survey module will attempt to do measurements so that the average interval + * between measurements will be interval_us. However due to the channel survey module + * having the lowest priority of all roles and modules, this may not be possible. In that + * case fewer than expected channel survey reports may be given. + * + * @note In order to use the channel survey module, @ref ble_gap_cfg_role_count_t::qos_channel_survey_role_available + * must be set. This is done using @ref sd_ble_cfg_set. + * + * @param[in] interval_us Requested average interval for the measurements and reports. See + * @ref BLE_GAP_QOS_CHANNEL_SURVEY_INTERVALS for valid ranges. If set + * to @ref BLE_GAP_QOS_CHANNEL_SURVEY_INTERVAL_CONTINUOUS, the channel + * survey role will be scheduled at every available opportunity. + * + * @retval ::NRF_SUCCESS The module is successfully started. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter supplied. interval_us is out of the + * allowed range. + * @retval ::NRF_ERROR_INVALID_STATE Trying to start the module when already running. + * @retval ::NRF_ERROR_RESOURCES The channel survey module is not available to the application. + * Set @ref ble_gap_cfg_role_count_t::qos_channel_survey_role_available using + * @ref sd_ble_cfg_set. + */ +SVCALL(SD_BLE_GAP_QOS_CHANNEL_SURVEY_START, uint32_t, sd_ble_gap_qos_channel_survey_start(uint32_t interval_us)); + +/**@brief Stop the Quality of Service (QoS) channel survey module. + * + * @retval ::NRF_SUCCESS The module is successfully stopped. + * @retval ::NRF_ERROR_INVALID_STATE Trying to stop the module when it is not running. + */ +SVCALL(SD_BLE_GAP_QOS_CHANNEL_SURVEY_STOP, uint32_t, sd_ble_gap_qos_channel_survey_stop(void)); + + +/** @} */ + +#ifdef __cplusplus +} +#endif +#endif // BLE_GAP_H__ + +/** + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gatt.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gatt.h new file mode 100644 index 0000000..98a7a15 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gatt.h @@ -0,0 +1,228 @@ +/* + * Copyright (c) 2013 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup BLE_GATT Generic Attribute Profile (GATT) Common + @{ + @brief Common definitions and prototypes for the GATT interfaces. + */ + +#ifndef BLE_GATT_H__ +#define BLE_GATT_H__ + +#include <stdint.h> +#include "nrf_svc.h" +#include "nrf_error.h" +#include "ble_hci.h" +#include "ble_ranges.h" +#include "ble_types.h" +#include "ble_err.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** @addtogroup BLE_GATT_DEFINES Defines + * @{ */ + +/** @brief Default ATT MTU, in bytes. */ +#define BLE_GATT_ATT_MTU_DEFAULT 23 + +/**@brief Invalid Attribute Handle. */ +#define BLE_GATT_HANDLE_INVALID 0x0000 + +/**@brief First Attribute Handle. */ +#define BLE_GATT_HANDLE_START 0x0001 + +/**@brief Last Attribute Handle. */ +#define BLE_GATT_HANDLE_END 0xFFFF + +/** @defgroup BLE_GATT_TIMEOUT_SOURCES GATT Timeout sources + * @{ */ +#define BLE_GATT_TIMEOUT_SRC_PROTOCOL 0x00 /**< ATT Protocol timeout. */ +/** @} */ + +/** @defgroup BLE_GATT_WRITE_OPS GATT Write operations + * @{ */ +#define BLE_GATT_OP_INVALID 0x00 /**< Invalid Operation. */ +#define BLE_GATT_OP_WRITE_REQ 0x01 /**< Write Request. */ +#define BLE_GATT_OP_WRITE_CMD 0x02 /**< Write Command. */ +#define BLE_GATT_OP_SIGN_WRITE_CMD 0x03 /**< Signed Write Command. */ +#define BLE_GATT_OP_PREP_WRITE_REQ 0x04 /**< Prepare Write Request. */ +#define BLE_GATT_OP_EXEC_WRITE_REQ 0x05 /**< Execute Write Request. */ +/** @} */ + +/** @defgroup BLE_GATT_EXEC_WRITE_FLAGS GATT Execute Write flags + * @{ */ +#define BLE_GATT_EXEC_WRITE_FLAG_PREPARED_CANCEL 0x00 /**< Cancel prepared write. */ +#define BLE_GATT_EXEC_WRITE_FLAG_PREPARED_WRITE 0x01 /**< Execute prepared write. */ +/** @} */ + +/** @defgroup BLE_GATT_HVX_TYPES GATT Handle Value operations + * @{ */ +#define BLE_GATT_HVX_INVALID 0x00 /**< Invalid Operation. */ +#define BLE_GATT_HVX_NOTIFICATION 0x01 /**< Handle Value Notification. */ +#define BLE_GATT_HVX_INDICATION 0x02 /**< Handle Value Indication. */ +/** @} */ + +/** @defgroup BLE_GATT_STATUS_CODES GATT Status Codes + * @{ */ +#define BLE_GATT_STATUS_SUCCESS 0x0000 /**< Success. */ +#define BLE_GATT_STATUS_UNKNOWN 0x0001 /**< Unknown or not applicable status. */ +#define BLE_GATT_STATUS_ATTERR_INVALID 0x0100 /**< ATT Error: Invalid Error Code. */ +#define BLE_GATT_STATUS_ATTERR_INVALID_HANDLE 0x0101 /**< ATT Error: Invalid Attribute Handle. */ +#define BLE_GATT_STATUS_ATTERR_READ_NOT_PERMITTED 0x0102 /**< ATT Error: Read not permitted. */ +#define BLE_GATT_STATUS_ATTERR_WRITE_NOT_PERMITTED 0x0103 /**< ATT Error: Write not permitted. */ +#define BLE_GATT_STATUS_ATTERR_INVALID_PDU 0x0104 /**< ATT Error: Used in ATT as Invalid PDU. */ +#define BLE_GATT_STATUS_ATTERR_INSUF_AUTHENTICATION 0x0105 /**< ATT Error: Authenticated link required. */ +#define BLE_GATT_STATUS_ATTERR_REQUEST_NOT_SUPPORTED 0x0106 /**< ATT Error: Used in ATT as Request Not Supported. */ +#define BLE_GATT_STATUS_ATTERR_INVALID_OFFSET 0x0107 /**< ATT Error: Offset specified was past the end of the attribute. */ +#define BLE_GATT_STATUS_ATTERR_INSUF_AUTHORIZATION 0x0108 /**< ATT Error: Used in ATT as Insufficient Authorization. */ +#define BLE_GATT_STATUS_ATTERR_PREPARE_QUEUE_FULL 0x0109 /**< ATT Error: Used in ATT as Prepare Queue Full. */ +#define BLE_GATT_STATUS_ATTERR_ATTRIBUTE_NOT_FOUND 0x010A /**< ATT Error: Used in ATT as Attribute not found. */ +#define BLE_GATT_STATUS_ATTERR_ATTRIBUTE_NOT_LONG 0x010B /**< ATT Error: Attribute cannot be read or written using read/write blob requests. */ +#define BLE_GATT_STATUS_ATTERR_INSUF_ENC_KEY_SIZE 0x010C /**< ATT Error: Encryption key size used is insufficient. */ +#define BLE_GATT_STATUS_ATTERR_INVALID_ATT_VAL_LENGTH 0x010D /**< ATT Error: Invalid value size. */ +#define BLE_GATT_STATUS_ATTERR_UNLIKELY_ERROR 0x010E /**< ATT Error: Very unlikely error. */ +#define BLE_GATT_STATUS_ATTERR_INSUF_ENCRYPTION 0x010F /**< ATT Error: Encrypted link required. */ +#define BLE_GATT_STATUS_ATTERR_UNSUPPORTED_GROUP_TYPE 0x0110 /**< ATT Error: Attribute type is not a supported grouping attribute. */ +#define BLE_GATT_STATUS_ATTERR_INSUF_RESOURCES 0x0111 /**< ATT Error: Encrypted link required. */ +#define BLE_GATT_STATUS_ATTERR_RFU_RANGE1_BEGIN 0x0112 /**< ATT Error: Reserved for Future Use range #1 begin. */ +#define BLE_GATT_STATUS_ATTERR_RFU_RANGE1_END 0x017F /**< ATT Error: Reserved for Future Use range #1 end. */ +#define BLE_GATT_STATUS_ATTERR_APP_BEGIN 0x0180 /**< ATT Error: Application range begin. */ +#define BLE_GATT_STATUS_ATTERR_APP_END 0x019F /**< ATT Error: Application range end. */ +#define BLE_GATT_STATUS_ATTERR_RFU_RANGE2_BEGIN 0x01A0 /**< ATT Error: Reserved for Future Use range #2 begin. */ +#define BLE_GATT_STATUS_ATTERR_RFU_RANGE2_END 0x01DF /**< ATT Error: Reserved for Future Use range #2 end. */ +#define BLE_GATT_STATUS_ATTERR_RFU_RANGE3_BEGIN 0x01E0 /**< ATT Error: Reserved for Future Use range #3 begin. */ +#define BLE_GATT_STATUS_ATTERR_RFU_RANGE3_END 0x01FC /**< ATT Error: Reserved for Future Use range #3 end. */ +#define BLE_GATT_STATUS_ATTERR_CPS_CCCD_CONFIG_ERROR 0x01FD /**< ATT Common Profile and Service Error: Client Characteristic Configuration Descriptor improperly configured. */ +#define BLE_GATT_STATUS_ATTERR_CPS_PROC_ALR_IN_PROG 0x01FE /**< ATT Common Profile and Service Error: Procedure Already in Progress. */ +#define BLE_GATT_STATUS_ATTERR_CPS_OUT_OF_RANGE 0x01FF /**< ATT Common Profile and Service Error: Out Of Range. */ +/** @} */ + + +/** @defgroup BLE_GATT_CPF_FORMATS Characteristic Presentation Formats + * @note Found at http://developer.bluetooth.org/gatt/descriptors/Pages/DescriptorViewer.aspx?u=org.bluetooth.descriptor.gatt.characteristic_presentation_format.xml + * @{ */ +#define BLE_GATT_CPF_FORMAT_RFU 0x00 /**< Reserved For Future Use. */ +#define BLE_GATT_CPF_FORMAT_BOOLEAN 0x01 /**< Boolean. */ +#define BLE_GATT_CPF_FORMAT_2BIT 0x02 /**< Unsigned 2-bit integer. */ +#define BLE_GATT_CPF_FORMAT_NIBBLE 0x03 /**< Unsigned 4-bit integer. */ +#define BLE_GATT_CPF_FORMAT_UINT8 0x04 /**< Unsigned 8-bit integer. */ +#define BLE_GATT_CPF_FORMAT_UINT12 0x05 /**< Unsigned 12-bit integer. */ +#define BLE_GATT_CPF_FORMAT_UINT16 0x06 /**< Unsigned 16-bit integer. */ +#define BLE_GATT_CPF_FORMAT_UINT24 0x07 /**< Unsigned 24-bit integer. */ +#define BLE_GATT_CPF_FORMAT_UINT32 0x08 /**< Unsigned 32-bit integer. */ +#define BLE_GATT_CPF_FORMAT_UINT48 0x09 /**< Unsigned 48-bit integer. */ +#define BLE_GATT_CPF_FORMAT_UINT64 0x0A /**< Unsigned 64-bit integer. */ +#define BLE_GATT_CPF_FORMAT_UINT128 0x0B /**< Unsigned 128-bit integer. */ +#define BLE_GATT_CPF_FORMAT_SINT8 0x0C /**< Signed 2-bit integer. */ +#define BLE_GATT_CPF_FORMAT_SINT12 0x0D /**< Signed 12-bit integer. */ +#define BLE_GATT_CPF_FORMAT_SINT16 0x0E /**< Signed 16-bit integer. */ +#define BLE_GATT_CPF_FORMAT_SINT24 0x0F /**< Signed 24-bit integer. */ +#define BLE_GATT_CPF_FORMAT_SINT32 0x10 /**< Signed 32-bit integer. */ +#define BLE_GATT_CPF_FORMAT_SINT48 0x11 /**< Signed 48-bit integer. */ +#define BLE_GATT_CPF_FORMAT_SINT64 0x12 /**< Signed 64-bit integer. */ +#define BLE_GATT_CPF_FORMAT_SINT128 0x13 /**< Signed 128-bit integer. */ +#define BLE_GATT_CPF_FORMAT_FLOAT32 0x14 /**< IEEE-754 32-bit floating point. */ +#define BLE_GATT_CPF_FORMAT_FLOAT64 0x15 /**< IEEE-754 64-bit floating point. */ +#define BLE_GATT_CPF_FORMAT_SFLOAT 0x16 /**< IEEE-11073 16-bit SFLOAT. */ +#define BLE_GATT_CPF_FORMAT_FLOAT 0x17 /**< IEEE-11073 32-bit FLOAT. */ +#define BLE_GATT_CPF_FORMAT_DUINT16 0x18 /**< IEEE-20601 format. */ +#define BLE_GATT_CPF_FORMAT_UTF8S 0x19 /**< UTF-8 string. */ +#define BLE_GATT_CPF_FORMAT_UTF16S 0x1A /**< UTF-16 string. */ +#define BLE_GATT_CPF_FORMAT_STRUCT 0x1B /**< Opaque Structure. */ +/** @} */ + +/** @defgroup BLE_GATT_CPF_NAMESPACES GATT Bluetooth Namespaces + * @{ + */ +#define BLE_GATT_CPF_NAMESPACE_BTSIG 0x01 /**< Bluetooth SIG defined Namespace. */ +#define BLE_GATT_CPF_NAMESPACE_DESCRIPTION_UNKNOWN 0x0000 /**< Namespace Description Unknown. */ +/** @} */ + +/** @} */ + +/** @addtogroup BLE_GATT_STRUCTURES Structures + * @{ */ + +/** + * @brief BLE GATT connection configuration parameters, set with @ref sd_ble_cfg_set. + * + * @retval ::NRF_ERROR_INVALID_PARAM att_mtu is smaller than @ref BLE_GATT_ATT_MTU_DEFAULT. + */ +typedef struct +{ + uint16_t att_mtu; /**< Maximum size of ATT packet the SoftDevice can send or receive. + The default and minimum value is @ref BLE_GATT_ATT_MTU_DEFAULT. + @mscs + @mmsc{@ref BLE_GATTC_MTU_EXCHANGE} + @mmsc{@ref BLE_GATTS_MTU_EXCHANGE} + @endmscs + */ +} ble_gatt_conn_cfg_t; + +/**@brief GATT Characteristic Properties. */ +typedef struct +{ + /* Standard properties */ + uint8_t broadcast :1; /**< Broadcasting of the value permitted. */ + uint8_t read :1; /**< Reading the value permitted. */ + uint8_t write_wo_resp :1; /**< Writing the value with Write Command permitted. */ + uint8_t write :1; /**< Writing the value with Write Request permitted. */ + uint8_t notify :1; /**< Notification of the value permitted. */ + uint8_t indicate :1; /**< Indications of the value permitted. */ + uint8_t auth_signed_wr :1; /**< Writing the value with Signed Write Command permitted. */ +} ble_gatt_char_props_t; + +/**@brief GATT Characteristic Extended Properties. */ +typedef struct +{ + /* Extended properties */ + uint8_t reliable_wr :1; /**< Writing the value with Queued Write operations permitted. */ + uint8_t wr_aux :1; /**< Writing the Characteristic User Description descriptor permitted. */ +} ble_gatt_char_ext_props_t; + +/** @} */ + +#ifdef __cplusplus +} +#endif +#endif // BLE_GATT_H__ + +/** @} */ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gattc.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gattc.h new file mode 100644 index 0000000..7fb3920 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gattc.h @@ -0,0 +1,715 @@ +/* + * Copyright (c) 2011 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup BLE_GATTC Generic Attribute Profile (GATT) Client + @{ + @brief Definitions and prototypes for the GATT Client interface. + */ + +#ifndef BLE_GATTC_H__ +#define BLE_GATTC_H__ + +#include <stdint.h> +#include "nrf.h" +#include "nrf_svc.h" +#include "nrf_error.h" +#include "ble_ranges.h" +#include "ble_types.h" +#include "ble_err.h" +#include "ble_gatt.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** @addtogroup BLE_GATTC_ENUMERATIONS Enumerations + * @{ */ + +/**@brief GATTC API SVC numbers. */ +enum BLE_GATTC_SVCS +{ + SD_BLE_GATTC_PRIMARY_SERVICES_DISCOVER = BLE_GATTC_SVC_BASE, /**< Primary Service Discovery. */ + SD_BLE_GATTC_RELATIONSHIPS_DISCOVER, /**< Relationship Discovery. */ + SD_BLE_GATTC_CHARACTERISTICS_DISCOVER, /**< Characteristic Discovery. */ + SD_BLE_GATTC_DESCRIPTORS_DISCOVER, /**< Characteristic Descriptor Discovery. */ + SD_BLE_GATTC_ATTR_INFO_DISCOVER, /**< Attribute Information Discovery. */ + SD_BLE_GATTC_CHAR_VALUE_BY_UUID_READ, /**< Read Characteristic Value by UUID. */ + SD_BLE_GATTC_READ, /**< Generic read. */ + SD_BLE_GATTC_CHAR_VALUES_READ, /**< Read multiple Characteristic Values. */ + SD_BLE_GATTC_WRITE, /**< Generic write. */ + SD_BLE_GATTC_HV_CONFIRM, /**< Handle Value Confirmation. */ + SD_BLE_GATTC_EXCHANGE_MTU_REQUEST, /**< Exchange MTU Request. */ +}; + +/** + * @brief GATT Client Event IDs. + */ +enum BLE_GATTC_EVTS +{ + BLE_GATTC_EVT_PRIM_SRVC_DISC_RSP = BLE_GATTC_EVT_BASE, /**< Primary Service Discovery Response event. \n See @ref ble_gattc_evt_prim_srvc_disc_rsp_t. */ + BLE_GATTC_EVT_REL_DISC_RSP, /**< Relationship Discovery Response event. \n See @ref ble_gattc_evt_rel_disc_rsp_t. */ + BLE_GATTC_EVT_CHAR_DISC_RSP, /**< Characteristic Discovery Response event. \n See @ref ble_gattc_evt_char_disc_rsp_t. */ + BLE_GATTC_EVT_DESC_DISC_RSP, /**< Descriptor Discovery Response event. \n See @ref ble_gattc_evt_desc_disc_rsp_t. */ + BLE_GATTC_EVT_ATTR_INFO_DISC_RSP, /**< Attribute Information Response event. \n See @ref ble_gattc_evt_attr_info_disc_rsp_t. */ + BLE_GATTC_EVT_CHAR_VAL_BY_UUID_READ_RSP, /**< Read By UUID Response event. \n See @ref ble_gattc_evt_char_val_by_uuid_read_rsp_t. */ + BLE_GATTC_EVT_READ_RSP, /**< Read Response event. \n See @ref ble_gattc_evt_read_rsp_t. */ + BLE_GATTC_EVT_CHAR_VALS_READ_RSP, /**< Read multiple Response event. \n See @ref ble_gattc_evt_char_vals_read_rsp_t. */ + BLE_GATTC_EVT_WRITE_RSP, /**< Write Response event. \n See @ref ble_gattc_evt_write_rsp_t. */ + BLE_GATTC_EVT_HVX, /**< Handle Value Notification or Indication event. \n Confirm indication with @ref sd_ble_gattc_hv_confirm. \n See @ref ble_gattc_evt_hvx_t. */ + BLE_GATTC_EVT_EXCHANGE_MTU_RSP, /**< Exchange MTU Response event. \n See @ref ble_gattc_evt_exchange_mtu_rsp_t. */ + BLE_GATTC_EVT_TIMEOUT, /**< Timeout event. \n See @ref ble_gattc_evt_timeout_t. */ + BLE_GATTC_EVT_WRITE_CMD_TX_COMPLETE /**< Write without Response transmission complete. \n See @ref ble_gattc_evt_write_cmd_tx_complete_t. */ +}; + +/** @} */ + +/** @addtogroup BLE_GATTC_DEFINES Defines + * @{ */ + +/** @defgroup BLE_ERRORS_GATTC SVC return values specific to GATTC + * @{ */ +#define BLE_ERROR_GATTC_PROC_NOT_PERMITTED (NRF_GATTC_ERR_BASE + 0x000) /**< Procedure not Permitted. */ +/** @} */ + +/** @defgroup BLE_GATTC_ATTR_INFO_FORMAT Attribute Information Formats + * @{ */ +#define BLE_GATTC_ATTR_INFO_FORMAT_16BIT 1 /**< 16-bit Attribute Information Format. */ +#define BLE_GATTC_ATTR_INFO_FORMAT_128BIT 2 /**< 128-bit Attribute Information Format. */ +/** @} */ + +/** @defgroup BLE_GATTC_DEFAULTS GATT Client defaults + * @{ */ +#define BLE_GATTC_WRITE_CMD_TX_QUEUE_SIZE_DEFAULT 1 /**< Default number of Write without Response that can be queued for transmission. */ +/** @} */ + +/** @} */ + +/** @addtogroup BLE_GATTC_STRUCTURES Structures + * @{ */ + +/** + * @brief BLE GATTC connection configuration parameters, set with @ref sd_ble_cfg_set. + */ +typedef struct +{ + uint8_t write_cmd_tx_queue_size; /**< The guaranteed minimum number of Write without Response that can be queued for transmission. + The default value is @ref BLE_GATTC_WRITE_CMD_TX_QUEUE_SIZE_DEFAULT */ +} ble_gattc_conn_cfg_t; + +/**@brief Operation Handle Range. */ +typedef struct +{ + uint16_t start_handle; /**< Start Handle. */ + uint16_t end_handle; /**< End Handle. */ +} ble_gattc_handle_range_t; + + +/**@brief GATT service. */ +typedef struct +{ + ble_uuid_t uuid; /**< Service UUID. */ + ble_gattc_handle_range_t handle_range; /**< Service Handle Range. */ +} ble_gattc_service_t; + + +/**@brief GATT include. */ +typedef struct +{ + uint16_t handle; /**< Include Handle. */ + ble_gattc_service_t included_srvc; /**< Handle of the included service. */ +} ble_gattc_include_t; + + +/**@brief GATT characteristic. */ +typedef struct +{ + ble_uuid_t uuid; /**< Characteristic UUID. */ + ble_gatt_char_props_t char_props; /**< Characteristic Properties. */ + uint8_t char_ext_props : 1; /**< Extended properties present. */ + uint16_t handle_decl; /**< Handle of the Characteristic Declaration. */ + uint16_t handle_value; /**< Handle of the Characteristic Value. */ +} ble_gattc_char_t; + + +/**@brief GATT descriptor. */ +typedef struct +{ + uint16_t handle; /**< Descriptor Handle. */ + ble_uuid_t uuid; /**< Descriptor UUID. */ +} ble_gattc_desc_t; + + +/**@brief Write Parameters. */ +typedef struct +{ + uint8_t write_op; /**< Write Operation to be performed, see @ref BLE_GATT_WRITE_OPS. */ + uint8_t flags; /**< Flags, see @ref BLE_GATT_EXEC_WRITE_FLAGS. */ + uint16_t handle; /**< Handle to the attribute to be written. */ + uint16_t offset; /**< Offset in bytes. @note For WRITE_CMD and WRITE_REQ, offset must be 0. */ + uint16_t len; /**< Length of data in bytes. */ + uint8_t const *p_value; /**< Pointer to the value data. */ +} ble_gattc_write_params_t; + +/**@brief Attribute Information for 16-bit Attribute UUID. */ +typedef struct +{ + uint16_t handle; /**< Attribute handle. */ + ble_uuid_t uuid; /**< 16-bit Attribute UUID. */ +} ble_gattc_attr_info16_t; + +/**@brief Attribute Information for 128-bit Attribute UUID. */ +typedef struct +{ + uint16_t handle; /**< Attribute handle. */ + ble_uuid128_t uuid; /**< 128-bit Attribute UUID. */ +} ble_gattc_attr_info128_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_PRIM_SRVC_DISC_RSP. */ +typedef struct +{ + uint16_t count; /**< Service count. */ + ble_gattc_service_t services[1]; /**< Service data. @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ +} ble_gattc_evt_prim_srvc_disc_rsp_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_REL_DISC_RSP. */ +typedef struct +{ + uint16_t count; /**< Include count. */ + ble_gattc_include_t includes[1]; /**< Include data. @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ +} ble_gattc_evt_rel_disc_rsp_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_CHAR_DISC_RSP. */ +typedef struct +{ + uint16_t count; /**< Characteristic count. */ + ble_gattc_char_t chars[1]; /**< Characteristic data. @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ +} ble_gattc_evt_char_disc_rsp_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_DESC_DISC_RSP. */ +typedef struct +{ + uint16_t count; /**< Descriptor count. */ + ble_gattc_desc_t descs[1]; /**< Descriptor data. @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ +} ble_gattc_evt_desc_disc_rsp_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_ATTR_INFO_DISC_RSP. */ +typedef struct +{ + uint16_t count; /**< Attribute count. */ + uint8_t format; /**< Attribute information format, see @ref BLE_GATTC_ATTR_INFO_FORMAT. */ + union { + ble_gattc_attr_info16_t attr_info16[1]; /**< Attribute information for 16-bit Attribute UUID. + @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ + ble_gattc_attr_info128_t attr_info128[1]; /**< Attribute information for 128-bit Attribute UUID. + @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ + } info; /**< Attribute information union. */ +} ble_gattc_evt_attr_info_disc_rsp_t; + +/**@brief GATT read by UUID handle value pair. */ +typedef struct +{ + uint16_t handle; /**< Attribute Handle. */ + uint8_t *p_value; /**< Pointer to the Attribute Value, length is available in @ref ble_gattc_evt_char_val_by_uuid_read_rsp_t::value_len. */ +} ble_gattc_handle_value_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_CHAR_VAL_BY_UUID_READ_RSP. */ +typedef struct +{ + uint16_t count; /**< Handle-Value Pair Count. */ + uint16_t value_len; /**< Length of the value in Handle-Value(s) list. */ + uint8_t handle_value[1]; /**< Handle-Value(s) list. To iterate through the list use @ref sd_ble_gattc_evt_char_val_by_uuid_read_rsp_iter. + @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ +} ble_gattc_evt_char_val_by_uuid_read_rsp_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_READ_RSP. */ +typedef struct +{ + uint16_t handle; /**< Attribute Handle. */ + uint16_t offset; /**< Offset of the attribute data. */ + uint16_t len; /**< Attribute data length. */ + uint8_t data[1]; /**< Attribute data. @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ +} ble_gattc_evt_read_rsp_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_CHAR_VALS_READ_RSP. */ +typedef struct +{ + uint16_t len; /**< Concatenated Attribute values length. */ + uint8_t values[1]; /**< Attribute values. @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ +} ble_gattc_evt_char_vals_read_rsp_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_WRITE_RSP. */ +typedef struct +{ + uint16_t handle; /**< Attribute Handle. */ + uint8_t write_op; /**< Type of write operation, see @ref BLE_GATT_WRITE_OPS. */ + uint16_t offset; /**< Data offset. */ + uint16_t len; /**< Data length. */ + uint8_t data[1]; /**< Data. @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ +} ble_gattc_evt_write_rsp_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_HVX. */ +typedef struct +{ + uint16_t handle; /**< Handle to which the HVx operation applies. */ + uint8_t type; /**< Indication or Notification, see @ref BLE_GATT_HVX_TYPES. */ + uint16_t len; /**< Attribute data length. */ + uint8_t data[1]; /**< Attribute data. @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ +} ble_gattc_evt_hvx_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_EXCHANGE_MTU_RSP. */ +typedef struct +{ + uint16_t server_rx_mtu; /**< Server RX MTU size. */ +} ble_gattc_evt_exchange_mtu_rsp_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_TIMEOUT. */ +typedef struct +{ + uint8_t src; /**< Timeout source, see @ref BLE_GATT_TIMEOUT_SOURCES. */ +} ble_gattc_evt_timeout_t; + +/**@brief Event structure for @ref BLE_GATTC_EVT_WRITE_CMD_TX_COMPLETE. */ +typedef struct +{ + uint8_t count; /**< Number of write without response transmissions completed. */ +} ble_gattc_evt_write_cmd_tx_complete_t; + +/**@brief GATTC event structure. */ +typedef struct +{ + uint16_t conn_handle; /**< Connection Handle on which event occurred. */ + uint16_t gatt_status; /**< GATT status code for the operation, see @ref BLE_GATT_STATUS_CODES. */ + uint16_t error_handle; /**< In case of error: The handle causing the error. In all other cases @ref BLE_GATT_HANDLE_INVALID. */ + union + { + ble_gattc_evt_prim_srvc_disc_rsp_t prim_srvc_disc_rsp; /**< Primary Service Discovery Response Event Parameters. */ + ble_gattc_evt_rel_disc_rsp_t rel_disc_rsp; /**< Relationship Discovery Response Event Parameters. */ + ble_gattc_evt_char_disc_rsp_t char_disc_rsp; /**< Characteristic Discovery Response Event Parameters. */ + ble_gattc_evt_desc_disc_rsp_t desc_disc_rsp; /**< Descriptor Discovery Response Event Parameters. */ + ble_gattc_evt_char_val_by_uuid_read_rsp_t char_val_by_uuid_read_rsp; /**< Characteristic Value Read by UUID Response Event Parameters. */ + ble_gattc_evt_read_rsp_t read_rsp; /**< Read Response Event Parameters. */ + ble_gattc_evt_char_vals_read_rsp_t char_vals_read_rsp; /**< Characteristic Values Read Response Event Parameters. */ + ble_gattc_evt_write_rsp_t write_rsp; /**< Write Response Event Parameters. */ + ble_gattc_evt_hvx_t hvx; /**< Handle Value Notification/Indication Event Parameters. */ + ble_gattc_evt_exchange_mtu_rsp_t exchange_mtu_rsp; /**< Exchange MTU Response Event Parameters. */ + ble_gattc_evt_timeout_t timeout; /**< Timeout Event Parameters. */ + ble_gattc_evt_attr_info_disc_rsp_t attr_info_disc_rsp; /**< Attribute Information Discovery Event Parameters. */ + ble_gattc_evt_write_cmd_tx_complete_t write_cmd_tx_complete; /**< Write without Response transmission complete Event Parameters. */ + } params; /**< Event Parameters. @note Only valid if @ref gatt_status == @ref BLE_GATT_STATUS_SUCCESS. */ +} ble_gattc_evt_t; +/** @} */ + +/** @addtogroup BLE_GATTC_FUNCTIONS Functions + * @{ */ + +/**@brief Initiate or continue a GATT Primary Service Discovery procedure. + * + * @details This function initiates or resumes a Primary Service discovery procedure, starting from the supplied handle. + * If the last service has not been reached, this function must be called again with an updated start handle value to continue the search. + * + * @note If any of the discovered services have 128-bit UUIDs which are not present in the table provided to ble_vs_uuids_assign, a UUID structure with + * type @ref BLE_UUID_TYPE_UNKNOWN will be received in the corresponding event. + * + * @events + * @event{@ref BLE_GATTC_EVT_PRIM_SRVC_DISC_RSP} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTC_PRIM_SRVC_DISC_MSC} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] start_handle Handle to start searching from. + * @param[in] p_srvc_uuid Pointer to the service UUID to be found. If it is NULL, all primary services will be returned. + * + * @retval ::NRF_SUCCESS Successfully started or resumed the Primary Service Discovery procedure. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_BUSY Client procedure already in progress. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_PRIMARY_SERVICES_DISCOVER, uint32_t, sd_ble_gattc_primary_services_discover(uint16_t conn_handle, uint16_t start_handle, ble_uuid_t const *p_srvc_uuid)); + + +/**@brief Initiate or continue a GATT Relationship Discovery procedure. + * + * @details This function initiates or resumes the Find Included Services sub-procedure. If the last included service has not been reached, + * this must be called again with an updated handle range to continue the search. + * + * @events + * @event{@ref BLE_GATTC_EVT_REL_DISC_RSP} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTC_REL_DISC_MSC} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] p_handle_range A pointer to the range of handles of the Service to perform this procedure on. + * + * @retval ::NRF_SUCCESS Successfully started or resumed the Relationship Discovery procedure. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_BUSY Client procedure already in progress. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_RELATIONSHIPS_DISCOVER, uint32_t, sd_ble_gattc_relationships_discover(uint16_t conn_handle, ble_gattc_handle_range_t const *p_handle_range)); + + +/**@brief Initiate or continue a GATT Characteristic Discovery procedure. + * + * @details This function initiates or resumes a Characteristic discovery procedure. If the last Characteristic has not been reached, + * this must be called again with an updated handle range to continue the discovery. + * + * @note If any of the discovered characteristics have 128-bit UUIDs which are not present in the table provided to ble_vs_uuids_assign, a UUID structure with + * type @ref BLE_UUID_TYPE_UNKNOWN will be received in the corresponding event. + * + * @events + * @event{@ref BLE_GATTC_EVT_CHAR_DISC_RSP} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTC_CHAR_DISC_MSC} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] p_handle_range A pointer to the range of handles of the Service to perform this procedure on. + * + * @retval ::NRF_SUCCESS Successfully started or resumed the Characteristic Discovery procedure. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_BUSY Client procedure already in progress. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_CHARACTERISTICS_DISCOVER, uint32_t, sd_ble_gattc_characteristics_discover(uint16_t conn_handle, ble_gattc_handle_range_t const *p_handle_range)); + + +/**@brief Initiate or continue a GATT Characteristic Descriptor Discovery procedure. + * + * @details This function initiates or resumes a Characteristic Descriptor discovery procedure. If the last Descriptor has not been reached, + * this must be called again with an updated handle range to continue the discovery. + * + * @events + * @event{@ref BLE_GATTC_EVT_DESC_DISC_RSP} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTC_DESC_DISC_MSC} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] p_handle_range A pointer to the range of handles of the Characteristic to perform this procedure on. + * + * @retval ::NRF_SUCCESS Successfully started or resumed the Descriptor Discovery procedure. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_BUSY Client procedure already in progress. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_DESCRIPTORS_DISCOVER, uint32_t, sd_ble_gattc_descriptors_discover(uint16_t conn_handle, ble_gattc_handle_range_t const *p_handle_range)); + + +/**@brief Initiate or continue a GATT Read using Characteristic UUID procedure. + * + * @details This function initiates or resumes a Read using Characteristic UUID procedure. If the last Characteristic has not been reached, + * this must be called again with an updated handle range to continue the discovery. + * + * @events + * @event{@ref BLE_GATTC_EVT_CHAR_VAL_BY_UUID_READ_RSP} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTC_READ_UUID_MSC} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] p_uuid Pointer to a Characteristic value UUID to read. + * @param[in] p_handle_range A pointer to the range of handles to perform this procedure on. + * + * @retval ::NRF_SUCCESS Successfully started or resumed the Read using Characteristic UUID procedure. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_BUSY Client procedure already in progress. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_CHAR_VALUE_BY_UUID_READ, uint32_t, sd_ble_gattc_char_value_by_uuid_read(uint16_t conn_handle, ble_uuid_t const *p_uuid, ble_gattc_handle_range_t const *p_handle_range)); + + +/**@brief Initiate or continue a GATT Read (Long) Characteristic or Descriptor procedure. + * + * @details This function initiates or resumes a GATT Read (Long) Characteristic or Descriptor procedure. If the Characteristic or Descriptor + * to be read is longer than ATT_MTU - 1, this function must be called multiple times with appropriate offset to read the + * complete value. + * + * @events + * @event{@ref BLE_GATTC_EVT_READ_RSP} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTC_VALUE_READ_MSC} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] handle The handle of the attribute to be read. + * @param[in] offset Offset into the attribute value to be read. + * + * @retval ::NRF_SUCCESS Successfully started or resumed the Read (Long) procedure. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State. + * @retval ::NRF_ERROR_BUSY Client procedure already in progress. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_READ, uint32_t, sd_ble_gattc_read(uint16_t conn_handle, uint16_t handle, uint16_t offset)); + + +/**@brief Initiate a GATT Read Multiple Characteristic Values procedure. + * + * @details This function initiates a GATT Read Multiple Characteristic Values procedure. + * + * @events + * @event{@ref BLE_GATTC_EVT_CHAR_VALS_READ_RSP} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTC_READ_MULT_MSC} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] p_handles A pointer to the handle(s) of the attribute(s) to be read. + * @param[in] handle_count The number of handles in p_handles. + * + * @retval ::NRF_SUCCESS Successfully started the Read Multiple Characteristic Values procedure. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_BUSY Client procedure already in progress. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_CHAR_VALUES_READ, uint32_t, sd_ble_gattc_char_values_read(uint16_t conn_handle, uint16_t const *p_handles, uint16_t handle_count)); + + +/**@brief Perform a Write (Characteristic Value or Descriptor, with or without response, signed or not, long or reliable) procedure. + * + * @details This function can perform all write procedures described in GATT. + * + * @note Only one write with response procedure can be ongoing per connection at a time. + * If the application tries to write with response while another write with response procedure is ongoing, + * the function call will return @ref NRF_ERROR_BUSY. + * A @ref BLE_GATTC_EVT_WRITE_RSP event will be issued as soon as the write response arrives from the peer. + * + * @note The number of Write without Response that can be queued is configured by @ref ble_gattc_conn_cfg_t::write_cmd_tx_queue_size + * When the queue is full, the function call will return @ref NRF_ERROR_RESOURCES. + * A @ref BLE_GATTC_EVT_WRITE_CMD_TX_COMPLETE event will be issued as soon as the transmission of the write without response is complete. + * + * @note The application can keep track of the available queue element count for writes without responses by following the procedure below: + * - Store initial queue element count in a variable. + * - Decrement the variable, which stores the currently available queue element count, by one when a call to this function returns @ref NRF_SUCCESS. + * - Increment the variable, which stores the current available queue element count, by the count variable in @ref BLE_GATTC_EVT_WRITE_CMD_TX_COMPLETE event. + * + * @events + * @event{@ref BLE_GATTC_EVT_WRITE_CMD_TX_COMPLETE, Write without response transmission complete.} + * @event{@ref BLE_GATTC_EVT_WRITE_RSP, Write response received from the peer.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTC_VALUE_WRITE_WITHOUT_RESP_MSC} + * @mmsc{@ref BLE_GATTC_VALUE_WRITE_MSC} + * @mmsc{@ref BLE_GATTC_VALUE_LONG_WRITE_MSC} + * @mmsc{@ref BLE_GATTC_VALUE_RELIABLE_WRITE_MSC} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] p_write_params A pointer to a write parameters structure. + * + * @retval ::NRF_SUCCESS Successfully started the Write procedure. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_DATA_SIZE Invalid data size(s) supplied. + * @retval ::NRF_ERROR_BUSY For write with response, procedure already in progress. Wait for a @ref BLE_GATTC_EVT_WRITE_RSP event and retry. + * @retval ::NRF_ERROR_RESOURCES Too many writes without responses queued. + * Wait for a @ref BLE_GATTC_EVT_WRITE_CMD_TX_COMPLETE event and retry. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_WRITE, uint32_t, sd_ble_gattc_write(uint16_t conn_handle, ble_gattc_write_params_t const *p_write_params)); + + +/**@brief Send a Handle Value Confirmation to the GATT Server. + * + * @mscs + * @mmsc{@ref BLE_GATTC_HVI_MSC} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] handle The handle of the attribute in the indication. + * + * @retval ::NRF_SUCCESS Successfully queued the Handle Value Confirmation for transmission. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State or no Indication pending to be confirmed. + * @retval ::BLE_ERROR_INVALID_ATTR_HANDLE Invalid attribute handle. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_HV_CONFIRM, uint32_t, sd_ble_gattc_hv_confirm(uint16_t conn_handle, uint16_t handle)); + +/**@brief Discovers information about a range of attributes on a GATT server. + * + * @events + * @event{@ref BLE_GATTC_EVT_ATTR_INFO_DISC_RSP, Generated when information about a range of attributes has been received.} + * @endevents + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] p_handle_range The range of handles to request information about. + * + * @retval ::NRF_SUCCESS Successfully started an attribute information discovery procedure. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid connection state + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_BUSY Client procedure already in progress. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_ATTR_INFO_DISCOVER, uint32_t, sd_ble_gattc_attr_info_discover(uint16_t conn_handle, ble_gattc_handle_range_t const * p_handle_range)); + +/**@brief Start an ATT_MTU exchange by sending an Exchange MTU Request to the server. + * + * @details The SoftDevice sets ATT_MTU to the minimum of: + * - The Client RX MTU value, and + * - The Server RX MTU value from @ref BLE_GATTC_EVT_EXCHANGE_MTU_RSP. + * + * However, the SoftDevice never sets ATT_MTU lower than @ref BLE_GATT_ATT_MTU_DEFAULT. + * + * @events + * @event{@ref BLE_GATTC_EVT_EXCHANGE_MTU_RSP} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTC_MTU_EXCHANGE} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] client_rx_mtu Client RX MTU size. + * - The minimum value is @ref BLE_GATT_ATT_MTU_DEFAULT. + * - The maximum value is @ref ble_gatt_conn_cfg_t::att_mtu in the connection configuration + used for this connection. + * - The value must be equal to Server RX MTU size given in @ref sd_ble_gatts_exchange_mtu_reply + * if an ATT_MTU exchange has already been performed in the other direction. + * + * @retval ::NRF_SUCCESS Successfully sent request to the server. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid connection state or an ATT_MTU exchange was already requested once. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid Client RX MTU size supplied. + * @retval ::NRF_ERROR_BUSY Client procedure already in progress. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTC_EXCHANGE_MTU_REQUEST, uint32_t, sd_ble_gattc_exchange_mtu_request(uint16_t conn_handle, uint16_t client_rx_mtu)); + +/**@brief Iterate through Handle-Value(s) list in @ref BLE_GATTC_EVT_CHAR_VAL_BY_UUID_READ_RSP event. + * + * @param[in] p_gattc_evt Pointer to event buffer containing @ref BLE_GATTC_EVT_CHAR_VAL_BY_UUID_READ_RSP event. + * @note If the buffer contains different event, behavior is undefined. + * @param[in,out] p_iter Iterator, points to @ref ble_gattc_handle_value_t structure that will be filled in with + * the next Handle-Value pair in each iteration. If the function returns other than + * @ref NRF_SUCCESS, it will not be changed. + * - To start iteration, initialize the structure to zero. + * - To continue, pass the value from previous iteration. + * + * \code + * ble_gattc_handle_value_t iter; + * memset(&iter, 0, sizeof(ble_gattc_handle_value_t)); + * while (sd_ble_gattc_evt_char_val_by_uuid_read_rsp_iter(&ble_evt.evt.gattc_evt, &iter) == NRF_SUCCESS) + * { + * app_handle = iter.handle; + * memcpy(app_value, iter.p_value, ble_evt.evt.gattc_evt.params.char_val_by_uuid_read_rsp.value_len); + * } + * \endcode + * + * @retval ::NRF_SUCCESS Successfully retrieved the next Handle-Value pair. + * @retval ::NRF_ERROR_NOT_FOUND No more Handle-Value pairs available in the list. + */ +__STATIC_INLINE uint32_t sd_ble_gattc_evt_char_val_by_uuid_read_rsp_iter(ble_gattc_evt_t *p_gattc_evt, ble_gattc_handle_value_t *p_iter); + +/** @} */ + +#ifndef SUPPRESS_INLINE_IMPLEMENTATION + +__STATIC_INLINE uint32_t sd_ble_gattc_evt_char_val_by_uuid_read_rsp_iter(ble_gattc_evt_t *p_gattc_evt, ble_gattc_handle_value_t *p_iter) +{ + uint32_t value_len = p_gattc_evt->params.char_val_by_uuid_read_rsp.value_len; + uint8_t *p_first = p_gattc_evt->params.char_val_by_uuid_read_rsp.handle_value; + uint8_t *p_next = p_iter->p_value ? p_iter->p_value + value_len : p_first; + + if ((p_next - p_first) / (sizeof(uint16_t) + value_len) < p_gattc_evt->params.char_val_by_uuid_read_rsp.count) + { + p_iter->handle = (uint16_t)p_next[1] << 8 | p_next[0]; + p_iter->p_value = p_next + sizeof(uint16_t); + return NRF_SUCCESS; + } + else + { + return NRF_ERROR_NOT_FOUND; + } +} + +#endif /* SUPPRESS_INLINE_IMPLEMENTATION */ + +#ifdef __cplusplus +} +#endif +#endif /* BLE_GATTC_H__ */ + +/** + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gatts.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gatts.h new file mode 100644 index 0000000..e437b6e --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_gatts.h @@ -0,0 +1,845 @@ +/* + * Copyright (c) 2011 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup BLE_GATTS Generic Attribute Profile (GATT) Server + @{ + @brief Definitions and prototypes for the GATTS interface. + */ + +#ifndef BLE_GATTS_H__ +#define BLE_GATTS_H__ + +#include <stdint.h> +#include "nrf_svc.h" +#include "nrf_error.h" +#include "ble_hci.h" +#include "ble_ranges.h" +#include "ble_types.h" +#include "ble_err.h" +#include "ble_gatt.h" +#include "ble_gap.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** @addtogroup BLE_GATTS_ENUMERATIONS Enumerations + * @{ */ + +/** + * @brief GATTS API SVC numbers. + */ +enum BLE_GATTS_SVCS +{ + SD_BLE_GATTS_SERVICE_ADD = BLE_GATTS_SVC_BASE, /**< Add a service. */ + SD_BLE_GATTS_INCLUDE_ADD, /**< Add an included service. */ + SD_BLE_GATTS_CHARACTERISTIC_ADD, /**< Add a characteristic. */ + SD_BLE_GATTS_DESCRIPTOR_ADD, /**< Add a generic attribute. */ + SD_BLE_GATTS_VALUE_SET, /**< Set an attribute value. */ + SD_BLE_GATTS_VALUE_GET, /**< Get an attribute value. */ + SD_BLE_GATTS_HVX, /**< Handle Value Notification or Indication. */ + SD_BLE_GATTS_SERVICE_CHANGED, /**< Perform a Service Changed Indication to one or more peers. */ + SD_BLE_GATTS_RW_AUTHORIZE_REPLY, /**< Reply to an authorization request for a read or write operation on one or more attributes. */ + SD_BLE_GATTS_SYS_ATTR_SET, /**< Set the persistent system attributes for a connection. */ + SD_BLE_GATTS_SYS_ATTR_GET, /**< Retrieve the persistent system attributes. */ + SD_BLE_GATTS_INITIAL_USER_HANDLE_GET, /**< Retrieve the first valid user handle. */ + SD_BLE_GATTS_ATTR_GET, /**< Retrieve the UUID and/or metadata of an attribute. */ + SD_BLE_GATTS_EXCHANGE_MTU_REPLY /**< Reply to Exchange MTU Request. */ +}; + +/** + * @brief GATT Server Event IDs. + */ +enum BLE_GATTS_EVTS +{ + BLE_GATTS_EVT_WRITE = BLE_GATTS_EVT_BASE, /**< Write operation performed. \n See @ref ble_gatts_evt_write_t. */ + BLE_GATTS_EVT_RW_AUTHORIZE_REQUEST, /**< Read/Write Authorization request. \n Reply with @ref sd_ble_gatts_rw_authorize_reply. \n See @ref ble_gatts_evt_rw_authorize_request_t. */ + BLE_GATTS_EVT_SYS_ATTR_MISSING, /**< A persistent system attribute access is pending. \n Respond with @ref sd_ble_gatts_sys_attr_set. \n See @ref ble_gatts_evt_sys_attr_missing_t. */ + BLE_GATTS_EVT_HVC, /**< Handle Value Confirmation. \n See @ref ble_gatts_evt_hvc_t. */ + BLE_GATTS_EVT_SC_CONFIRM, /**< Service Changed Confirmation. \n No additional event structure applies. */ + BLE_GATTS_EVT_EXCHANGE_MTU_REQUEST, /**< Exchange MTU Request. \n Reply with @ref sd_ble_gatts_exchange_mtu_reply. \n See @ref ble_gatts_evt_exchange_mtu_request_t. */ + BLE_GATTS_EVT_TIMEOUT, /**< Peer failed to respond to an ATT request in time. \n See @ref ble_gatts_evt_timeout_t. */ + BLE_GATTS_EVT_HVN_TX_COMPLETE /**< Handle Value Notification transmission complete. \n See @ref ble_gatts_evt_hvn_tx_complete_t. */ +}; + +/**@brief GATTS Configuration IDs. + * + * IDs that uniquely identify a GATTS configuration. + */ +enum BLE_GATTS_CFGS +{ + BLE_GATTS_CFG_SERVICE_CHANGED = BLE_GATTS_CFG_BASE, /**< Service changed configuration. */ + BLE_GATTS_CFG_ATTR_TAB_SIZE, /**< Attribute table size configuration. */ +}; + +/** @} */ + +/** @addtogroup BLE_GATTS_DEFINES Defines + * @{ */ + +/** @defgroup BLE_ERRORS_GATTS SVC return values specific to GATTS + * @{ */ +#define BLE_ERROR_GATTS_INVALID_ATTR_TYPE (NRF_GATTS_ERR_BASE + 0x000) /**< Invalid attribute type. */ +#define BLE_ERROR_GATTS_SYS_ATTR_MISSING (NRF_GATTS_ERR_BASE + 0x001) /**< System Attributes missing. */ +/** @} */ + +/** @defgroup BLE_GATTS_ATTR_LENS_MAX Maximum attribute lengths + * @{ */ +#define BLE_GATTS_FIX_ATTR_LEN_MAX (510) /**< Maximum length for fixed length Attribute Values. */ +#define BLE_GATTS_VAR_ATTR_LEN_MAX (512) /**< Maximum length for variable length Attribute Values. */ +/** @} */ + +/** @defgroup BLE_GATTS_SRVC_TYPES GATT Server Service Types + * @{ */ +#define BLE_GATTS_SRVC_TYPE_INVALID 0x00 /**< Invalid Service Type. */ +#define BLE_GATTS_SRVC_TYPE_PRIMARY 0x01 /**< Primary Service. */ +#define BLE_GATTS_SRVC_TYPE_SECONDARY 0x02 /**< Secondary Type. */ +/** @} */ + + +/** @defgroup BLE_GATTS_ATTR_TYPES GATT Server Attribute Types + * @{ */ +#define BLE_GATTS_ATTR_TYPE_INVALID 0x00 /**< Invalid Attribute Type. */ +#define BLE_GATTS_ATTR_TYPE_PRIM_SRVC_DECL 0x01 /**< Primary Service Declaration. */ +#define BLE_GATTS_ATTR_TYPE_SEC_SRVC_DECL 0x02 /**< Secondary Service Declaration. */ +#define BLE_GATTS_ATTR_TYPE_INC_DECL 0x03 /**< Include Declaration. */ +#define BLE_GATTS_ATTR_TYPE_CHAR_DECL 0x04 /**< Characteristic Declaration. */ +#define BLE_GATTS_ATTR_TYPE_CHAR_VAL 0x05 /**< Characteristic Value. */ +#define BLE_GATTS_ATTR_TYPE_DESC 0x06 /**< Descriptor. */ +#define BLE_GATTS_ATTR_TYPE_OTHER 0x07 /**< Other, non-GATT specific type. */ +/** @} */ + + +/** @defgroup BLE_GATTS_OPS GATT Server Operations + * @{ */ +#define BLE_GATTS_OP_INVALID 0x00 /**< Invalid Operation. */ +#define BLE_GATTS_OP_WRITE_REQ 0x01 /**< Write Request. */ +#define BLE_GATTS_OP_WRITE_CMD 0x02 /**< Write Command. */ +#define BLE_GATTS_OP_SIGN_WRITE_CMD 0x03 /**< Signed Write Command. */ +#define BLE_GATTS_OP_PREP_WRITE_REQ 0x04 /**< Prepare Write Request. */ +#define BLE_GATTS_OP_EXEC_WRITE_REQ_CANCEL 0x05 /**< Execute Write Request: Cancel all prepared writes. */ +#define BLE_GATTS_OP_EXEC_WRITE_REQ_NOW 0x06 /**< Execute Write Request: Immediately execute all prepared writes. */ +/** @} */ + +/** @defgroup BLE_GATTS_VLOCS GATT Value Locations + * @{ */ +#define BLE_GATTS_VLOC_INVALID 0x00 /**< Invalid Location. */ +#define BLE_GATTS_VLOC_STACK 0x01 /**< Attribute Value is located in stack memory, no user memory is required. */ +#define BLE_GATTS_VLOC_USER 0x02 /**< Attribute Value is located in user memory. This requires the user to maintain a valid buffer through the lifetime of the attribute, since the stack + will read and write directly to the memory using the pointer provided in the APIs. There are no alignment requirements for the buffer. */ +/** @} */ + +/** @defgroup BLE_GATTS_AUTHORIZE_TYPES GATT Server Authorization Types + * @{ */ +#define BLE_GATTS_AUTHORIZE_TYPE_INVALID 0x00 /**< Invalid Type. */ +#define BLE_GATTS_AUTHORIZE_TYPE_READ 0x01 /**< Authorize a Read Operation. */ +#define BLE_GATTS_AUTHORIZE_TYPE_WRITE 0x02 /**< Authorize a Write Request Operation. */ +/** @} */ + +/** @defgroup BLE_GATTS_SYS_ATTR_FLAGS System Attribute Flags + * @{ */ +#define BLE_GATTS_SYS_ATTR_FLAG_SYS_SRVCS (1 << 0) /**< Restrict system attributes to system services only. */ +#define BLE_GATTS_SYS_ATTR_FLAG_USR_SRVCS (1 << 1) /**< Restrict system attributes to user services only. */ +/** @} */ + +/** @defgroup BLE_GATTS_SERVICE_CHANGED Service Changed Inclusion Values + * @{ + */ +#define BLE_GATTS_SERVICE_CHANGED_DEFAULT (1) /**< Default is to include the Service Changed characteristic in the Attribute Table. */ +/** @} */ + +/** @defgroup BLE_GATTS_ATTR_TAB_SIZE Attribute Table size + * @{ + */ +#define BLE_GATTS_ATTR_TAB_SIZE_MIN (248) /**< Minimum Attribute Table size */ +#define BLE_GATTS_ATTR_TAB_SIZE_DEFAULT (1408) /**< Default Attribute Table size. */ +/** @} */ + +/** @defgroup BLE_GATTS_DEFAULTS GATT Server defaults + * @{ + */ +#define BLE_GATTS_HVN_TX_QUEUE_SIZE_DEFAULT 1 /**< Default number of Handle Value Notifications that can be queued for transmission. */ +/** @} */ + +/** @} */ + +/** @addtogroup BLE_GATTS_STRUCTURES Structures + * @{ */ + +/** + * @brief BLE GATTS connection configuration parameters, set with @ref sd_ble_cfg_set. + */ +typedef struct +{ + uint8_t hvn_tx_queue_size; /**< Minimum guaranteed number of Handle Value Notifications that can be queued for transmission. + The default value is @ref BLE_GATTS_HVN_TX_QUEUE_SIZE_DEFAULT */ +} ble_gatts_conn_cfg_t; + +/**@brief Attribute metadata. */ +typedef struct +{ + ble_gap_conn_sec_mode_t read_perm; /**< Read permissions. */ + ble_gap_conn_sec_mode_t write_perm; /**< Write permissions. */ + uint8_t vlen :1; /**< Variable length attribute. */ + uint8_t vloc :2; /**< Value location, see @ref BLE_GATTS_VLOCS.*/ + uint8_t rd_auth :1; /**< Read authorization and value will be requested from the application on every read operation. */ + uint8_t wr_auth :1; /**< Write authorization will be requested from the application on every Write Request operation (but not Write Command). */ +} ble_gatts_attr_md_t; + + +/**@brief GATT Attribute. */ +typedef struct +{ + ble_uuid_t const *p_uuid; /**< Pointer to the attribute UUID. */ + ble_gatts_attr_md_t const *p_attr_md; /**< Pointer to the attribute metadata structure. */ + uint16_t init_len; /**< Initial attribute value length in bytes. */ + uint16_t init_offs; /**< Initial attribute value offset in bytes. If different from zero, the first init_offs bytes of the attribute value will be left uninitialized. */ + uint16_t max_len; /**< Maximum attribute value length in bytes, see @ref BLE_GATTS_ATTR_LENS_MAX for maximum values. */ + uint8_t *p_value; /**< Pointer to the attribute data. Please note that if the @ref BLE_GATTS_VLOC_USER value location is selected in the attribute metadata, this will have to point to a buffer + that remains valid through the lifetime of the attribute. This excludes usage of automatic variables that may go out of scope or any other temporary location. + The stack may access that memory directly without the application's knowledge. For writable characteristics, this value must not be a location in flash memory.*/ +} ble_gatts_attr_t; + +/**@brief GATT Attribute Value. */ +typedef struct +{ + uint16_t len; /**< Length in bytes to be written or read. Length in bytes written or read after successful return.*/ + uint16_t offset; /**< Attribute value offset. */ + uint8_t *p_value; /**< Pointer to where value is stored or will be stored. + If value is stored in user memory, only the attribute length is updated when p_value == NULL. + Set to NULL when reading to obtain the complete length of the attribute value */ +} ble_gatts_value_t; + + +/**@brief GATT Characteristic Presentation Format. */ +typedef struct +{ + uint8_t format; /**< Format of the value, see @ref BLE_GATT_CPF_FORMATS. */ + int8_t exponent; /**< Exponent for integer data types. */ + uint16_t unit; /**< Unit from Bluetooth Assigned Numbers. */ + uint8_t name_space; /**< Namespace from Bluetooth Assigned Numbers, see @ref BLE_GATT_CPF_NAMESPACES. */ + uint16_t desc; /**< Namespace description from Bluetooth Assigned Numbers, see @ref BLE_GATT_CPF_NAMESPACES. */ +} ble_gatts_char_pf_t; + + +/**@brief GATT Characteristic metadata. */ +typedef struct +{ + ble_gatt_char_props_t char_props; /**< Characteristic Properties. */ + ble_gatt_char_ext_props_t char_ext_props; /**< Characteristic Extended Properties. */ + uint8_t const *p_char_user_desc; /**< Pointer to a UTF-8 encoded string (non-NULL terminated), NULL if the descriptor is not required. */ + uint16_t char_user_desc_max_size; /**< The maximum size in bytes of the user description descriptor. */ + uint16_t char_user_desc_size; /**< The size of the user description, must be smaller or equal to char_user_desc_max_size. */ + ble_gatts_char_pf_t const *p_char_pf; /**< Pointer to a presentation format structure or NULL if the CPF descriptor is not required. */ + ble_gatts_attr_md_t const *p_user_desc_md; /**< Attribute metadata for the User Description descriptor, or NULL for default values. */ + ble_gatts_attr_md_t const *p_cccd_md; /**< Attribute metadata for the Client Characteristic Configuration Descriptor, or NULL for default values. */ + ble_gatts_attr_md_t const *p_sccd_md; /**< Attribute metadata for the Server Characteristic Configuration Descriptor, or NULL for default values. */ +} ble_gatts_char_md_t; + + +/**@brief GATT Characteristic Definition Handles. */ +typedef struct +{ + uint16_t value_handle; /**< Handle to the characteristic value. */ + uint16_t user_desc_handle; /**< Handle to the User Description descriptor, or @ref BLE_GATT_HANDLE_INVALID if not present. */ + uint16_t cccd_handle; /**< Handle to the Client Characteristic Configuration Descriptor, or @ref BLE_GATT_HANDLE_INVALID if not present. */ + uint16_t sccd_handle; /**< Handle to the Server Characteristic Configuration Descriptor, or @ref BLE_GATT_HANDLE_INVALID if not present. */ +} ble_gatts_char_handles_t; + + +/**@brief GATT HVx parameters. */ +typedef struct +{ + uint16_t handle; /**< Characteristic Value Handle. */ + uint8_t type; /**< Indication or Notification, see @ref BLE_GATT_HVX_TYPES. */ + uint16_t offset; /**< Offset within the attribute value. */ + uint16_t *p_len; /**< Length in bytes to be written, length in bytes written after return. */ + uint8_t const *p_data; /**< Actual data content, use NULL to use the current attribute value. */ +} ble_gatts_hvx_params_t; + +/**@brief GATT Authorization parameters. */ +typedef struct +{ + uint16_t gatt_status; /**< GATT status code for the operation, see @ref BLE_GATT_STATUS_CODES. */ + uint8_t update : 1; /**< If set, data supplied in p_data will be used to update the attribute value. + Please note that for @ref BLE_GATTS_AUTHORIZE_TYPE_WRITE operations this bit must always be set, + as the data to be written needs to be stored and later provided by the application. */ + uint16_t offset; /**< Offset of the attribute value being updated. */ + uint16_t len; /**< Length in bytes of the value in p_data pointer, see @ref BLE_GATTS_ATTR_LENS_MAX. */ + uint8_t const *p_data; /**< Pointer to new value used to update the attribute value. */ +} ble_gatts_authorize_params_t; + +/**@brief GATT Read or Write Authorize Reply parameters. */ +typedef struct +{ + uint8_t type; /**< Type of authorize operation, see @ref BLE_GATTS_AUTHORIZE_TYPES. */ + union { + ble_gatts_authorize_params_t read; /**< Read authorization parameters. */ + ble_gatts_authorize_params_t write; /**< Write authorization parameters. */ + } params; /**< Reply Parameters. */ +} ble_gatts_rw_authorize_reply_params_t; + +/**@brief Service Changed Inclusion configuration parameters, set with @ref sd_ble_cfg_set. */ +typedef struct +{ + uint8_t service_changed : 1; /**< If 1, include the Service Changed characteristic in the Attribute Table. Default is @ref BLE_GATTS_SERVICE_CHANGED_DEFAULT. */ +} ble_gatts_cfg_service_changed_t; + +/**@brief Attribute table size configuration parameters, set with @ref sd_ble_cfg_set. + * + * @retval ::NRF_ERROR_INVALID_LENGTH One or more of the following is true: + * - The specified Attribute Table size is too small. + * The minimum acceptable size is defined by @ref BLE_GATTS_ATTR_TAB_SIZE_MIN. + * - The specified Attribute Table size is not a multiple of 4. + */ +typedef struct +{ + uint32_t attr_tab_size; /**< Attribute table size. Default is @ref BLE_GATTS_ATTR_TAB_SIZE_DEFAULT, minimum is @ref BLE_GATTS_ATTR_TAB_SIZE_MIN. */ +} ble_gatts_cfg_attr_tab_size_t; + +/**@brief Config structure for GATTS configurations. */ +typedef union +{ + ble_gatts_cfg_service_changed_t service_changed; /**< Include service changed characteristic, cfg_id is @ref BLE_GATTS_CFG_SERVICE_CHANGED. */ + ble_gatts_cfg_attr_tab_size_t attr_tab_size; /**< Attribute table size, cfg_id is @ref BLE_GATTS_CFG_ATTR_TAB_SIZE. */ +} ble_gatts_cfg_t; + + +/**@brief Event structure for @ref BLE_GATTS_EVT_WRITE. */ +typedef struct +{ + uint16_t handle; /**< Attribute Handle. */ + ble_uuid_t uuid; /**< Attribute UUID. */ + uint8_t op; /**< Type of write operation, see @ref BLE_GATTS_OPS. */ + uint8_t auth_required; /**< Writing operation deferred due to authorization requirement. Application may use @ref sd_ble_gatts_value_set to finalize the writing operation. */ + uint16_t offset; /**< Offset for the write operation. */ + uint16_t len; /**< Length of the received data. */ + uint8_t data[1]; /**< Received data. @note This is a variable length array. The size of 1 indicated is only a placeholder for compilation. + See @ref sd_ble_evt_get for more information on how to use event structures with variable length array members. */ +} ble_gatts_evt_write_t; + +/**@brief Event substructure for authorized read requests, see @ref ble_gatts_evt_rw_authorize_request_t. */ +typedef struct +{ + uint16_t handle; /**< Attribute Handle. */ + ble_uuid_t uuid; /**< Attribute UUID. */ + uint16_t offset; /**< Offset for the read operation. */ +} ble_gatts_evt_read_t; + +/**@brief Event structure for @ref BLE_GATTS_EVT_RW_AUTHORIZE_REQUEST. */ +typedef struct +{ + uint8_t type; /**< Type of authorize operation, see @ref BLE_GATTS_AUTHORIZE_TYPES. */ + union { + ble_gatts_evt_read_t read; /**< Attribute Read Parameters. */ + ble_gatts_evt_write_t write; /**< Attribute Write Parameters. */ + } request; /**< Request Parameters. */ +} ble_gatts_evt_rw_authorize_request_t; + +/**@brief Event structure for @ref BLE_GATTS_EVT_SYS_ATTR_MISSING. */ +typedef struct +{ + uint8_t hint; /**< Hint (currently unused). */ +} ble_gatts_evt_sys_attr_missing_t; + + +/**@brief Event structure for @ref BLE_GATTS_EVT_HVC. */ +typedef struct +{ + uint16_t handle; /**< Attribute Handle. */ +} ble_gatts_evt_hvc_t; + +/**@brief Event structure for @ref BLE_GATTS_EVT_EXCHANGE_MTU_REQUEST. */ +typedef struct +{ + uint16_t client_rx_mtu; /**< Client RX MTU size. */ +} ble_gatts_evt_exchange_mtu_request_t; + +/**@brief Event structure for @ref BLE_GATTS_EVT_TIMEOUT. */ +typedef struct +{ + uint8_t src; /**< Timeout source, see @ref BLE_GATT_TIMEOUT_SOURCES. */ +} ble_gatts_evt_timeout_t; + +/**@brief Event structure for @ref BLE_GATTS_EVT_HVN_TX_COMPLETE. */ +typedef struct +{ + uint8_t count; /**< Number of notification transmissions completed. */ +} ble_gatts_evt_hvn_tx_complete_t; + +/**@brief GATTS event structure. */ +typedef struct +{ + uint16_t conn_handle; /**< Connection Handle on which the event occurred. */ + union + { + ble_gatts_evt_write_t write; /**< Write Event Parameters. */ + ble_gatts_evt_rw_authorize_request_t authorize_request; /**< Read or Write Authorize Request Parameters. */ + ble_gatts_evt_sys_attr_missing_t sys_attr_missing; /**< System attributes missing. */ + ble_gatts_evt_hvc_t hvc; /**< Handle Value Confirmation Event Parameters. */ + ble_gatts_evt_exchange_mtu_request_t exchange_mtu_request; /**< Exchange MTU Request Event Parameters. */ + ble_gatts_evt_timeout_t timeout; /**< Timeout Event. */ + ble_gatts_evt_hvn_tx_complete_t hvn_tx_complete; /**< Handle Value Notification transmission complete Event Parameters. */ + } params; /**< Event Parameters. */ +} ble_gatts_evt_t; + +/** @} */ + +/** @addtogroup BLE_GATTS_FUNCTIONS Functions + * @{ */ + +/**@brief Add a service declaration to the Attribute Table. + * + * @note Secondary Services are only relevant in the context of the entity that references them, it is therefore forbidden to + * add a secondary service declaration that is not referenced by another service later in the Attribute Table. + * + * @mscs + * @mmsc{@ref BLE_GATTS_ATT_TABLE_POP_MSC} + * @endmscs + * + * @param[in] type Toggles between primary and secondary services, see @ref BLE_GATTS_SRVC_TYPES. + * @param[in] p_uuid Pointer to service UUID. + * @param[out] p_handle Pointer to a 16-bit word where the assigned handle will be stored. + * + * @retval ::NRF_SUCCESS Successfully added a service declaration. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied, Vendor Specific UUIDs need to be present in the table. + * @retval ::NRF_ERROR_FORBIDDEN Forbidden value supplied, certain UUIDs are reserved for the stack. + * @retval ::NRF_ERROR_NO_MEM Not enough memory to complete operation. + */ +SVCALL(SD_BLE_GATTS_SERVICE_ADD, uint32_t, sd_ble_gatts_service_add(uint8_t type, ble_uuid_t const *p_uuid, uint16_t *p_handle)); + + +/**@brief Add an include declaration to the Attribute Table. + * + * @note It is currently only possible to add an include declaration to the last added service (i.e. only sequential population is supported at this time). + * + * @note The included service must already be present in the Attribute Table prior to this call. + * + * @mscs + * @mmsc{@ref BLE_GATTS_ATT_TABLE_POP_MSC} + * @endmscs + * + * @param[in] service_handle Handle of the service where the included service is to be placed, if @ref BLE_GATT_HANDLE_INVALID is used, it will be placed sequentially. + * @param[in] inc_srvc_handle Handle of the included service. + * @param[out] p_include_handle Pointer to a 16-bit word where the assigned handle will be stored. + * + * @retval ::NRF_SUCCESS Successfully added an include declaration. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied, handle values need to match previously added services. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation. + * @retval ::NRF_ERROR_NOT_SUPPORTED Feature is not supported, service_handle must be that of the last added service. + * @retval ::NRF_ERROR_FORBIDDEN Forbidden value supplied, self inclusions are not allowed. + * @retval ::NRF_ERROR_NO_MEM Not enough memory to complete operation. + * @retval ::NRF_ERROR_NOT_FOUND Attribute not found. + */ +SVCALL(SD_BLE_GATTS_INCLUDE_ADD, uint32_t, sd_ble_gatts_include_add(uint16_t service_handle, uint16_t inc_srvc_handle, uint16_t *p_include_handle)); + + +/**@brief Add a characteristic declaration, a characteristic value declaration and optional characteristic descriptor declarations to the Attribute Table. + * + * @note It is currently only possible to add a characteristic to the last added service (i.e. only sequential population is supported at this time). + * + * @note Several restrictions apply to the parameters, such as matching permissions between the user description descriptor and the writable auxiliaries bits, + * readable (no security) and writable (selectable) CCCDs and SCCDs and valid presentation format values. + * + * @note If no metadata is provided for the optional descriptors, their permissions will be derived from the characteristic permissions. + * + * @mscs + * @mmsc{@ref BLE_GATTS_ATT_TABLE_POP_MSC} + * @endmscs + * + * @param[in] service_handle Handle of the service where the characteristic is to be placed, if @ref BLE_GATT_HANDLE_INVALID is used, it will be placed sequentially. + * @param[in] p_char_md Characteristic metadata. + * @param[in] p_attr_char_value Pointer to the attribute structure corresponding to the characteristic value. + * @param[out] p_handles Pointer to the structure where the assigned handles will be stored. + * + * @retval ::NRF_SUCCESS Successfully added a characteristic. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied, service handle, Vendor Specific UUIDs, lengths, and permissions need to adhere to the constraints. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation, a service context is required. + * @retval ::NRF_ERROR_FORBIDDEN Forbidden value supplied, certain UUIDs are reserved for the stack. + * @retval ::NRF_ERROR_NO_MEM Not enough memory to complete operation. + * @retval ::NRF_ERROR_DATA_SIZE Invalid data size(s) supplied, attribute lengths are restricted by @ref BLE_GATTS_ATTR_LENS_MAX. + */ +SVCALL(SD_BLE_GATTS_CHARACTERISTIC_ADD, uint32_t, sd_ble_gatts_characteristic_add(uint16_t service_handle, ble_gatts_char_md_t const *p_char_md, ble_gatts_attr_t const *p_attr_char_value, ble_gatts_char_handles_t *p_handles)); + + +/**@brief Add a descriptor to the Attribute Table. + * + * @note It is currently only possible to add a descriptor to the last added characteristic (i.e. only sequential population is supported at this time). + * + * @mscs + * @mmsc{@ref BLE_GATTS_ATT_TABLE_POP_MSC} + * @endmscs + * + * @param[in] char_handle Handle of the characteristic where the descriptor is to be placed, if @ref BLE_GATT_HANDLE_INVALID is used, it will be placed sequentially. + * @param[in] p_attr Pointer to the attribute structure. + * @param[out] p_handle Pointer to a 16-bit word where the assigned handle will be stored. + * + * @retval ::NRF_SUCCESS Successfully added a descriptor. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied, characteristic handle, Vendor Specific UUIDs, lengths, and permissions need to adhere to the constraints. + * @retval ::NRF_ERROR_INVALID_STATE Invalid state to perform operation, a characteristic context is required. + * @retval ::NRF_ERROR_FORBIDDEN Forbidden value supplied, certain UUIDs are reserved for the stack. + * @retval ::NRF_ERROR_NO_MEM Not enough memory to complete operation. + * @retval ::NRF_ERROR_DATA_SIZE Invalid data size(s) supplied, attribute lengths are restricted by @ref BLE_GATTS_ATTR_LENS_MAX. + */ +SVCALL(SD_BLE_GATTS_DESCRIPTOR_ADD, uint32_t, sd_ble_gatts_descriptor_add(uint16_t char_handle, ble_gatts_attr_t const *p_attr, uint16_t *p_handle)); + +/**@brief Set the value of a given attribute. + * + * @note Values other than system attributes can be set at any time, regardless of whether any active connections exist. + * + * @mscs + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_QUEUE_FULL_MSC} + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_NOBUF_NOAUTH_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. Ignored if the value does not belong to a system attribute. + * @param[in] handle Attribute handle. + * @param[in,out] p_value Attribute value information. + * + * @retval ::NRF_SUCCESS Successfully set the value of the attribute. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_NOT_FOUND Attribute not found. + * @retval ::NRF_ERROR_FORBIDDEN Forbidden handle supplied, certain attributes are not modifiable by the application. + * @retval ::NRF_ERROR_DATA_SIZE Invalid data size(s) supplied, attribute lengths are restricted by @ref BLE_GATTS_ATTR_LENS_MAX. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied on a system attribute. + */ +SVCALL(SD_BLE_GATTS_VALUE_SET, uint32_t, sd_ble_gatts_value_set(uint16_t conn_handle, uint16_t handle, ble_gatts_value_t *p_value)); + +/**@brief Get the value of a given attribute. + * + * @note If the attribute value is longer than the size of the supplied buffer, + * @ref ble_gatts_value_t::len will return the total attribute value length (excluding offset), + * and not the number of bytes actually returned in @ref ble_gatts_value_t::p_value. + * The application may use this information to allocate a suitable buffer size. + * + * @note When retrieving system attribute values with this function, the connection handle + * may refer to an already disconnected connection. Refer to the documentation of + * @ref sd_ble_gatts_sys_attr_get for further information. + * + * @param[in] conn_handle Connection handle. Ignored if the value does not belong to a system attribute. + * @param[in] handle Attribute handle. + * @param[in,out] p_value Attribute value information. + * + * @retval ::NRF_SUCCESS Successfully retrieved the value of the attribute. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_NOT_FOUND Attribute not found. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid attribute offset supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid connection handle supplied on a system attribute. + * @retval ::BLE_ERROR_GATTS_SYS_ATTR_MISSING System attributes missing, use @ref sd_ble_gatts_sys_attr_set to set them to a known value. + */ +SVCALL(SD_BLE_GATTS_VALUE_GET, uint32_t, sd_ble_gatts_value_get(uint16_t conn_handle, uint16_t handle, ble_gatts_value_t *p_value)); + +/**@brief Notify or Indicate an attribute value. + * + * @details This function checks for the relevant Client Characteristic Configuration descriptor value to verify that the relevant operation + * (notification or indication) has been enabled by the client. It is also able to update the attribute value before issuing the PDU, so that + * the application can atomically perform a value update and a server initiated transaction with a single API call. + * + * @note The local attribute value may be updated even if an outgoing packet is not sent to the peer due to an error during execution. + * The Attribute Table has been updated if one of the following error codes is returned: @ref NRF_ERROR_INVALID_STATE, @ref NRF_ERROR_BUSY, + * @ref NRF_ERROR_FORBIDDEN, @ref BLE_ERROR_GATTS_SYS_ATTR_MISSING and @ref NRF_ERROR_RESOURCES. + * The caller can check whether the value has been updated by looking at the contents of *(@ref ble_gatts_hvx_params_t::p_len). + * + * @note Only one indication procedure can be ongoing per connection at a time. + * If the application tries to indicate an attribute value while another indication procedure is ongoing, + * the function call will return @ref NRF_ERROR_BUSY. + * A @ref BLE_GATTS_EVT_HVC event will be issued as soon as the confirmation arrives from the peer. + * + * @note The number of Handle Value Notifications that can be queued is configured by @ref ble_gatts_conn_cfg_t::hvn_tx_queue_size + * When the queue is full, the function call will return @ref NRF_ERROR_RESOURCES. + * A @ref BLE_GATTS_EVT_HVN_TX_COMPLETE event will be issued as soon as the transmission of the notification is complete. + * + * @note The application can keep track of the available queue element count for notifications by following the procedure below: + * - Store initial queue element count in a variable. + * - Decrement the variable, which stores the currently available queue element count, by one when a call to this function returns @ref NRF_SUCCESS. + * - Increment the variable, which stores the current available queue element count, by the count variable in @ref BLE_GATTS_EVT_HVN_TX_COMPLETE event. + * + * @events + * @event{@ref BLE_GATTS_EVT_HVN_TX_COMPLETE, Notification transmission complete.} + * @event{@ref BLE_GATTS_EVT_HVC, Confirmation received from the peer.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTS_HVX_SYS_ATTRS_MISSING_MSC} + * @mmsc{@ref BLE_GATTS_HVN_MSC} + * @mmsc{@ref BLE_GATTS_HVI_MSC} + * @mmsc{@ref BLE_GATTS_HVX_DISABLED_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in,out] p_hvx_params Pointer to an HVx parameters structure. If @ref ble_gatts_hvx_params_t::p_data + * contains a non-NULL pointer the attribute value will be updated with the contents + * pointed by it before sending the notification or indication. If the attribute value + * is updated, @ref ble_gatts_hvx_params_t::p_len is updated by the SoftDevice to + * contain the number of actual bytes written, else it will be set to 0. + * + * @retval ::NRF_SUCCESS Successfully queued a notification or indication for transmission, and optionally updated the attribute value. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE One or more of the following is true: + * - Invalid Connection State + * - Notifications and/or indications not enabled in the CCCD + * - An ATT_MTU exchange is ongoing + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::BLE_ERROR_INVALID_ATTR_HANDLE Invalid attribute handle(s) supplied. Only attributes added directly by the application are available to notify and indicate. + * @retval ::BLE_ERROR_GATTS_INVALID_ATTR_TYPE Invalid attribute type(s) supplied, only characteristic values may be notified and indicated. + * @retval ::NRF_ERROR_NOT_FOUND Attribute not found. + * @retval ::NRF_ERROR_FORBIDDEN The connection's current security level is lower than the one required by the write permissions of the CCCD associated with this characteristic. + * @retval ::NRF_ERROR_DATA_SIZE Invalid data size(s) supplied. + * @retval ::NRF_ERROR_BUSY For @ref BLE_GATT_HVX_INDICATION Procedure already in progress. Wait for a @ref BLE_GATTS_EVT_HVC event and retry. + * @retval ::BLE_ERROR_GATTS_SYS_ATTR_MISSING System attributes missing, use @ref sd_ble_gatts_sys_attr_set to set them to a known value. + * @retval ::NRF_ERROR_RESOURCES Too many notifications queued. + * Wait for a @ref BLE_GATTS_EVT_HVN_TX_COMPLETE event and retry. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTS_HVX, uint32_t, sd_ble_gatts_hvx(uint16_t conn_handle, ble_gatts_hvx_params_t const *p_hvx_params)); + +/**@brief Indicate the Service Changed attribute value. + * + * @details This call will send a Handle Value Indication to one or more peers connected to inform them that the Attribute + * Table layout has changed. As soon as the peer has confirmed the indication, a @ref BLE_GATTS_EVT_SC_CONFIRM event will + * be issued. + * + * @note Some of the restrictions and limitations that apply to @ref sd_ble_gatts_hvx also apply here. + * + * @events + * @event{@ref BLE_GATTS_EVT_SC_CONFIRM, Confirmation of attribute table change received from peer.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_GATTS_SC_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] start_handle Start of affected attribute handle range. + * @param[in] end_handle End of affected attribute handle range. + * + * @retval ::NRF_SUCCESS Successfully queued the Service Changed indication for transmission. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_NOT_SUPPORTED Service Changed not enabled at initialization. See @ref + * sd_ble_cfg_set and @ref ble_gatts_cfg_service_changed_t. + * @retval ::NRF_ERROR_INVALID_STATE One or more of the following is true: + * - Invalid Connection State + * - Notifications and/or indications not enabled in the CCCD + * - An ATT_MTU exchange is ongoing + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::BLE_ERROR_INVALID_ATTR_HANDLE Invalid attribute handle(s) supplied, handles must be in the range populated by the application. + * @retval ::NRF_ERROR_BUSY Procedure already in progress. + * @retval ::BLE_ERROR_GATTS_SYS_ATTR_MISSING System attributes missing, use @ref sd_ble_gatts_sys_attr_set to set them to a known value. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTS_SERVICE_CHANGED, uint32_t, sd_ble_gatts_service_changed(uint16_t conn_handle, uint16_t start_handle, uint16_t end_handle)); + +/**@brief Respond to a Read/Write authorization request. + * + * @note This call should only be used as a response to a @ref BLE_GATTS_EVT_RW_AUTHORIZE_REQUEST event issued to the application. + * + * @mscs + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_NOBUF_AUTH_MSC} + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_BUF_AUTH_MSC} + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_NOBUF_NOAUTH_MSC} + * @mmsc{@ref BLE_GATTS_READ_REQ_AUTH_MSC} + * @mmsc{@ref BLE_GATTS_WRITE_REQ_AUTH_MSC} + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_QUEUE_FULL_MSC} + * @mmsc{@ref BLE_GATTS_QUEUED_WRITE_PEER_CANCEL_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] p_rw_authorize_reply_params Pointer to a structure with the attribute provided by the application. + * + * @note @ref ble_gatts_authorize_params_t::p_data is ignored when this function is used to respond + * to a @ref BLE_GATTS_AUTHORIZE_TYPE_READ event if @ref ble_gatts_authorize_params_t::update + * is set to 0. + * + * @retval ::NRF_SUCCESS Successfully queued a response to the peer, and in the case of a write operation, Attribute Table updated. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_BUSY The stack is busy, process pending events and retry. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State or no authorization request pending. + * @retval ::NRF_ERROR_INVALID_PARAM Authorization op invalid, + * handle supplied does not match requested handle, + * or invalid data to be written provided by the application. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTS_RW_AUTHORIZE_REPLY, uint32_t, sd_ble_gatts_rw_authorize_reply(uint16_t conn_handle, ble_gatts_rw_authorize_reply_params_t const *p_rw_authorize_reply_params)); + + +/**@brief Update persistent system attribute information. + * + * @details Supply information about persistent system attributes to the stack, + * previously obtained using @ref sd_ble_gatts_sys_attr_get. + * This call is only allowed for active connections, and is usually + * made immediately after a connection is established with an known bonded device, + * often as a response to a @ref BLE_GATTS_EVT_SYS_ATTR_MISSING. + * + * p_sysattrs may point directly to the application's stored copy of the system attributes + * obtained using @ref sd_ble_gatts_sys_attr_get. + * If the pointer is NULL, the system attribute info is initialized, assuming that + * the application does not have any previously saved system attribute data for this device. + * + * @note The state of persistent system attributes is reset upon connection establishment and then remembered for its duration. + * + * @note If this call returns with an error code different from @ref NRF_SUCCESS, the storage of persistent system attributes may have been completed only partially. + * This means that the state of the attribute table is undefined, and the application should either provide a new set of attributes using this same call or + * reset the SoftDevice to return to a known state. + * + * @note When the @ref BLE_GATTS_SYS_ATTR_FLAG_SYS_SRVCS is used with this function, only the system attributes included in system services will be modified. + * @note When the @ref BLE_GATTS_SYS_ATTR_FLAG_USR_SRVCS is used with this function, only the system attributes included in user services will be modified. + * + * @mscs + * @mmsc{@ref BLE_GATTS_HVX_SYS_ATTRS_MISSING_MSC} + * @mmsc{@ref BLE_GATTS_SYS_ATTRS_UNK_PEER_MSC} + * @mmsc{@ref BLE_GATTS_SYS_ATTRS_BONDED_PEER_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle. + * @param[in] p_sys_attr_data Pointer to a saved copy of system attributes supplied to the stack, or NULL. + * @param[in] len Size of data pointed by p_sys_attr_data, in octets. + * @param[in] flags Optional additional flags, see @ref BLE_GATTS_SYS_ATTR_FLAGS + * + * @retval ::NRF_SUCCESS Successfully set the system attribute information. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid flags supplied. + * @retval ::NRF_ERROR_INVALID_DATA Invalid data supplied, the data should be exactly the same as retrieved with @ref sd_ble_gatts_sys_attr_get. + * @retval ::NRF_ERROR_NO_MEM Not enough memory to complete operation. + */ +SVCALL(SD_BLE_GATTS_SYS_ATTR_SET, uint32_t, sd_ble_gatts_sys_attr_set(uint16_t conn_handle, uint8_t const *p_sys_attr_data, uint16_t len, uint32_t flags)); + + +/**@brief Retrieve persistent system attribute information from the stack. + * + * @details This call is used to retrieve information about values to be stored persistently by the application + * during the lifetime of a connection or after it has been terminated. When a new connection is established with the same bonded device, + * the system attribute information retrieved with this function should be restored using using @ref sd_ble_gatts_sys_attr_set. + * If retrieved after disconnection, the data should be read before a new connection established. The connection handle for + * the previous, now disconnected, connection will remain valid until a new one is created to allow this API call to refer to it. + * Connection handles belonging to active connections can be used as well, but care should be taken since the system attributes + * may be written to at any time by the peer during a connection's lifetime. + * + * @note When the @ref BLE_GATTS_SYS_ATTR_FLAG_SYS_SRVCS is used with this function, only the system attributes included in system services will be returned. + * @note When the @ref BLE_GATTS_SYS_ATTR_FLAG_USR_SRVCS is used with this function, only the system attributes included in user services will be returned. + * + * @mscs + * @mmsc{@ref BLE_GATTS_SYS_ATTRS_BONDED_PEER_MSC} + * @endmscs + * + * @param[in] conn_handle Connection handle of the recently terminated connection. + * @param[out] p_sys_attr_data Pointer to a buffer where updated information about system attributes will be filled in. The format of the data is described + * in @ref BLE_GATTS_SYS_ATTRS_FORMAT. NULL can be provided to obtain the length of the data. + * @param[in,out] p_len Size of application buffer if p_sys_attr_data is not NULL. Unconditionally updated to actual length of system attribute data. + * @param[in] flags Optional additional flags, see @ref BLE_GATTS_SYS_ATTR_FLAGS + * + * @retval ::NRF_SUCCESS Successfully retrieved the system attribute information. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid flags supplied. + * @retval ::NRF_ERROR_DATA_SIZE The system attribute information did not fit into the provided buffer. + * @retval ::NRF_ERROR_NOT_FOUND No system attributes found. + */ +SVCALL(SD_BLE_GATTS_SYS_ATTR_GET, uint32_t, sd_ble_gatts_sys_attr_get(uint16_t conn_handle, uint8_t *p_sys_attr_data, uint16_t *p_len, uint32_t flags)); + + +/**@brief Retrieve the first valid user attribute handle. + * + * @param[out] p_handle Pointer to an integer where the handle will be stored. + * + * @retval ::NRF_SUCCESS Successfully retrieved the handle. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + */ +SVCALL(SD_BLE_GATTS_INITIAL_USER_HANDLE_GET, uint32_t, sd_ble_gatts_initial_user_handle_get(uint16_t *p_handle)); + +/**@brief Retrieve the attribute UUID and/or metadata. + * + * @param[in] handle Attribute handle + * @param[out] p_uuid UUID of the attribute. Use NULL to omit this field. + * @param[out] p_md Metadata of the attribute. Use NULL to omit this field. + * + * @retval ::NRF_SUCCESS Successfully retrieved the attribute metadata, + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameters supplied. Returned when both @c p_uuid and @c p_md are NULL. + * @retval ::NRF_ERROR_NOT_FOUND Attribute was not found. + */ +SVCALL(SD_BLE_GATTS_ATTR_GET, uint32_t, sd_ble_gatts_attr_get(uint16_t handle, ble_uuid_t * p_uuid, ble_gatts_attr_md_t * p_md)); + +/**@brief Reply to an ATT_MTU exchange request by sending an Exchange MTU Response to the client. + * + * @details This function is only used to reply to a @ref BLE_GATTS_EVT_EXCHANGE_MTU_REQUEST event. + * + * @details The SoftDevice sets ATT_MTU to the minimum of: + * - The Client RX MTU value from @ref BLE_GATTS_EVT_EXCHANGE_MTU_REQUEST, and + * - The Server RX MTU value. + * + * However, the SoftDevice never sets ATT_MTU lower than @ref BLE_GATT_ATT_MTU_DEFAULT. + * + * @mscs + * @mmsc{@ref BLE_GATTS_MTU_EXCHANGE} + * @endmscs + * + * @param[in] conn_handle The connection handle identifying the connection to perform this procedure on. + * @param[in] server_rx_mtu Server RX MTU size. + * - The minimum value is @ref BLE_GATT_ATT_MTU_DEFAULT. + * - The maximum value is @ref ble_gatt_conn_cfg_t::att_mtu in the connection configuration + * used for this connection. + * - The value must be equal to Client RX MTU size given in @ref sd_ble_gattc_exchange_mtu_request + * if an ATT_MTU exchange has already been performed in the other direction. + * + * @retval ::NRF_SUCCESS Successfully sent response to the client. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid Connection State or no ATT_MTU exchange request pending. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid Server RX MTU size supplied. + * @retval ::NRF_ERROR_TIMEOUT There has been a GATT procedure timeout. No new GATT procedure can be performed without reestablishing the connection. + */ +SVCALL(SD_BLE_GATTS_EXCHANGE_MTU_REPLY, uint32_t, sd_ble_gatts_exchange_mtu_reply(uint16_t conn_handle, uint16_t server_rx_mtu)); +/** @} */ + +#ifdef __cplusplus +} +#endif +#endif // BLE_GATTS_H__ + +/** + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_hci.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_hci.h new file mode 100644 index 0000000..f0dde9a --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_hci.h @@ -0,0 +1,135 @@ +/* + * Copyright (c) 2012 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup BLE_COMMON + @{ +*/ + + +#ifndef BLE_HCI_H__ +#define BLE_HCI_H__ +#ifdef __cplusplus +extern "C" { +#endif + +/** @defgroup BLE_HCI_STATUS_CODES Bluetooth status codes + * @{ */ + +#define BLE_HCI_STATUS_CODE_SUCCESS 0x00 /**< Success. */ +#define BLE_HCI_STATUS_CODE_UNKNOWN_BTLE_COMMAND 0x01 /**< Unknown BLE Command. */ +#define BLE_HCI_STATUS_CODE_UNKNOWN_CONNECTION_IDENTIFIER 0x02 /**< Unknown Connection Identifier. */ +/*0x03 Hardware Failure +0x04 Page Timeout +*/ +#define BLE_HCI_AUTHENTICATION_FAILURE 0x05 /**< Authentication Failure. */ +#define BLE_HCI_STATUS_CODE_PIN_OR_KEY_MISSING 0x06 /**< Pin or Key missing. */ +#define BLE_HCI_MEMORY_CAPACITY_EXCEEDED 0x07 /**< Memory Capacity Exceeded. */ +#define BLE_HCI_CONNECTION_TIMEOUT 0x08 /**< Connection Timeout. */ +/*0x09 Connection Limit Exceeded +0x0A Synchronous Connection Limit To A Device Exceeded +0x0B ACL Connection Already Exists*/ +#define BLE_HCI_STATUS_CODE_COMMAND_DISALLOWED 0x0C /**< Command Disallowed. */ +/*0x0D Connection Rejected due to Limited Resources +0x0E Connection Rejected Due To Security Reasons +0x0F Connection Rejected due to Unacceptable BD_ADDR +0x10 Connection Accept Timeout Exceeded +0x11 Unsupported Feature or Parameter Value*/ +#define BLE_HCI_STATUS_CODE_INVALID_BTLE_COMMAND_PARAMETERS 0x12 /**< Invalid BLE Command Parameters. */ +#define BLE_HCI_REMOTE_USER_TERMINATED_CONNECTION 0x13 /**< Remote User Terminated Connection. */ +#define BLE_HCI_REMOTE_DEV_TERMINATION_DUE_TO_LOW_RESOURCES 0x14 /**< Remote Device Terminated Connection due to low resources.*/ +#define BLE_HCI_REMOTE_DEV_TERMINATION_DUE_TO_POWER_OFF 0x15 /**< Remote Device Terminated Connection due to power off. */ +#define BLE_HCI_LOCAL_HOST_TERMINATED_CONNECTION 0x16 /**< Local Host Terminated Connection. */ +/* +0x17 Repeated Attempts +0x18 Pairing Not Allowed +0x19 Unknown LMP PDU +*/ +#define BLE_HCI_UNSUPPORTED_REMOTE_FEATURE 0x1A /**< Unsupported Remote Feature. */ +/* +0x1B SCO Offset Rejected +0x1C SCO Interval Rejected +0x1D SCO Air Mode Rejected*/ +#define BLE_HCI_STATUS_CODE_INVALID_LMP_PARAMETERS 0x1E /**< Invalid LMP Parameters. */ +#define BLE_HCI_STATUS_CODE_UNSPECIFIED_ERROR 0x1F /**< Unspecified Error. */ +/*0x20 Unsupported LMP Parameter Value +0x21 Role Change Not Allowed +*/ +#define BLE_HCI_STATUS_CODE_LMP_RESPONSE_TIMEOUT 0x22 /**< LMP Response Timeout. */ +#define BLE_HCI_STATUS_CODE_LMP_ERROR_TRANSACTION_COLLISION 0x23 /**< LMP Error Transaction Collision/LL Procedure Collision. */ +#define BLE_HCI_STATUS_CODE_LMP_PDU_NOT_ALLOWED 0x24 /**< LMP PDU Not Allowed. */ +/*0x25 Encryption Mode Not Acceptable +0x26 Link Key Can Not be Changed +0x27 Requested QoS Not Supported +*/ +#define BLE_HCI_INSTANT_PASSED 0x28 /**< Instant Passed. */ +#define BLE_HCI_PAIRING_WITH_UNIT_KEY_UNSUPPORTED 0x29 /**< Pairing with Unit Key Unsupported. */ +#define BLE_HCI_DIFFERENT_TRANSACTION_COLLISION 0x2A /**< Different Transaction Collision. */ +/* +0x2B Reserved +0x2C QoS Unacceptable Parameter +0x2D QoS Rejected +0x2E Channel Classification Not Supported +0x2F Insufficient Security +*/ +#define BLE_HCI_PARAMETER_OUT_OF_MANDATORY_RANGE 0x30 /**< Parameter Out Of Mandatory Range. */ +/* +0x31 Reserved +0x32 Role Switch Pending +0x33 Reserved +0x34 Reserved Slot Violation +0x35 Role Switch Failed +0x36 Extended Inquiry Response Too Large +0x37 Secure Simple Pairing Not Supported By Host. +0x38 Host Busy - Pairing +0x39 Connection Rejected due to No Suitable Channel Found*/ +#define BLE_HCI_CONTROLLER_BUSY 0x3A /**< Controller Busy. */ +#define BLE_HCI_CONN_INTERVAL_UNACCEPTABLE 0x3B /**< Connection Interval Unacceptable. */ +#define BLE_HCI_DIRECTED_ADVERTISER_TIMEOUT 0x3C /**< Directed Advertisement Timeout. */ +#define BLE_HCI_CONN_TERMINATED_DUE_TO_MIC_FAILURE 0x3D /**< Connection Terminated due to MIC Failure. */ +#define BLE_HCI_CONN_FAILED_TO_BE_ESTABLISHED 0x3E /**< Connection Failed to be Established. */ + +/** @} */ + + +#ifdef __cplusplus +} +#endif +#endif // BLE_HCI_H__ + +/** @} */ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_l2cap.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_l2cap.h new file mode 100644 index 0000000..eaeb4b7 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_l2cap.h @@ -0,0 +1,506 @@ +/* + * Copyright (c) 2011 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup BLE_L2CAP Logical Link Control and Adaptation Protocol (L2CAP) + @{ + @brief Definitions and prototypes for the L2CAP interface. + */ + +#ifndef BLE_L2CAP_H__ +#define BLE_L2CAP_H__ + +#include <stdint.h> +#include "nrf_svc.h" +#include "nrf_error.h" +#include "ble_ranges.h" +#include "ble_types.h" +#include "ble_err.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/**@addtogroup BLE_L2CAP_TERMINOLOGY Terminology + * @{ + * @details + * + * L2CAP SDU + * - A data unit that the application can send/receive to/from a peer. + * + * L2CAP PDU + * - A data unit that is exchanged between local and remote L2CAP entities. + * It consists of L2CAP protocol control information and payload fields. + * The payload field can contain an L2CAP SDU or a part of an L2CAP SDU. + * + * L2CAP MTU + * - The maximum length of an L2CAP SDU. + * + * L2CAP MPS + * - The maximum length of an L2CAP PDU payload field. + * + * Credits + * - A value indicating the number of L2CAP PDUs that the receiver of the credit can send to the peer. + * @} */ + +/**@addtogroup BLE_L2CAP_ENUMERATIONS Enumerations + * @{ */ + +/**@brief L2CAP API SVC numbers. */ +enum BLE_L2CAP_SVCS +{ + SD_BLE_L2CAP_CH_SETUP = BLE_L2CAP_SVC_BASE + 0, /**< Set up an L2CAP channel. */ + SD_BLE_L2CAP_CH_RELEASE = BLE_L2CAP_SVC_BASE + 1, /**< Release an L2CAP channel. */ + SD_BLE_L2CAP_CH_RX = BLE_L2CAP_SVC_BASE + 2, /**< Receive an SDU on an L2CAP channel. */ + SD_BLE_L2CAP_CH_TX = BLE_L2CAP_SVC_BASE + 3, /**< Transmit an SDU on an L2CAP channel. */ + SD_BLE_L2CAP_CH_FLOW_CONTROL = BLE_L2CAP_SVC_BASE + 4, /**< Advanced SDU reception flow control. */ +}; + +/**@brief L2CAP Event IDs. */ +enum BLE_L2CAP_EVTS +{ + BLE_L2CAP_EVT_CH_SETUP_REQUEST = BLE_L2CAP_EVT_BASE + 0, /**< L2CAP Channel Setup Request event. + \n See @ref ble_l2cap_evt_ch_setup_request_t. */ + BLE_L2CAP_EVT_CH_SETUP_REFUSED = BLE_L2CAP_EVT_BASE + 1, /**< L2CAP Channel Setup Refused event. + \n See @ref ble_l2cap_evt_ch_setup_refused_t. */ + BLE_L2CAP_EVT_CH_SETUP = BLE_L2CAP_EVT_BASE + 2, /**< L2CAP Channel Setup Completed event. + \n See @ref ble_l2cap_evt_ch_setup_t. */ + BLE_L2CAP_EVT_CH_RELEASED = BLE_L2CAP_EVT_BASE + 3, /**< L2CAP Channel Released event. + \n No additional event structure applies. */ + BLE_L2CAP_EVT_CH_SDU_BUF_RELEASED = BLE_L2CAP_EVT_BASE + 4, /**< L2CAP Channel SDU data buffer released event. + \n See @ref ble_l2cap_evt_ch_sdu_buf_released_t. */ + BLE_L2CAP_EVT_CH_CREDIT = BLE_L2CAP_EVT_BASE + 5, /**< L2CAP Channel Credit received. + \n See @ref ble_l2cap_evt_ch_credit_t. */ + BLE_L2CAP_EVT_CH_RX = BLE_L2CAP_EVT_BASE + 6, /**< L2CAP Channel SDU received. + \n See @ref ble_l2cap_evt_ch_rx_t. */ + BLE_L2CAP_EVT_CH_TX = BLE_L2CAP_EVT_BASE + 7, /**< L2CAP Channel SDU transmitted. + \n See @ref ble_l2cap_evt_ch_tx_t. */ +}; + +/** @} */ + +/**@addtogroup BLE_L2CAP_DEFINES Defines + * @{ */ + +/**@brief Maximum number of L2CAP channels per connection. */ +#define BLE_L2CAP_CH_COUNT_MAX (64) + +/**@brief Minimum L2CAP MTU, in bytes. */ +#define BLE_L2CAP_MTU_MIN (23) + +/**@brief Minimum L2CAP MPS, in bytes. */ +#define BLE_L2CAP_MPS_MIN (23) + +/**@brief Invalid CID. */ +#define BLE_L2CAP_CID_INVALID (0x0000) + +/**@brief Default number of credits for @ref sd_ble_l2cap_ch_flow_control. */ +#define BLE_L2CAP_CREDITS_DEFAULT (1) + +/**@defgroup BLE_L2CAP_CH_SETUP_REFUSED_SRCS L2CAP channel setup refused sources + * @{ */ +#define BLE_L2CAP_CH_SETUP_REFUSED_SRC_LOCAL (0x01) /**< Local. */ +#define BLE_L2CAP_CH_SETUP_REFUSED_SRC_REMOTE (0x02) /**< Remote. */ + /** @} */ + + /** @defgroup BLE_L2CAP_CH_STATUS_CODES L2CAP channel status codes + * @{ */ +#define BLE_L2CAP_CH_STATUS_CODE_SUCCESS (0x0000) /**< Success. */ +#define BLE_L2CAP_CH_STATUS_CODE_LE_PSM_NOT_SUPPORTED (0x0002) /**< LE_PSM not supported. */ +#define BLE_L2CAP_CH_STATUS_CODE_NO_RESOURCES (0x0004) /**< No resources available. */ +#define BLE_L2CAP_CH_STATUS_CODE_INSUFF_AUTHENTICATION (0x0005) /**< Insufficient authentication. */ +#define BLE_L2CAP_CH_STATUS_CODE_INSUFF_AUTHORIZATION (0x0006) /**< Insufficient authorization. */ +#define BLE_L2CAP_CH_STATUS_CODE_INSUFF_ENC_KEY_SIZE (0x0007) /**< Insufficient encryption key size. */ +#define BLE_L2CAP_CH_STATUS_CODE_INSUFF_ENC (0x0008) /**< Insufficient encryption. */ +#define BLE_L2CAP_CH_STATUS_CODE_INVALID_SCID (0x0009) /**< Invalid Source CID. */ +#define BLE_L2CAP_CH_STATUS_CODE_SCID_ALLOCATED (0x000A) /**< Source CID already allocated. */ +#define BLE_L2CAP_CH_STATUS_CODE_UNACCEPTABLE_PARAMS (0x000B) /**< Unacceptable parameters. */ +#define BLE_L2CAP_CH_STATUS_CODE_NOT_UNDERSTOOD (0x8000) /**< Command Reject received instead of LE Credit Based Connection Response. */ +#define BLE_L2CAP_CH_STATUS_CODE_TIMEOUT (0xC000) /**< Operation timed out. */ +/** @} */ + +/** @} */ + +/**@addtogroup BLE_L2CAP_STRUCTURES Structures + * @{ */ + +/** + * @brief BLE L2CAP connection configuration parameters, set with @ref sd_ble_cfg_set. + * + * @note These parameters are set per connection, so all L2CAP channels created on this connection + * will have the same parameters. + * + * @retval ::NRF_ERROR_INVALID_PARAM One or more of the following is true: + * - rx_mps is smaller than @ref BLE_L2CAP_MPS_MIN. + * - tx_mps is smaller than @ref BLE_L2CAP_MPS_MIN. + * - ch_count is greater than @ref BLE_L2CAP_CH_COUNT_MAX. + * @retval ::NRF_ERROR_NO_MEM rx_mps or tx_mps is set too high. + */ +typedef struct +{ + uint16_t rx_mps; /**< The maximum L2CAP PDU payload size, in bytes, that L2CAP shall + be able to receive on L2CAP channels on connections with this + configuration. The minimum value is @ref BLE_L2CAP_MPS_MIN. */ + uint16_t tx_mps; /**< The maximum L2CAP PDU payload size, in bytes, that L2CAP shall + be able to transmit on L2CAP channels on connections with this + configuration. The minimum value is @ref BLE_L2CAP_MPS_MIN. */ + uint8_t rx_queue_size; /**< Number of SDU data buffers that can be queued for reception per + L2CAP channel. The minimum value is one. */ + uint8_t tx_queue_size; /**< Number of SDU data buffers that can be queued for transmission + per L2CAP channel. The minimum value is one. */ + uint8_t ch_count; /**< Number of L2CAP channels the application can create per connection + with this configuration. The default value is zero, the maximum + value is @ref BLE_L2CAP_CH_COUNT_MAX. + @note if this parameter is set to zero, all other parameters in + @ref ble_l2cap_conn_cfg_t are ignored. */ +} ble_l2cap_conn_cfg_t; + +/**@brief L2CAP channel RX parameters. */ +typedef struct +{ + uint16_t rx_mtu; /**< The maximum L2CAP SDU size, in bytes, that L2CAP shall be able to + receive on this L2CAP channel. + - Must be equal to or greater than @ref BLE_L2CAP_MTU_MIN. */ + uint16_t rx_mps; /**< The maximum L2CAP PDU payload size, in bytes, that L2CAP shall be + able to receive on this L2CAP channel. + - Must be equal to or greater than @ref BLE_L2CAP_MPS_MIN. + - Must be equal to or less than @ref ble_l2cap_conn_cfg_t::rx_mps. */ + ble_data_t sdu_buf; /**< SDU data buffer for reception. + - If @ref ble_data_t::p_data is non-NULL, initial credits are + issued to the peer. + - If @ref ble_data_t::p_data is NULL, no initial credits are + issued to the peer. */ +} ble_l2cap_ch_rx_params_t; + +/**@brief L2CAP channel setup parameters. */ +typedef struct +{ + ble_l2cap_ch_rx_params_t rx_params; /**< L2CAP channel RX parameters. */ + uint16_t le_psm; /**< LE Protocol/Service Multiplexer. Used when requesting + setup of an L2CAP channel, ignored otherwise. */ + uint16_t status; /**< Status code, see @ref BLE_L2CAP_CH_STATUS_CODES. + Used when replying to a setup request of an L2CAP + channel, ignored otherwise. */ +} ble_l2cap_ch_setup_params_t; + +/**@brief L2CAP channel TX parameters. */ +typedef struct +{ + uint16_t tx_mtu; /**< The maximum L2CAP SDU size, in bytes, that L2CAP is able to + transmit on this L2CAP channel. */ + uint16_t peer_mps; /**< The maximum L2CAP PDU payload size, in bytes, that the peer is + able to receive on this L2CAP channel. */ + uint16_t tx_mps; /**< The maximum L2CAP PDU payload size, in bytes, that L2CAP is able + to transmit on this L2CAP channel. This is effective tx_mps, + selected by the SoftDevice as + MIN( @ref ble_l2cap_ch_tx_params_t::peer_mps, @ref ble_l2cap_conn_cfg_t::tx_mps ) */ + uint16_t credits; /**< Initial credits given by the peer. */ +} ble_l2cap_ch_tx_params_t; + +/**@brief L2CAP Channel Setup Request event. */ +typedef struct +{ + ble_l2cap_ch_tx_params_t tx_params; /**< L2CAP channel TX parameters. */ + uint16_t le_psm; /**< LE Protocol/Service Multiplexer. */ +} ble_l2cap_evt_ch_setup_request_t; + +/**@brief L2CAP Channel Setup Refused event. */ +typedef struct +{ + uint8_t source; /**< Source, see @ref BLE_L2CAP_CH_SETUP_REFUSED_SRCS */ + uint16_t status; /**< Status code, see @ref BLE_L2CAP_CH_STATUS_CODES */ +} ble_l2cap_evt_ch_setup_refused_t; + +/**@brief L2CAP Channel Setup Completed event. */ +typedef struct +{ + ble_l2cap_ch_tx_params_t tx_params; /**< L2CAP channel TX parameters. */ +} ble_l2cap_evt_ch_setup_t; + +/**@brief L2CAP Channel SDU Data Duffer Released event. */ +typedef struct +{ + ble_data_t sdu_buf; /**< Returned reception or transmission SDU data buffer. The SoftDevice + returns SDU data buffers supplied by the application, which have + not yet been returned previously via a @ref BLE_L2CAP_EVT_CH_RX or + @ref BLE_L2CAP_EVT_CH_TX event. */ +} ble_l2cap_evt_ch_sdu_buf_released_t; + +/**@brief L2CAP Channel Credit received event. */ +typedef struct +{ + uint16_t credits; /**< Additional credits given by the peer. */ +} ble_l2cap_evt_ch_credit_t; + +/**@brief L2CAP Channel received SDU event. */ +typedef struct +{ + uint16_t sdu_len; /**< Total SDU length, in bytes. */ + ble_data_t sdu_buf; /**< SDU data buffer. + @note If there is not enough space in the buffer + (sdu_buf.len < sdu_len) then the rest of the SDU will be + silently discarded by the SoftDevice. */ +} ble_l2cap_evt_ch_rx_t; + +/**@brief L2CAP Channel transmitted SDU event. */ +typedef struct +{ + ble_data_t sdu_buf; /**< SDU data buffer. */ +} ble_l2cap_evt_ch_tx_t; + +/**@brief L2CAP event structure. */ +typedef struct +{ + uint16_t conn_handle; /**< Connection Handle on which the event occured. */ + uint16_t local_cid; /**< Local Channel ID of the L2CAP channel, or + @ref BLE_L2CAP_CID_INVALID if not present. */ + union + { + ble_l2cap_evt_ch_setup_request_t ch_setup_request; /**< L2CAP Channel Setup Request Event Parameters. */ + ble_l2cap_evt_ch_setup_refused_t ch_setup_refused; /**< L2CAP Channel Setup Refused Event Parameters. */ + ble_l2cap_evt_ch_setup_t ch_setup; /**< L2CAP Channel Setup Completed Event Parameters. */ + ble_l2cap_evt_ch_sdu_buf_released_t ch_sdu_buf_released;/**< L2CAP Channel SDU Data Buffer Released Event Parameters. */ + ble_l2cap_evt_ch_credit_t credit; /**< L2CAP Channel Credit Received Event Parameters. */ + ble_l2cap_evt_ch_rx_t rx; /**< L2CAP Channel SDU Received Event Parameters. */ + ble_l2cap_evt_ch_tx_t tx; /**< L2CAP Channel SDU Transmitted Event Parameters. */ + } params; /**< Event Parameters. */ +} ble_l2cap_evt_t; + +/** @} */ + +/**@addtogroup BLE_L2CAP_FUNCTIONS Functions + * @{ */ + +/**@brief Set up an L2CAP channel. + * + * @details This function is used to: + * - Request setup of an L2CAP channel: sends an LE Credit Based Connection Request packet to a peer. + * - Reply to a setup request of an L2CAP channel (if called in response to a + * @ref BLE_L2CAP_EVT_CH_SETUP_REQUEST event): sends an LE Credit Based Connection + * Response packet to a peer. + * + * @note A call to this function will require the application to keep the SDU data buffer alive + * until the SDU data buffer is returned in @ref BLE_L2CAP_EVT_CH_RX or + * @ref BLE_L2CAP_EVT_CH_SDU_BUF_RELEASED event. + * + * @events + * @event{@ref BLE_L2CAP_EVT_CH_SETUP, Setup successful.} + * @event{@ref BLE_L2CAP_EVT_CH_SETUP_REFUSED, Setup failed.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_L2CAP_CH_SETUP_MSC} + * @endmscs + * + * @param[in] conn_handle Connection Handle. + * @param[in,out] p_local_cid Pointer to a uint16_t containing Local Channel ID of the L2CAP channel: + * - As input: @ref BLE_L2CAP_CID_INVALID when requesting setup of an L2CAP + * channel or local_cid provided in the @ref BLE_L2CAP_EVT_CH_SETUP_REQUEST + * event when replying to a setup request of an L2CAP channel. + * - As output: local_cid for this channel. + * @param[in] p_params L2CAP channel parameters. + * + * @retval ::NRF_SUCCESS Successfully queued request or response for transmission. + * @retval ::NRF_ERROR_BUSY The stack is busy, process pending events and retry. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid parameter(s) supplied. + * @retval ::NRF_ERROR_INVALID_LENGTH Supplied higher rx_mps than has been configured on this link. + * @retval ::NRF_ERROR_INVALID_STATE Invalid State to perform operation (L2CAP channel already set up). + * @retval ::NRF_ERROR_NOT_FOUND CID not found. + * @retval ::NRF_ERROR_RESOURCES The limit has been reached for available L2CAP channels, + * see @ref ble_l2cap_conn_cfg_t::ch_count. + */ +SVCALL(SD_BLE_L2CAP_CH_SETUP, uint32_t, sd_ble_l2cap_ch_setup(uint16_t conn_handle, uint16_t *p_local_cid, ble_l2cap_ch_setup_params_t const *p_params)); + +/**@brief Release an L2CAP channel. + * + * @details This sends a Disconnection Request packet to a peer. + * + * @events + * @event{@ref BLE_L2CAP_EVT_CH_RELEASED, Release complete.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_L2CAP_CH_RELEASE_MSC} + * @endmscs + * + * @param[in] conn_handle Connection Handle. + * @param[in] local_cid Local Channel ID of the L2CAP channel. + * + * @retval ::NRF_SUCCESS Successfully queued request for transmission. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid State to perform operation (Setup or release is + * in progress for the L2CAP channel). + * @retval ::NRF_ERROR_NOT_FOUND CID not found. + */ +SVCALL(SD_BLE_L2CAP_CH_RELEASE, uint32_t, sd_ble_l2cap_ch_release(uint16_t conn_handle, uint16_t local_cid)); + +/**@brief Receive an SDU on an L2CAP channel. + * + * @details This may issue additional credits to the peer using an LE Flow Control Credit packet. + * + * @note A call to this function will require the application to keep the memory pointed by + * @ref ble_data_t::p_data alive until the SDU data buffer is returned in @ref BLE_L2CAP_EVT_CH_RX + * or @ref BLE_L2CAP_EVT_CH_SDU_BUF_RELEASED event. + * + * @note The SoftDevice can queue up to @ref ble_l2cap_conn_cfg_t::rx_queue_size SDU data buffers + * for reception per L2CAP channel. + * + * @events + * @event{@ref BLE_L2CAP_EVT_CH_RX, The SDU is received.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_L2CAP_CH_RX_MSC} + * @endmscs + * + * @param[in] conn_handle Connection Handle. + * @param[in] local_cid Local Channel ID of the L2CAP channel. + * @param[in] p_sdu_buf Pointer to the SDU data buffer. + * + * @retval ::NRF_SUCCESS Buffer accepted. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid State to perform operation (Setup or release is + * in progress for an L2CAP channel). + * @retval ::NRF_ERROR_NOT_FOUND CID not found. + * @retval ::NRF_ERROR_RESOURCES Too many SDU data buffers supplied. Wait for a + * @ref BLE_L2CAP_EVT_CH_RX event and retry. + */ +SVCALL(SD_BLE_L2CAP_CH_RX, uint32_t, sd_ble_l2cap_ch_rx(uint16_t conn_handle, uint16_t local_cid, ble_data_t const *p_sdu_buf)); + +/**@brief Transmit an SDU on an L2CAP channel. + * + * @note A call to this function will require the application to keep the memory pointed by + * @ref ble_data_t::p_data alive until the SDU data buffer is returned in @ref BLE_L2CAP_EVT_CH_TX + * or @ref BLE_L2CAP_EVT_CH_SDU_BUF_RELEASED event. + * + * @note The SoftDevice can queue up to @ref ble_l2cap_conn_cfg_t::tx_queue_size SDUs for + * transmission per L2CAP channel. + * + * @note The application can keep track of the available credits for transmission by following + * the procedure below: + * - Store initial credits given by the peer in a variable. + * (Initial credits are provided in a @ref BLE_L2CAP_EVT_CH_SETUP event.) + * - Decrement the variable, which stores the currently available credits, by + * ceiling((@ref ble_data_t::len + 2) / tx_mps) when a call to this function returns + * @ref NRF_SUCCESS. (tx_mps is provided in a @ref BLE_L2CAP_EVT_CH_SETUP event.) + * - Increment the variable, which stores the currently available credits, by additional + * credits given by the peer in a @ref BLE_L2CAP_EVT_CH_CREDIT event. + * + * @events + * @event{@ref BLE_L2CAP_EVT_CH_TX, The SDU is transmitted.} + * @endevents + * + * @mscs + * @mmsc{@ref BLE_L2CAP_CH_TX_MSC} + * @endmscs + * + * @param[in] conn_handle Connection Handle. + * @param[in] local_cid Local Channel ID of the L2CAP channel. + * @param[in] p_sdu_buf Pointer to the SDU data buffer. + * + * @retval ::NRF_SUCCESS Successfully queued L2CAP SDU for transmission. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid State to perform operation (Setup or release is + * in progress for the L2CAP channel). + * @retval ::NRF_ERROR_NOT_FOUND CID not found. + * @retval ::NRF_ERROR_DATA_SIZE Invalid SDU length supplied, must not be more than + * @ref ble_l2cap_ch_tx_params_t::tx_mtu provided in + * @ref BLE_L2CAP_EVT_CH_SETUP event. + * @retval ::NRF_ERROR_RESOURCES Too many SDUs queued for transmission. Wait for a + * @ref BLE_L2CAP_EVT_CH_TX event and retry. + */ +SVCALL(SD_BLE_L2CAP_CH_TX, uint32_t, sd_ble_l2cap_ch_tx(uint16_t conn_handle, uint16_t local_cid, ble_data_t const *p_sdu_buf)); + +/**@brief Advanced SDU reception flow control. + * + * @details Adjust the way the SoftDevice issues credits to the peer. + * This may issue additional credits to the peer using an LE Flow Control Credit packet. + * + * @mscs + * @mmsc{@ref BLE_L2CAP_CH_FLOW_CONTROL_MSC} + * @endmscs + * + * @param[in] conn_handle Connection Handle. + * @param[in] local_cid Local Channel ID of the L2CAP channel or @ref BLE_L2CAP_CID_INVALID to set + * the value that will be used for newly created channels. + * @param[in] credits Number of credits that the SoftDevice will make sure the peer has every + * time it starts using a new reception buffer. + * - @ref BLE_L2CAP_CREDITS_DEFAULT is the default value the SoftDevice will + * use if this function is not called. + * - If set to zero, the SoftDevice will stop issuing credits for new reception + * buffers the application provides or has provided. SDU reception that is + * currently ongoing will be allowed to complete. + * @param[out] p_credits NULL or pointer to a uint16_t. If a valid pointer is provided, it will be + * written by the SoftDevice with the number of credits that is or will be + * available to the peer. If the value written by the SoftDevice is 0 when + * credits parameter was set to 0, the peer will not be able to send more + * data until more credits are provided by calling this function again with + * credits > 0. This parameter is ignored when local_cid is set to + * @ref BLE_L2CAP_CID_INVALID. + * + * @note Application should take care when setting number of credits higher than default value. In + * this case the application must make sure that the SoftDevice always has reception buffers + * available (see @ref sd_ble_l2cap_ch_rx) for that channel. If the SoftDevice does not have + * such buffers available, packets may be NACKed on the Link Layer and all Bluetooth traffic + * on the connection handle may be stalled until the SoftDevice again has an available + * reception buffer. This applies even if the application has used this call to set the + * credits back to default, or zero. + * + * @retval ::NRF_SUCCESS Flow control parameters accepted. + * @retval ::NRF_ERROR_INVALID_ADDR Invalid pointer supplied. + * @retval ::BLE_ERROR_INVALID_CONN_HANDLE Invalid Connection Handle. + * @retval ::NRF_ERROR_INVALID_STATE Invalid State to perform operation (Setup or release is + * in progress for an L2CAP channel). + * @retval ::NRF_ERROR_NOT_FOUND CID not found. + */ +SVCALL(SD_BLE_L2CAP_CH_FLOW_CONTROL, uint32_t, sd_ble_l2cap_ch_flow_control(uint16_t conn_handle, uint16_t local_cid, uint16_t credits, uint16_t *p_credits)); + +/** @} */ + +#ifdef __cplusplus +} +#endif +#endif // BLE_L2CAP_H__ + +/** + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_ranges.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_ranges.h new file mode 100644 index 0000000..0935bca --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_ranges.h @@ -0,0 +1,156 @@ +/* + * Copyright (c) 2012 - 2018, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup BLE_COMMON + @{ + @defgroup ble_ranges Module specific SVC, event and option number subranges + @{ + + @brief Definition of SVC, event and option number subranges for each API module. + + @note + SVCs, event and option numbers are split into subranges for each API module. + Each module receives its entire allocated range of SVC calls, whether implemented or not, + but return BLE_ERROR_NOT_SUPPORTED for unimplemented or undefined calls in its range. + + Note that the symbols BLE_<module>_SVC_LAST is the end of the allocated SVC range, + rather than the last SVC function call actually defined and implemented. + + Specific SVC, event and option values are defined in each module's ble_<module>.h file, + which defines names of each individual SVC code based on the range start value. +*/ + +#ifndef BLE_RANGES_H__ +#define BLE_RANGES_H__ + +#ifdef __cplusplus +extern "C" { +#endif + +#define BLE_SVC_BASE 0x60 /**< Common BLE SVC base. */ +#define BLE_SVC_LAST 0x6B /**< Common BLE SVC last. */ + +#define BLE_GAP_SVC_BASE 0x6C /**< GAP BLE SVC base. */ +#define BLE_GAP_SVC_LAST 0x9A /**< GAP BLE SVC last. */ + +#define BLE_GATTC_SVC_BASE 0x9B /**< GATTC BLE SVC base. */ +#define BLE_GATTC_SVC_LAST 0xA7 /**< GATTC BLE SVC last. */ + +#define BLE_GATTS_SVC_BASE 0xA8 /**< GATTS BLE SVC base. */ +#define BLE_GATTS_SVC_LAST 0xB7 /**< GATTS BLE SVC last. */ + +#define BLE_L2CAP_SVC_BASE 0xB8 /**< L2CAP BLE SVC base. */ +#define BLE_L2CAP_SVC_LAST 0xBF /**< L2CAP BLE SVC last. */ + + +#define BLE_EVT_INVALID 0x00 /**< Invalid BLE Event. */ + +#define BLE_EVT_BASE 0x01 /**< Common BLE Event base. */ +#define BLE_EVT_LAST 0x0F /**< Common BLE Event last. */ + +#define BLE_GAP_EVT_BASE 0x10 /**< GAP BLE Event base. */ +#define BLE_GAP_EVT_LAST 0x2F /**< GAP BLE Event last. */ + +#define BLE_GATTC_EVT_BASE 0x30 /**< GATTC BLE Event base. */ +#define BLE_GATTC_EVT_LAST 0x4F /**< GATTC BLE Event last. */ + +#define BLE_GATTS_EVT_BASE 0x50 /**< GATTS BLE Event base. */ +#define BLE_GATTS_EVT_LAST 0x6F /**< GATTS BLE Event last. */ + +#define BLE_L2CAP_EVT_BASE 0x70 /**< L2CAP BLE Event base. */ +#define BLE_L2CAP_EVT_LAST 0x8F /**< L2CAP BLE Event last. */ + + +#define BLE_OPT_INVALID 0x00 /**< Invalid BLE Option. */ + +#define BLE_OPT_BASE 0x01 /**< Common BLE Option base. */ +#define BLE_OPT_LAST 0x1F /**< Common BLE Option last. */ + +#define BLE_GAP_OPT_BASE 0x20 /**< GAP BLE Option base. */ +#define BLE_GAP_OPT_LAST 0x3F /**< GAP BLE Option last. */ + +#define BLE_GATT_OPT_BASE 0x40 /**< GATT BLE Option base. */ +#define BLE_GATT_OPT_LAST 0x5F /**< GATT BLE Option last. */ + +#define BLE_GATTC_OPT_BASE 0x60 /**< GATTC BLE Option base. */ +#define BLE_GATTC_OPT_LAST 0x7F /**< GATTC BLE Option last. */ + +#define BLE_GATTS_OPT_BASE 0x80 /**< GATTS BLE Option base. */ +#define BLE_GATTS_OPT_LAST 0x9F /**< GATTS BLE Option last. */ + +#define BLE_L2CAP_OPT_BASE 0xA0 /**< L2CAP BLE Option base. */ +#define BLE_L2CAP_OPT_LAST 0xBF /**< L2CAP BLE Option last. */ + + +#define BLE_CFG_INVALID 0x00 /**< Invalid BLE configuration. */ + +#define BLE_CFG_BASE 0x01 /**< Common BLE configuration base. */ +#define BLE_CFG_LAST 0x1F /**< Common BLE configuration last. */ + +#define BLE_CONN_CFG_BASE 0x20 /**< BLE connection configuration base. */ +#define BLE_CONN_CFG_LAST 0x3F /**< BLE connection configuration last. */ + +#define BLE_GAP_CFG_BASE 0x40 /**< GAP BLE configuration base. */ +#define BLE_GAP_CFG_LAST 0x5F /**< GAP BLE configuration last. */ + +#define BLE_GATT_CFG_BASE 0x60 /**< GATT BLE configuration base. */ +#define BLE_GATT_CFG_LAST 0x7F /**< GATT BLE configuration last. */ + +#define BLE_GATTC_CFG_BASE 0x80 /**< GATTC BLE configuration base. */ +#define BLE_GATTC_CFG_LAST 0x9F /**< GATTC BLE configuration last. */ + +#define BLE_GATTS_CFG_BASE 0xA0 /**< GATTS BLE configuration base. */ +#define BLE_GATTS_CFG_LAST 0xBF /**< GATTS BLE configuration last. */ + +#define BLE_L2CAP_CFG_BASE 0xC0 /**< L2CAP BLE configuration base. */ +#define BLE_L2CAP_CFG_LAST 0xDF /**< L2CAP BLE configuration last. */ + + + + + +#ifdef __cplusplus +} +#endif +#endif /* BLE_RANGES_H__ */ + +/** + @} + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_types.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_types.h new file mode 100644 index 0000000..88c9318 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/ble_types.h @@ -0,0 +1,215 @@ +/* + * Copyright (c) 2012 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup BLE_COMMON + @{ + @defgroup ble_types Common types and macro definitions + @{ + + @brief Common types and macro definitions for the BLE SoftDevice. + */ + +#ifndef BLE_TYPES_H__ +#define BLE_TYPES_H__ + +#include <stdint.h> + +#ifdef __cplusplus +extern "C" { +#endif + +/** @addtogroup BLE_TYPES_DEFINES Defines + * @{ */ + +/** @defgroup BLE_CONN_HANDLES BLE Connection Handles + * @{ */ +#define BLE_CONN_HANDLE_INVALID 0xFFFF /**< Invalid Connection Handle. */ +#define BLE_CONN_HANDLE_ALL 0xFFFE /**< Applies to all Connection Handles. */ +/** @} */ + + +/** @defgroup BLE_UUID_VALUES Assigned Values for BLE UUIDs + * @{ */ +/* Generic UUIDs, applicable to all services */ +#define BLE_UUID_UNKNOWN 0x0000 /**< Reserved UUID. */ +#define BLE_UUID_SERVICE_PRIMARY 0x2800 /**< Primary Service. */ +#define BLE_UUID_SERVICE_SECONDARY 0x2801 /**< Secondary Service. */ +#define BLE_UUID_SERVICE_INCLUDE 0x2802 /**< Include. */ +#define BLE_UUID_CHARACTERISTIC 0x2803 /**< Characteristic. */ +#define BLE_UUID_DESCRIPTOR_CHAR_EXT_PROP 0x2900 /**< Characteristic Extended Properties Descriptor. */ +#define BLE_UUID_DESCRIPTOR_CHAR_USER_DESC 0x2901 /**< Characteristic User Description Descriptor. */ +#define BLE_UUID_DESCRIPTOR_CLIENT_CHAR_CONFIG 0x2902 /**< Client Characteristic Configuration Descriptor. */ +#define BLE_UUID_DESCRIPTOR_SERVER_CHAR_CONFIG 0x2903 /**< Server Characteristic Configuration Descriptor. */ +#define BLE_UUID_DESCRIPTOR_CHAR_PRESENTATION_FORMAT 0x2904 /**< Characteristic Presentation Format Descriptor. */ +#define BLE_UUID_DESCRIPTOR_CHAR_AGGREGATE_FORMAT 0x2905 /**< Characteristic Aggregate Format Descriptor. */ +/* GATT specific UUIDs */ +#define BLE_UUID_GATT 0x1801 /**< Generic Attribute Profile. */ +#define BLE_UUID_GATT_CHARACTERISTIC_SERVICE_CHANGED 0x2A05 /**< Service Changed Characteristic. */ +/* GAP specific UUIDs */ +#define BLE_UUID_GAP 0x1800 /**< Generic Access Profile. */ +#define BLE_UUID_GAP_CHARACTERISTIC_DEVICE_NAME 0x2A00 /**< Device Name Characteristic. */ +#define BLE_UUID_GAP_CHARACTERISTIC_APPEARANCE 0x2A01 /**< Appearance Characteristic. */ +#define BLE_UUID_GAP_CHARACTERISTIC_RECONN_ADDR 0x2A03 /**< Reconnection Address Characteristic. */ +#define BLE_UUID_GAP_CHARACTERISTIC_PPCP 0x2A04 /**< Peripheral Preferred Connection Parameters Characteristic. */ +#define BLE_UUID_GAP_CHARACTERISTIC_CAR 0x2AA6 /**< Central Address Resolution Characteristic. */ +#define BLE_UUID_GAP_CHARACTERISTIC_RPA_ONLY 0x2AC9 /**< Resolvable Private Address Only Characteristic. */ +/** @} */ + + +/** @defgroup BLE_UUID_TYPES Types of UUID + * @{ */ +#define BLE_UUID_TYPE_UNKNOWN 0x00 /**< Invalid UUID type. */ +#define BLE_UUID_TYPE_BLE 0x01 /**< Bluetooth SIG UUID (16-bit). */ +#define BLE_UUID_TYPE_VENDOR_BEGIN 0x02 /**< Vendor UUID types start at this index (128-bit). */ +/** @} */ + + +/** @defgroup BLE_APPEARANCES Bluetooth Appearance values + * @note Retrieved from http://developer.bluetooth.org/gatt/characteristics/Pages/CharacteristicViewer.aspx?u=org.bluetooth.characteristic.gap.appearance.xml + * @{ */ +#define BLE_APPEARANCE_UNKNOWN 0 /**< Unknown. */ +#define BLE_APPEARANCE_GENERIC_PHONE 64 /**< Generic Phone. */ +#define BLE_APPEARANCE_GENERIC_COMPUTER 128 /**< Generic Computer. */ +#define BLE_APPEARANCE_GENERIC_WATCH 192 /**< Generic Watch. */ +#define BLE_APPEARANCE_WATCH_SPORTS_WATCH 193 /**< Watch: Sports Watch. */ +#define BLE_APPEARANCE_GENERIC_CLOCK 256 /**< Generic Clock. */ +#define BLE_APPEARANCE_GENERIC_DISPLAY 320 /**< Generic Display. */ +#define BLE_APPEARANCE_GENERIC_REMOTE_CONTROL 384 /**< Generic Remote Control. */ +#define BLE_APPEARANCE_GENERIC_EYE_GLASSES 448 /**< Generic Eye-glasses. */ +#define BLE_APPEARANCE_GENERIC_TAG 512 /**< Generic Tag. */ +#define BLE_APPEARANCE_GENERIC_KEYRING 576 /**< Generic Keyring. */ +#define BLE_APPEARANCE_GENERIC_MEDIA_PLAYER 640 /**< Generic Media Player. */ +#define BLE_APPEARANCE_GENERIC_BARCODE_SCANNER 704 /**< Generic Barcode Scanner. */ +#define BLE_APPEARANCE_GENERIC_THERMOMETER 768 /**< Generic Thermometer. */ +#define BLE_APPEARANCE_THERMOMETER_EAR 769 /**< Thermometer: Ear. */ +#define BLE_APPEARANCE_GENERIC_HEART_RATE_SENSOR 832 /**< Generic Heart rate Sensor. */ +#define BLE_APPEARANCE_HEART_RATE_SENSOR_HEART_RATE_BELT 833 /**< Heart Rate Sensor: Heart Rate Belt. */ +#define BLE_APPEARANCE_GENERIC_BLOOD_PRESSURE 896 /**< Generic Blood Pressure. */ +#define BLE_APPEARANCE_BLOOD_PRESSURE_ARM 897 /**< Blood Pressure: Arm. */ +#define BLE_APPEARANCE_BLOOD_PRESSURE_WRIST 898 /**< Blood Pressure: Wrist. */ +#define BLE_APPEARANCE_GENERIC_HID 960 /**< Human Interface Device (HID). */ +#define BLE_APPEARANCE_HID_KEYBOARD 961 /**< Keyboard (HID Subtype). */ +#define BLE_APPEARANCE_HID_MOUSE 962 /**< Mouse (HID Subtype). */ +#define BLE_APPEARANCE_HID_JOYSTICK 963 /**< Joystick (HID Subtype). */ +#define BLE_APPEARANCE_HID_GAMEPAD 964 /**< Gamepad (HID Subtype). */ +#define BLE_APPEARANCE_HID_DIGITIZERSUBTYPE 965 /**< Digitizer Tablet (HID Subtype). */ +#define BLE_APPEARANCE_HID_CARD_READER 966 /**< Card Reader (HID Subtype). */ +#define BLE_APPEARANCE_HID_DIGITAL_PEN 967 /**< Digital Pen (HID Subtype). */ +#define BLE_APPEARANCE_HID_BARCODE 968 /**< Barcode Scanner (HID Subtype). */ +#define BLE_APPEARANCE_GENERIC_GLUCOSE_METER 1024 /**< Generic Glucose Meter. */ +#define BLE_APPEARANCE_GENERIC_RUNNING_WALKING_SENSOR 1088 /**< Generic Running Walking Sensor. */ +#define BLE_APPEARANCE_RUNNING_WALKING_SENSOR_IN_SHOE 1089 /**< Running Walking Sensor: In-Shoe. */ +#define BLE_APPEARANCE_RUNNING_WALKING_SENSOR_ON_SHOE 1090 /**< Running Walking Sensor: On-Shoe. */ +#define BLE_APPEARANCE_RUNNING_WALKING_SENSOR_ON_HIP 1091 /**< Running Walking Sensor: On-Hip. */ +#define BLE_APPEARANCE_GENERIC_CYCLING 1152 /**< Generic Cycling. */ +#define BLE_APPEARANCE_CYCLING_CYCLING_COMPUTER 1153 /**< Cycling: Cycling Computer. */ +#define BLE_APPEARANCE_CYCLING_SPEED_SENSOR 1154 /**< Cycling: Speed Sensor. */ +#define BLE_APPEARANCE_CYCLING_CADENCE_SENSOR 1155 /**< Cycling: Cadence Sensor. */ +#define BLE_APPEARANCE_CYCLING_POWER_SENSOR 1156 /**< Cycling: Power Sensor. */ +#define BLE_APPEARANCE_CYCLING_SPEED_CADENCE_SENSOR 1157 /**< Cycling: Speed and Cadence Sensor. */ +#define BLE_APPEARANCE_GENERIC_PULSE_OXIMETER 3136 /**< Generic Pulse Oximeter. */ +#define BLE_APPEARANCE_PULSE_OXIMETER_FINGERTIP 3137 /**< Fingertip (Pulse Oximeter subtype). */ +#define BLE_APPEARANCE_PULSE_OXIMETER_WRIST_WORN 3138 /**< Wrist Worn(Pulse Oximeter subtype). */ +#define BLE_APPEARANCE_GENERIC_WEIGHT_SCALE 3200 /**< Generic Weight Scale. */ +#define BLE_APPEARANCE_GENERIC_OUTDOOR_SPORTS_ACT 5184 /**< Generic Outdoor Sports Activity. */ +#define BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_DISP 5185 /**< Location Display Device (Outdoor Sports Activity subtype). */ +#define BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_AND_NAV_DISP 5186 /**< Location and Navigation Display Device (Outdoor Sports Activity subtype). */ +#define BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_POD 5187 /**< Location Pod (Outdoor Sports Activity subtype). */ +#define BLE_APPEARANCE_OUTDOOR_SPORTS_ACT_LOC_AND_NAV_POD 5188 /**< Location and Navigation Pod (Outdoor Sports Activity subtype). */ +/** @} */ + +/** @brief Set .type and .uuid fields of ble_uuid_struct to specified UUID value. */ +#define BLE_UUID_BLE_ASSIGN(instance, value) do {\ + instance.type = BLE_UUID_TYPE_BLE; \ + instance.uuid = value;} while(0) + +/** @brief Copy type and uuid members from src to dst ble_uuid_t pointer. Both pointers must be valid/non-null. */ +#define BLE_UUID_COPY_PTR(dst, src) do {\ + (dst)->type = (src)->type; \ + (dst)->uuid = (src)->uuid;} while(0) + +/** @brief Copy type and uuid members from src to dst ble_uuid_t struct. */ +#define BLE_UUID_COPY_INST(dst, src) do {\ + (dst).type = (src).type; \ + (dst).uuid = (src).uuid;} while(0) + +/** @brief Compare for equality both type and uuid members of two (valid, non-null) ble_uuid_t pointers. */ +#define BLE_UUID_EQ(p_uuid1, p_uuid2) \ + (((p_uuid1)->type == (p_uuid2)->type) && ((p_uuid1)->uuid == (p_uuid2)->uuid)) + +/** @brief Compare for difference both type and uuid members of two (valid, non-null) ble_uuid_t pointers. */ +#define BLE_UUID_NEQ(p_uuid1, p_uuid2) \ + (((p_uuid1)->type != (p_uuid2)->type) || ((p_uuid1)->uuid != (p_uuid2)->uuid)) + +/** @} */ + +/** @addtogroup BLE_TYPES_STRUCTURES Structures + * @{ */ + +/** @brief 128 bit UUID values. */ +typedef struct +{ + uint8_t uuid128[16]; /**< Little-Endian UUID bytes. */ +} ble_uuid128_t; + +/** @brief Bluetooth Low Energy UUID type, encapsulates both 16-bit and 128-bit UUIDs. */ +typedef struct +{ + uint16_t uuid; /**< 16-bit UUID value or octets 12-13 of 128-bit UUID. */ + uint8_t type; /**< UUID type, see @ref BLE_UUID_TYPES. If type is @ref BLE_UUID_TYPE_UNKNOWN, the value of uuid is undefined. */ +} ble_uuid_t; + +/**@brief Data structure. */ +typedef struct +{ + uint8_t *p_data; /**< Pointer to the data buffer provided to/from the application. */ + uint16_t len; /**< Length of the data buffer, in bytes. */ +} ble_data_t; + +/** @} */ +#ifdef __cplusplus +} +#endif + +#endif /* BLE_TYPES_H__ */ + +/** + @} + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf52/nrf_mbr.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf52/nrf_mbr.h new file mode 100644 index 0000000..cc5971c --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf52/nrf_mbr.h @@ -0,0 +1,241 @@ +/* + * Copyright (c) 2014 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @defgroup nrf_mbr_api Master Boot Record API + @{ + + @brief APIs for updating SoftDevice and BootLoader + +*/ + +#ifndef NRF_MBR_H__ +#define NRF_MBR_H__ + +#include "nrf_svc.h" +#include <stdint.h> + +#ifdef __cplusplus +extern "C" { +#endif + +/** @addtogroup NRF_MBR_DEFINES Defines + * @{ */ + +/**@brief MBR SVC Base number. */ +#define MBR_SVC_BASE (0x18) + +/**@brief Page size in words. */ +#define MBR_PAGE_SIZE_IN_WORDS (1024) + +/** @brief The size that must be reserved for the MBR when a SoftDevice is written to flash. +This is the offset where the first byte of the SoftDevice hex file is written.*/ +#define MBR_SIZE (0x1000) + +/** @} */ + +/** @addtogroup NRF_MBR_ENUMS Enumerations + * @{ */ + +/**@brief nRF Master Boot Record API SVC numbers. */ +enum NRF_MBR_SVCS +{ + SD_MBR_COMMAND = MBR_SVC_BASE, /**< ::sd_mbr_command */ +}; + +/**@brief Possible values for ::sd_mbr_command_t.command */ +enum NRF_MBR_COMMANDS +{ + SD_MBR_COMMAND_COPY_BL, /**< Copy a new BootLoader. @see ::sd_mbr_command_copy_bl_t*/ + SD_MBR_COMMAND_COPY_SD, /**< Copy a new SoftDevice. @see ::sd_mbr_command_copy_sd_t*/ + SD_MBR_COMMAND_INIT_SD, /**< Initialize forwarding interrupts to SD, and run reset function in SD. Does not require any parameters in ::sd_mbr_command_t params.*/ + SD_MBR_COMMAND_COMPARE, /**< This command works like memcmp. @see ::sd_mbr_command_compare_t*/ + SD_MBR_COMMAND_VECTOR_TABLE_BASE_SET, /**< Change the address the MBR starts after a reset. @see ::sd_mbr_command_vector_table_base_set_t*/ + SD_MBR_COMMAND_RESERVED, + SD_MBR_COMMAND_IRQ_FORWARD_ADDRESS_SET, /**< Start forwarding all interrupts to this address. @see ::sd_mbr_command_irq_forward_address_set_t*/ +}; + +/** @} */ + +/** @addtogroup NRF_MBR_TYPES Types + * @{ */ + +/**@brief This command copies part of a new SoftDevice + * + * The destination area is erased before copying. + * If dst is in the middle of a flash page, that whole flash page will be erased. + * If (dst+len) is in the middle of a flash page, that whole flash page will be erased. + * + * The user of this function is responsible for setting the BPROT registers. + * + * @retval ::NRF_SUCCESS indicates that the contents of the memory blocks where copied correctly. + * @retval ::NRF_ERROR_INTERNAL indicates that the contents of the memory blocks where not verified correctly after copying. + */ +typedef struct +{ + uint32_t *src; /**< Pointer to the source of data to be copied.*/ + uint32_t *dst; /**< Pointer to the destination where the content is to be copied.*/ + uint32_t len; /**< Number of 32 bit words to copy. Must be a multiple of @ref MBR_PAGE_SIZE_IN_WORDS words.*/ +} sd_mbr_command_copy_sd_t; + + +/**@brief This command works like memcmp, but takes the length in words. + * + * @retval ::NRF_SUCCESS indicates that the contents of both memory blocks are equal. + * @retval ::NRF_ERROR_NULL indicates that the contents of the memory blocks are not equal. + */ +typedef struct +{ + uint32_t *ptr1; /**< Pointer to block of memory. */ + uint32_t *ptr2; /**< Pointer to block of memory. */ + uint32_t len; /**< Number of 32 bit words to compare.*/ +} sd_mbr_command_compare_t; + + +/**@brief This command copies a new BootLoader. + * + * With this command, destination of BootLoader is always the address written in + * NRF_UICR->BOOTADDR. + * + * Destination is erased by this function. + * If (destination+bl_len) is in the middle of a flash page, that whole flash page will be erased. + * + * This function will use PROTENSET to protect the flash that is not intended to be written. + * + * On success, this function will not return. It will start the new BootLoader from reset-vector as normal. + * + * @retval ::NRF_ERROR_INTERNAL indicates an internal error that should not happen. + * @retval ::NRF_ERROR_FORBIDDEN if NRF_UICR->BOOTADDR is not set. + * @retval ::NRF_ERROR_INVALID_LENGTH if parameters attempts to read or write outside flash area. + * @retval ::NRF_ERROR_NO_MEM if no parameter page is provided (see SoftDevice Specification for more info) + */ +typedef struct +{ + uint32_t *bl_src; /**< Pointer to the source of the Bootloader to be be copied.*/ + uint32_t bl_len; /**< Number of 32 bit words to copy for BootLoader. */ +} sd_mbr_command_copy_bl_t; + +/**@brief Change the address the MBR starts after a reset + * + * Once this function has been called, this address is where the MBR will start to forward + * interrupts to after a reset. + * + * To restore default forwarding this function should be called with @ref address set to 0. The + * MBR will then start forwarding interrupts to the address in NFR_UICR->BOOTADDR or to the + * SoftDevice if the BOOTADDR is not set. + * + * On success, this function will not return. It will reset the device. + * + * @retval ::NRF_ERROR_INTERNAL indicates an internal error that should not happen. + * @retval ::NRF_ERROR_INVALID_ADDR if parameter address is outside of the flash size. + * @retval ::NRF_ERROR_NO_MEM if no parameter page is provided (see SoftDevice Specification for more info) + */ +typedef struct +{ + uint32_t address; /**< The base address of the interrupt vector table for forwarded interrupts.*/ +} sd_mbr_command_vector_table_base_set_t; + +/**@brief Sets the base address of the interrupt vector table for interrupts forwarded from the MBR + * + * Unlike sd_mbr_command_vector_table_base_set_t, this function does not reset, and it does not + * change where the MBR starts after reset. + * + * @retval ::NRF_SUCCESS + */ +typedef struct +{ + uint32_t address; /**< The base address of the interrupt vector table for forwarded interrupts.*/ +} sd_mbr_command_irq_forward_address_set_t; + +/**@brief Input structure containing data used when calling ::sd_mbr_command + * + * Depending on what command value that is set, the corresponding params value type must also be + * set. See @ref NRF_MBR_COMMANDS for command types and corresponding params value type. If command + * @ref SD_MBR_COMMAND_INIT_SD is set, it is not necessary to set any values under params. + */ +typedef struct +{ + uint32_t command; /**< Type of command to be issued. See @ref NRF_MBR_COMMANDS. */ + union + { + sd_mbr_command_copy_sd_t copy_sd; /**< Parameters for copy SoftDevice.*/ + sd_mbr_command_compare_t compare; /**< Parameters for verify.*/ + sd_mbr_command_copy_bl_t copy_bl; /**< Parameters for copy BootLoader. Requires parameter page. */ + sd_mbr_command_vector_table_base_set_t base_set; /**< Parameters for vector table base set. Requires parameter page.*/ + sd_mbr_command_irq_forward_address_set_t irq_forward_address_set; /**< Parameters for irq forward address set*/ + } params; /**< Command parameters. */ +} sd_mbr_command_t; + +/** @} */ + +/** @addtogroup NRF_MBR_FUNCTIONS Functions + * @{ */ + +/**@brief Issue Master Boot Record commands + * + * Commands used when updating a SoftDevice and bootloader. + * + * The @ref SD_MBR_COMMAND_COPY_BL and @ref SD_MBR_COMMAND_VECTOR_TABLE_BASE_SET requires + * parameters to be retained by the MBR when resetting the IC. This is done in a separate flash + * page provided by the application. The UICR register UICR.NRFFW[1] must be set to an address + * corresponding to a page in the application flash space. This page will be cleared by the MBR and + * used to store the command before reset. When the UICR.NRFFW[1] field is set the page it refers + * to must not be used by the application. If the UICR.NRFFW[1] is set to 0xFFFFFFFF (the default) + * MBR commands which use flash will be unavailable and return @ref NRF_ERROR_NO_MEM. + * + * @param[in] param Pointer to a struct describing the command. + * + * @note For return values, see ::sd_mbr_command_copy_sd_t, ::sd_mbr_command_copy_bl_t, + * ::sd_mbr_command_compare_t, ::sd_mbr_command_vector_table_base_set_t, + * ::sd_mbr_command_irq_forward_address_set_t + * + * @retval ::NRF_ERROR_NO_MEM if UICR.NRFFW[1] is not set (i.e. is 0xFFFFFFFF). + * @retval ::NRF_ERROR_INVALID_PARAM if an invalid command is given. +*/ +SVCALL(SD_MBR_COMMAND, uint32_t, sd_mbr_command(sd_mbr_command_t* param)); + +/** @} */ + +#ifdef __cplusplus +} +#endif +#endif // NRF_MBR_H__ + +/** + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_error.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_error.h new file mode 100644 index 0000000..6badee9 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_error.h @@ -0,0 +1,90 @@ +/* + * Copyright (c) 2014 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + + /** + @defgroup nrf_error SoftDevice Global Error Codes + @{ + + @brief Global Error definitions +*/ + +/* Header guard */ +#ifndef NRF_ERROR_H__ +#define NRF_ERROR_H__ + +#ifdef __cplusplus +extern "C" { +#endif + +/** @defgroup NRF_ERRORS_BASE Error Codes Base number definitions + * @{ */ +#define NRF_ERROR_BASE_NUM (0x0) ///< Global error base +#define NRF_ERROR_SDM_BASE_NUM (0x1000) ///< SDM error base +#define NRF_ERROR_SOC_BASE_NUM (0x2000) ///< SoC error base +#define NRF_ERROR_STK_BASE_NUM (0x3000) ///< STK error base +/** @} */ + +#define NRF_SUCCESS (NRF_ERROR_BASE_NUM + 0) ///< Successful command +#define NRF_ERROR_SVC_HANDLER_MISSING (NRF_ERROR_BASE_NUM + 1) ///< SVC handler is missing +#define NRF_ERROR_SOFTDEVICE_NOT_ENABLED (NRF_ERROR_BASE_NUM + 2) ///< SoftDevice has not been enabled +#define NRF_ERROR_INTERNAL (NRF_ERROR_BASE_NUM + 3) ///< Internal Error +#define NRF_ERROR_NO_MEM (NRF_ERROR_BASE_NUM + 4) ///< No Memory for operation +#define NRF_ERROR_NOT_FOUND (NRF_ERROR_BASE_NUM + 5) ///< Not found +#define NRF_ERROR_NOT_SUPPORTED (NRF_ERROR_BASE_NUM + 6) ///< Not supported +#define NRF_ERROR_INVALID_PARAM (NRF_ERROR_BASE_NUM + 7) ///< Invalid Parameter +#define NRF_ERROR_INVALID_STATE (NRF_ERROR_BASE_NUM + 8) ///< Invalid state, operation disallowed in this state +#define NRF_ERROR_INVALID_LENGTH (NRF_ERROR_BASE_NUM + 9) ///< Invalid Length +#define NRF_ERROR_INVALID_FLAGS (NRF_ERROR_BASE_NUM + 10) ///< Invalid Flags +#define NRF_ERROR_INVALID_DATA (NRF_ERROR_BASE_NUM + 11) ///< Invalid Data +#define NRF_ERROR_DATA_SIZE (NRF_ERROR_BASE_NUM + 12) ///< Invalid Data size +#define NRF_ERROR_TIMEOUT (NRF_ERROR_BASE_NUM + 13) ///< Operation timed out +#define NRF_ERROR_NULL (NRF_ERROR_BASE_NUM + 14) ///< Null Pointer +#define NRF_ERROR_FORBIDDEN (NRF_ERROR_BASE_NUM + 15) ///< Forbidden Operation +#define NRF_ERROR_INVALID_ADDR (NRF_ERROR_BASE_NUM + 16) ///< Bad Memory Address +#define NRF_ERROR_BUSY (NRF_ERROR_BASE_NUM + 17) ///< Busy +#define NRF_ERROR_CONN_COUNT (NRF_ERROR_BASE_NUM + 18) ///< Maximum connection count exceeded. +#define NRF_ERROR_RESOURCES (NRF_ERROR_BASE_NUM + 19) ///< Not enough resources for operation + +#ifdef __cplusplus +} +#endif +#endif // NRF_ERROR_H__ + +/** + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_error_sdm.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_error_sdm.h new file mode 100644 index 0000000..530959b --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_error_sdm.h @@ -0,0 +1,70 @@ +/* + * Copyright (c) 2012 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + + /** + @addtogroup nrf_sdm_api + @{ + @defgroup nrf_sdm_error SoftDevice Manager Error Codes + @{ + + @brief Error definitions for the SDM API +*/ + +/* Header guard */ +#ifndef NRF_ERROR_SDM_H__ +#define NRF_ERROR_SDM_H__ + +#include "nrf_error.h" + +#ifdef __cplusplus +extern "C" { +#endif + +#define NRF_ERROR_SDM_LFCLK_SOURCE_UNKNOWN (NRF_ERROR_SDM_BASE_NUM + 0) ///< Unknown LFCLK source. +#define NRF_ERROR_SDM_INCORRECT_INTERRUPT_CONFIGURATION (NRF_ERROR_SDM_BASE_NUM + 1) ///< Incorrect interrupt configuration (can be caused by using illegal priority levels, or having enabled SoftDevice interrupts). +#define NRF_ERROR_SDM_INCORRECT_CLENR0 (NRF_ERROR_SDM_BASE_NUM + 2) ///< Incorrect CLENR0 (can be caused by erroneous SoftDevice flashing). + +#ifdef __cplusplus +} +#endif +#endif // NRF_ERROR_SDM_H__ + +/** + @} + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_error_soc.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_error_soc.h new file mode 100644 index 0000000..1e784b8 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_error_soc.h @@ -0,0 +1,85 @@ +/* + * Copyright (c) 2012 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @addtogroup nrf_soc_api + @{ + @defgroup nrf_soc_error SoC Library Error Codes + @{ + + @brief Error definitions for the SoC library + +*/ + +/* Header guard */ +#ifndef NRF_ERROR_SOC_H__ +#define NRF_ERROR_SOC_H__ + +#include "nrf_error.h" +#ifdef __cplusplus +extern "C" { +#endif + +/* Mutex Errors */ +#define NRF_ERROR_SOC_MUTEX_ALREADY_TAKEN (NRF_ERROR_SOC_BASE_NUM + 0) ///< Mutex already taken + +/* NVIC errors */ +#define NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE (NRF_ERROR_SOC_BASE_NUM + 1) ///< NVIC interrupt not available +#define NRF_ERROR_SOC_NVIC_INTERRUPT_PRIORITY_NOT_ALLOWED (NRF_ERROR_SOC_BASE_NUM + 2) ///< NVIC interrupt priority not allowed +#define NRF_ERROR_SOC_NVIC_SHOULD_NOT_RETURN (NRF_ERROR_SOC_BASE_NUM + 3) ///< NVIC should not return + +/* Power errors */ +#define NRF_ERROR_SOC_POWER_MODE_UNKNOWN (NRF_ERROR_SOC_BASE_NUM + 4) ///< Power mode unknown +#define NRF_ERROR_SOC_POWER_POF_THRESHOLD_UNKNOWN (NRF_ERROR_SOC_BASE_NUM + 5) ///< Power POF threshold unknown +#define NRF_ERROR_SOC_POWER_OFF_SHOULD_NOT_RETURN (NRF_ERROR_SOC_BASE_NUM + 6) ///< Power off should not return + +/* Rand errors */ +#define NRF_ERROR_SOC_RAND_NOT_ENOUGH_VALUES (NRF_ERROR_SOC_BASE_NUM + 7) ///< RAND not enough values + +/* PPI errors */ +#define NRF_ERROR_SOC_PPI_INVALID_CHANNEL (NRF_ERROR_SOC_BASE_NUM + 8) ///< Invalid PPI Channel +#define NRF_ERROR_SOC_PPI_INVALID_GROUP (NRF_ERROR_SOC_BASE_NUM + 9) ///< Invalid PPI Group + +#ifdef __cplusplus +} +#endif +#endif // NRF_ERROR_SOC_H__ +/** + @} + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_nvic.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_nvic.h new file mode 100644 index 0000000..f5c7e8e --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_nvic.h @@ -0,0 +1,486 @@ +/* + * Copyright (c) 2016 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + * @defgroup nrf_nvic_api SoftDevice NVIC API + * @{ + * + * @note In order to use this module, the following code has to be added to a .c file: + * \code + * nrf_nvic_state_t nrf_nvic_state = {0}; + * \endcode + * + * @note Definitions and declarations starting with __ (double underscore) in this header file are + * not intended for direct use by the application. + * + * @brief APIs for the accessing NVIC when using a SoftDevice. + * + */ + +#ifndef NRF_NVIC_H__ +#define NRF_NVIC_H__ + +#include <stdint.h> +#include "nrf.h" +#include "nrf_svc.h" +#include "nrf_error.h" +#include "nrf_error_soc.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/**@addtogroup NRF_NVIC_DEFINES Defines + * @{ */ + +/**@defgroup NRF_NVIC_ISER_DEFINES SoftDevice NVIC internal definitions + * @{ */ + +#define __NRF_NVIC_NVMC_IRQn (30) /**< The peripheral ID of the NVMC. IRQ numbers are used to identify peripherals, but the NVMC doesn't have an IRQ number in the MDK. */ + +#define __NRF_NVIC_ISER_COUNT (2) /**< The number of ISER/ICER registers in the NVIC that are used. */ + +/**@brief Interrupts used by the SoftDevice, with IRQn in the range 0-31. */ +#define __NRF_NVIC_SD_IRQS_0 ((uint32_t)( \ + (1U << POWER_CLOCK_IRQn) \ + | (1U << RADIO_IRQn) \ + | (1U << RTC0_IRQn) \ + | (1U << TIMER0_IRQn) \ + | (1U << RNG_IRQn) \ + | (1U << ECB_IRQn) \ + | (1U << CCM_AAR_IRQn) \ + | (1U << TEMP_IRQn) \ + | (1U << __NRF_NVIC_NVMC_IRQn) \ + | (1U << (uint32_t)SWI5_IRQn) \ + )) + +/**@brief Interrupts used by the SoftDevice, with IRQn in the range 32-63. */ +#define __NRF_NVIC_SD_IRQS_1 ((uint32_t)0) + +/**@brief Interrupts available for to application, with IRQn in the range 0-31. */ +#define __NRF_NVIC_APP_IRQS_0 (~__NRF_NVIC_SD_IRQS_0) + +/**@brief Interrupts available for to application, with IRQn in the range 32-63. */ +#define __NRF_NVIC_APP_IRQS_1 (~__NRF_NVIC_SD_IRQS_1) + +/**@} */ + +/**@} */ + +/**@addtogroup NRF_NVIC_VARIABLES Variables + * @{ */ + +/**@brief Type representing the state struct for the SoftDevice NVIC module. */ +typedef struct +{ + uint32_t volatile __irq_masks[__NRF_NVIC_ISER_COUNT]; /**< IRQs enabled by the application in the NVIC. */ + uint32_t volatile __cr_flag; /**< Non-zero if already in a critical region */ +} nrf_nvic_state_t; + +/**@brief Variable keeping the state for the SoftDevice NVIC module. This must be declared in an + * application source file. */ +extern nrf_nvic_state_t nrf_nvic_state; + +/**@} */ + +/**@addtogroup NRF_NVIC_INTERNAL_FUNCTIONS SoftDevice NVIC internal functions + * @{ */ + +/**@brief Disables IRQ interrupts globally, including the SoftDevice's interrupts. + * + * @retval The value of PRIMASK prior to disabling the interrupts. + */ +__STATIC_INLINE int __sd_nvic_irq_disable(void); + +/**@brief Enables IRQ interrupts globally, including the SoftDevice's interrupts. + */ +__STATIC_INLINE void __sd_nvic_irq_enable(void); + +/**@brief Checks if IRQn is available to application + * @param[in] IRQn IRQ to check + * + * @retval 1 (true) if the IRQ to check is available to the application + */ +__STATIC_INLINE uint32_t __sd_nvic_app_accessible_irq(IRQn_Type IRQn); + +/**@brief Checks if priority is available to application + * @param[in] priority priority to check + * + * @retval 1 (true) if the priority to check is available to the application + */ +__STATIC_INLINE uint32_t __sd_nvic_is_app_accessible_priority(uint32_t priority); + +/**@} */ + +/**@addtogroup NRF_NVIC_FUNCTIONS SoftDevice NVIC public functions + * @{ */ + +/**@brief Enable External Interrupt. + * @note Corresponds to NVIC_EnableIRQ in CMSIS. + * + * @pre IRQn is valid and not reserved by the stack. + * + * @param[in] IRQn See the NVIC_EnableIRQ documentation in CMSIS. + * + * @retval ::NRF_SUCCESS The interrupt was enabled. + * @retval ::NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE The interrupt is not available for the application. + * @retval ::NRF_ERROR_SOC_NVIC_INTERRUPT_PRIORITY_NOT_ALLOWED The interrupt has a priority not available for the application. + */ +__STATIC_INLINE uint32_t sd_nvic_EnableIRQ(IRQn_Type IRQn); + +/**@brief Disable External Interrupt. + * @note Corresponds to NVIC_DisableIRQ in CMSIS. + * + * @pre IRQn is valid and not reserved by the stack. + * + * @param[in] IRQn See the NVIC_DisableIRQ documentation in CMSIS. + * + * @retval ::NRF_SUCCESS The interrupt was disabled. + * @retval ::NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE The interrupt is not available for the application. + */ +__STATIC_INLINE uint32_t sd_nvic_DisableIRQ(IRQn_Type IRQn); + +/**@brief Get Pending Interrupt. + * @note Corresponds to NVIC_GetPendingIRQ in CMSIS. + * + * @pre IRQn is valid and not reserved by the stack. + * + * @param[in] IRQn See the NVIC_GetPendingIRQ documentation in CMSIS. + * @param[out] p_pending_irq Return value from NVIC_GetPendingIRQ. + * + * @retval ::NRF_SUCCESS The interrupt is available for the application. + * @retval ::NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE IRQn is not available for the application. + */ +__STATIC_INLINE uint32_t sd_nvic_GetPendingIRQ(IRQn_Type IRQn, uint32_t * p_pending_irq); + +/**@brief Set Pending Interrupt. + * @note Corresponds to NVIC_SetPendingIRQ in CMSIS. + * + * @pre IRQn is valid and not reserved by the stack. + * + * @param[in] IRQn See the NVIC_SetPendingIRQ documentation in CMSIS. + * + * @retval ::NRF_SUCCESS The interrupt is set pending. + * @retval ::NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE IRQn is not available for the application. + */ +__STATIC_INLINE uint32_t sd_nvic_SetPendingIRQ(IRQn_Type IRQn); + +/**@brief Clear Pending Interrupt. + * @note Corresponds to NVIC_ClearPendingIRQ in CMSIS. + * + * @pre IRQn is valid and not reserved by the stack. + * + * @param[in] IRQn See the NVIC_ClearPendingIRQ documentation in CMSIS. + * + * @retval ::NRF_SUCCESS The interrupt pending flag is cleared. + * @retval ::NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE IRQn is not available for the application. + */ +__STATIC_INLINE uint32_t sd_nvic_ClearPendingIRQ(IRQn_Type IRQn); + +/**@brief Set Interrupt Priority. + * @note Corresponds to NVIC_SetPriority in CMSIS. + * + * @pre IRQn is valid and not reserved by the stack. + * @pre Priority is valid and not reserved by the stack. + * + * @param[in] IRQn See the NVIC_SetPriority documentation in CMSIS. + * @param[in] priority A valid IRQ priority for use by the application. + * + * @retval ::NRF_SUCCESS The interrupt and priority level is available for the application. + * @retval ::NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE IRQn is not available for the application. + * @retval ::NRF_ERROR_SOC_NVIC_INTERRUPT_PRIORITY_NOT_ALLOWED The interrupt priority is not available for the application. + */ +__STATIC_INLINE uint32_t sd_nvic_SetPriority(IRQn_Type IRQn, uint32_t priority); + +/**@brief Get Interrupt Priority. + * @note Corresponds to NVIC_GetPriority in CMSIS. + * + * @pre IRQn is valid and not reserved by the stack. + * + * @param[in] IRQn See the NVIC_GetPriority documentation in CMSIS. + * @param[out] p_priority Return value from NVIC_GetPriority. + * + * @retval ::NRF_SUCCESS The interrupt priority is returned in p_priority. + * @retval ::NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE - IRQn is not available for the application. + */ +__STATIC_INLINE uint32_t sd_nvic_GetPriority(IRQn_Type IRQn, uint32_t * p_priority); + +/**@brief System Reset. + * @note Corresponds to NVIC_SystemReset in CMSIS. + * + * @retval ::NRF_ERROR_SOC_NVIC_SHOULD_NOT_RETURN + */ +__STATIC_INLINE uint32_t sd_nvic_SystemReset(void); + +/**@brief Enter critical region. + * + * @post Application interrupts will be disabled. + * @note sd_nvic_critical_region_enter() and ::sd_nvic_critical_region_exit() must be called in matching pairs inside each + * execution context + * @sa sd_nvic_critical_region_exit + * + * @param[out] p_is_nested_critical_region If 1, the application is now in a nested critical region. + * + * @retval ::NRF_SUCCESS + */ +__STATIC_INLINE uint32_t sd_nvic_critical_region_enter(uint8_t * p_is_nested_critical_region); + +/**@brief Exit critical region. + * + * @pre Application has entered a critical region using ::sd_nvic_critical_region_enter. + * @post If not in a nested critical region, the application interrupts will restored to the state before ::sd_nvic_critical_region_enter was called. + * + * @param[in] is_nested_critical_region If this is set to 1, the critical region won't be exited. @sa sd_nvic_critical_region_enter. + * + * @retval ::NRF_SUCCESS + */ +__STATIC_INLINE uint32_t sd_nvic_critical_region_exit(uint8_t is_nested_critical_region); + +/**@} */ + +#ifndef SUPPRESS_INLINE_IMPLEMENTATION + +__STATIC_INLINE int __sd_nvic_irq_disable(void) +{ + int pm = __get_PRIMASK(); + __disable_irq(); + return pm; +} + +__STATIC_INLINE void __sd_nvic_irq_enable(void) +{ + __enable_irq(); +} + +__STATIC_INLINE uint32_t __sd_nvic_app_accessible_irq(IRQn_Type IRQn) +{ + if (IRQn < 32) + { + return ((1UL<<IRQn) & __NRF_NVIC_APP_IRQS_0) != 0; + } + else if (IRQn < 64) + { + return ((1UL<<(IRQn-32)) & __NRF_NVIC_APP_IRQS_1) != 0; + } + else + { + return 1; + } +} + +__STATIC_INLINE uint32_t __sd_nvic_is_app_accessible_priority(uint32_t priority) +{ + if(priority >= (1 << __NVIC_PRIO_BITS)) + { + return 0; + } + if( priority == 0 + || priority == 1 + || priority == 4 + ) + { + return 0; + } + return 1; +} + + +__STATIC_INLINE uint32_t sd_nvic_EnableIRQ(IRQn_Type IRQn) +{ + if (!__sd_nvic_app_accessible_irq(IRQn)) + { + return NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE; + } + if (!__sd_nvic_is_app_accessible_priority(NVIC_GetPriority(IRQn))) + { + return NRF_ERROR_SOC_NVIC_INTERRUPT_PRIORITY_NOT_ALLOWED; + } + + if (nrf_nvic_state.__cr_flag) + { + nrf_nvic_state.__irq_masks[(uint32_t)((int32_t)IRQn) >> 5] |= (uint32_t)(1 << ((uint32_t)((int32_t)IRQn) & (uint32_t)0x1F)); + } + else + { + NVIC_EnableIRQ(IRQn); + } + return NRF_SUCCESS; +} + +__STATIC_INLINE uint32_t sd_nvic_DisableIRQ(IRQn_Type IRQn) +{ + if (!__sd_nvic_app_accessible_irq(IRQn)) + { + return NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE; + } + + if (nrf_nvic_state.__cr_flag) + { + nrf_nvic_state.__irq_masks[(uint32_t)((int32_t)IRQn) >> 5] &= ~(1UL << ((uint32_t)(IRQn) & 0x1F)); + } + else + { + NVIC_DisableIRQ(IRQn); + } + + return NRF_SUCCESS; +} + +__STATIC_INLINE uint32_t sd_nvic_GetPendingIRQ(IRQn_Type IRQn, uint32_t * p_pending_irq) +{ + if (__sd_nvic_app_accessible_irq(IRQn)) + { + *p_pending_irq = NVIC_GetPendingIRQ(IRQn); + return NRF_SUCCESS; + } + else + { + return NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE; + } +} + +__STATIC_INLINE uint32_t sd_nvic_SetPendingIRQ(IRQn_Type IRQn) +{ + if (__sd_nvic_app_accessible_irq(IRQn)) + { + NVIC_SetPendingIRQ(IRQn); + return NRF_SUCCESS; + } + else + { + return NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE; + } +} + +__STATIC_INLINE uint32_t sd_nvic_ClearPendingIRQ(IRQn_Type IRQn) +{ + if (__sd_nvic_app_accessible_irq(IRQn)) + { + NVIC_ClearPendingIRQ(IRQn); + return NRF_SUCCESS; + } + else + { + return NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE; + } +} + +__STATIC_INLINE uint32_t sd_nvic_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if (!__sd_nvic_app_accessible_irq(IRQn)) + { + return NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE; + } + + if (!__sd_nvic_is_app_accessible_priority(priority)) + { + return NRF_ERROR_SOC_NVIC_INTERRUPT_PRIORITY_NOT_ALLOWED; + } + + NVIC_SetPriority(IRQn, (uint32_t)priority); + return NRF_SUCCESS; +} + +__STATIC_INLINE uint32_t sd_nvic_GetPriority(IRQn_Type IRQn, uint32_t * p_priority) +{ + if (__sd_nvic_app_accessible_irq(IRQn)) + { + *p_priority = (NVIC_GetPriority(IRQn) & 0xFF); + return NRF_SUCCESS; + } + else + { + return NRF_ERROR_SOC_NVIC_INTERRUPT_NOT_AVAILABLE; + } +} + +__STATIC_INLINE uint32_t sd_nvic_SystemReset(void) +{ + NVIC_SystemReset(); + return NRF_ERROR_SOC_NVIC_SHOULD_NOT_RETURN; +} + +__STATIC_INLINE uint32_t sd_nvic_critical_region_enter(uint8_t * p_is_nested_critical_region) +{ + int was_masked = __sd_nvic_irq_disable(); + if (!nrf_nvic_state.__cr_flag) + { + nrf_nvic_state.__cr_flag = 1; + nrf_nvic_state.__irq_masks[0] = ( NVIC->ICER[0] & __NRF_NVIC_APP_IRQS_0 ); + NVIC->ICER[0] = __NRF_NVIC_APP_IRQS_0; + nrf_nvic_state.__irq_masks[1] = ( NVIC->ICER[1] & __NRF_NVIC_APP_IRQS_1 ); + NVIC->ICER[1] = __NRF_NVIC_APP_IRQS_1; + *p_is_nested_critical_region = 0; + } + else + { + *p_is_nested_critical_region = 1; + } + if (!was_masked) + { + __sd_nvic_irq_enable(); + } + return NRF_SUCCESS; +} + +__STATIC_INLINE uint32_t sd_nvic_critical_region_exit(uint8_t is_nested_critical_region) +{ + if (nrf_nvic_state.__cr_flag && (is_nested_critical_region == 0)) + { + int was_masked = __sd_nvic_irq_disable(); + NVIC->ISER[0] = nrf_nvic_state.__irq_masks[0]; + NVIC->ISER[1] = nrf_nvic_state.__irq_masks[1]; + nrf_nvic_state.__cr_flag = 0; + if (!was_masked) + { + __sd_nvic_irq_enable(); + } + } + + return NRF_SUCCESS; +} + +#endif /* SUPPRESS_INLINE_IMPLEMENTATION */ + +#ifdef __cplusplus +} +#endif + +#endif // NRF_NVIC_H__ + +/**@} */ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_sd_def.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_sd_def.h new file mode 100644 index 0000000..c9ab241 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_sd_def.h @@ -0,0 +1,59 @@ +/** + * Copyright (c) 2015 - 2018, Nordic Semiconductor ASA + * + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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 NRF_SD_DEF_H__ +#define NRF_SD_DEF_H__ + +#include <stdint.h> + +#ifdef __cplusplus +extern "C" { +#endif + +#define SD_PPI_CHANNELS_USED 0xFFFE0000uL /**< PPI channels utilized by SotfDevice (not available to the application). */ +#define SD_PPI_GROUPS_USED 0x0000000CuL /**< PPI groups utilized by SoftDevice (not available to the application). */ +#define SD_TIMERS_USED 0x00000001uL /**< Timers used by SoftDevice. */ +#define SD_SWI_USED 0x0000003CuL /**< Software interrupts used by SoftDevice */ + + +#ifdef __cplusplus +} +#endif + +#endif /* NRF_SD_DEF_H__ */ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_sdm.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_sdm.h new file mode 100644 index 0000000..8c48d93 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_sdm.h @@ -0,0 +1,358 @@ +/* + * Copyright (c) 2015 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + @defgroup nrf_sdm_api SoftDevice Manager API + @{ + + @brief APIs for SoftDevice management. + +*/ + +#ifndef NRF_SDM_H__ +#define NRF_SDM_H__ + +#include <stdint.h> +#include "nrf.h" +#include "nrf_svc.h" +#include "nrf_error.h" +#include "nrf_error_sdm.h" +#include "nrf_soc.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** @addtogroup NRF_SDM_DEFINES Defines + * @{ */ +#ifdef NRFSOC_DOXYGEN +/// Declared in nrf_mbr.h +#define MBR_SIZE 0 +#warning test +#endif + +/** @brief The major version for the SoftDevice binary distributed with this header file. */ +#define SD_MAJOR_VERSION (6) + +/** @brief The minor version for the SoftDevice binary distributed with this header file. */ +#define SD_MINOR_VERSION (0) + +/** @brief The bugfix version for the SoftDevice binary distributed with this header file. */ +#define SD_BUGFIX_VERSION (0) + +/** @brief The full version number for the SoftDevice binary this header file was distributed + * with, as a decimal number in the form Mmmmbbb, where: + * - M is major version (one or more digits) + * - mmm is minor version (three digits) + * - bbb is bugfix version (three digits). */ +#define SD_VERSION (SD_MAJOR_VERSION * 1000000 + SD_MINOR_VERSION * 1000 + SD_BUGFIX_VERSION) + +/** @brief SoftDevice Manager SVC Base number. */ +#define SDM_SVC_BASE 0x10 + +/** @brief SoftDevice unique string size in bytes. */ +#define SD_UNIQUE_STR_SIZE 20 + +/** @brief Invalid info field. Returned when an info field does not exist. */ +#define SDM_INFO_FIELD_INVALID (0) + +/** @brief Defines the SoftDevice Information Structure location (address) as an offset from +the start of the SoftDevice (without MBR)*/ +#define SOFTDEVICE_INFO_STRUCT_OFFSET (0x2000) + +/** @brief Defines the absolute SoftDevice Information Structure location (address) when the + * SoftDevice is installed just above the MBR (the usual case). */ +#define SOFTDEVICE_INFO_STRUCT_ADDRESS (SOFTDEVICE_INFO_STRUCT_OFFSET + MBR_SIZE) + +/** @brief Defines the offset for the SoftDevice Information Structure size value relative to the + * SoftDevice base address. The size value is of type uint8_t. */ +#define SD_INFO_STRUCT_SIZE_OFFSET (SOFTDEVICE_INFO_STRUCT_OFFSET) + +/** @brief Defines the offset for the SoftDevice size value relative to the SoftDevice base address. + * The size value is of type uint32_t. */ +#define SD_SIZE_OFFSET (SOFTDEVICE_INFO_STRUCT_OFFSET + 0x08) + +/** @brief Defines the offset for FWID value relative to the SoftDevice base address. The FWID value + * is of type uint16_t. */ +#define SD_FWID_OFFSET (SOFTDEVICE_INFO_STRUCT_OFFSET + 0x0C) + +/** @brief Defines the offset for the SoftDevice ID relative to the SoftDevice base address. The ID + * is of type uint32_t. */ +#define SD_ID_OFFSET (SOFTDEVICE_INFO_STRUCT_OFFSET + 0x10) + +/** @brief Defines the offset for the SoftDevice version relative to the SoftDevice base address in + * the same format as @ref SD_VERSION, stored as an uint32_t. */ +#define SD_VERSION_OFFSET (SOFTDEVICE_INFO_STRUCT_OFFSET + 0x14) + +/** @brief Defines the offset for the SoftDevice unique string relative to the SoftDevice base address. + * The SD_UNIQUE_STR is stored as an array of uint8_t. The size of array is @ref SD_UNIQUE_STR_SIZE. + */ +#define SD_UNIQUE_STR_OFFSET (SOFTDEVICE_INFO_STRUCT_OFFSET + 0x18) + +/** @brief Defines a macro for retrieving the actual SoftDevice Information Structure size value + * from a given base address. Use @ref MBR_SIZE as the argument when the SoftDevice is + * installed just above the MBR (the usual case). */ +#define SD_INFO_STRUCT_SIZE_GET(baseaddr) (*((uint8_t *) ((baseaddr) + SD_INFO_STRUCT_SIZE_OFFSET))) + +/** @brief Defines a macro for retrieving the actual SoftDevice size value from a given base + * address. Use @ref MBR_SIZE as the argument when the SoftDevice is installed just above + * the MBR (the usual case). */ +#define SD_SIZE_GET(baseaddr) (*((uint32_t *) ((baseaddr) + SD_SIZE_OFFSET))) + +/** @brief Defines a macro for retrieving the actual FWID value from a given base address. Use + * @ref MBR_SIZE as the argument when the SoftDevice is installed just above the MBR (the usual + * case). */ +#define SD_FWID_GET(baseaddr) (*((uint16_t *) ((baseaddr) + SD_FWID_OFFSET))) + +/** @brief Defines a macro for retrieving the actual SoftDevice ID from a given base address. Use + * @ref MBR_SIZE as the argument when the SoftDevice is installed just above the MBR (the + * usual case). */ +#define SD_ID_GET(baseaddr) ((SD_INFO_STRUCT_SIZE_GET(baseaddr) > (SD_ID_OFFSET - SOFTDEVICE_INFO_STRUCT_OFFSET)) \ + ? (*((uint32_t *) ((baseaddr) + SD_ID_OFFSET))) : SDM_INFO_FIELD_INVALID) + +/** @brief Defines a macro for retrieving the actual SoftDevice version from a given base address. + * Use @ref MBR_SIZE as the argument when the SoftDevice is installed just above the MBR + * (the usual case). */ +#define SD_VERSION_GET(baseaddr) ((SD_INFO_STRUCT_SIZE_GET(baseaddr) > (SD_VERSION_OFFSET - SOFTDEVICE_INFO_STRUCT_OFFSET)) \ + ? (*((uint32_t *) ((baseaddr) + SD_VERSION_OFFSET))) : SDM_INFO_FIELD_INVALID) + +/** @brief Defines a macro for retrieving the address of SoftDevice unique str based on a given base address. + * Use @ref MBR_SIZE as the argument when the SoftDevice is installed just above the MBR + * (the usual case). */ +#define SD_UNIQUE_STR_ADDR_GET(baseaddr) ((SD_INFO_STRUCT_SIZE_GET(baseaddr) > (SD_UNIQUE_STR_OFFSET - SOFTDEVICE_INFO_STRUCT_OFFSET)) \ + ? (((uint8_t *) ((baseaddr) + SD_UNIQUE_STR_OFFSET))) : SDM_INFO_FIELD_INVALID) + +/**@defgroup NRF_FAULT_ID_RANGES Fault ID ranges + * @{ */ +#define NRF_FAULT_ID_SD_RANGE_START 0x00000000 /**< SoftDevice ID range start. */ +#define NRF_FAULT_ID_APP_RANGE_START 0x00001000 /**< Application ID range start. */ +/**@} */ + +/**@defgroup NRF_FAULT_IDS Fault ID types + * @{ */ +#define NRF_FAULT_ID_SD_ASSERT (NRF_FAULT_ID_SD_RANGE_START + 1) /**< SoftDevice assertion. The info parameter is reserved for future used. */ +#define NRF_FAULT_ID_APP_MEMACC (NRF_FAULT_ID_APP_RANGE_START + 1) /**< Application invalid memory access. The info parameter will contain 0x00000000, + in case of SoftDevice RAM access violation. In case of SoftDevice peripheral + register violation the info parameter will contain the sub-region number of + PREGION[0], on whose address range the disallowed write access caused the + memory access fault. */ +/**@} */ + +/** @} */ + +/** @addtogroup NRF_SDM_ENUMS Enumerations + * @{ */ + +/**@brief nRF SoftDevice Manager API SVC numbers. */ +enum NRF_SD_SVCS +{ + SD_SOFTDEVICE_ENABLE = SDM_SVC_BASE, /**< ::sd_softdevice_enable */ + SD_SOFTDEVICE_DISABLE, /**< ::sd_softdevice_disable */ + SD_SOFTDEVICE_IS_ENABLED, /**< ::sd_softdevice_is_enabled */ + SD_SOFTDEVICE_VECTOR_TABLE_BASE_SET, /**< ::sd_softdevice_vector_table_base_set */ + SVC_SDM_LAST /**< Placeholder for last SDM SVC */ +}; + +/** @} */ + +/** @addtogroup NRF_SDM_DEFINES Defines + * @{ */ + +/**@defgroup NRF_CLOCK_LF_ACCURACY Clock accuracy + * @{ */ + +#define NRF_CLOCK_LF_ACCURACY_250_PPM (0) /**< Default: 250 ppm */ +#define NRF_CLOCK_LF_ACCURACY_500_PPM (1) /**< 500 ppm */ +#define NRF_CLOCK_LF_ACCURACY_150_PPM (2) /**< 150 ppm */ +#define NRF_CLOCK_LF_ACCURACY_100_PPM (3) /**< 100 ppm */ +#define NRF_CLOCK_LF_ACCURACY_75_PPM (4) /**< 75 ppm */ +#define NRF_CLOCK_LF_ACCURACY_50_PPM (5) /**< 50 ppm */ +#define NRF_CLOCK_LF_ACCURACY_30_PPM (6) /**< 30 ppm */ +#define NRF_CLOCK_LF_ACCURACY_20_PPM (7) /**< 20 ppm */ +#define NRF_CLOCK_LF_ACCURACY_10_PPM (8) /**< 10 ppm */ +#define NRF_CLOCK_LF_ACCURACY_5_PPM (9) /**< 5 ppm */ +#define NRF_CLOCK_LF_ACCURACY_2_PPM (10) /**< 2 ppm */ +#define NRF_CLOCK_LF_ACCURACY_1_PPM (11) /**< 1 ppm */ + +/** @} */ + +/**@defgroup NRF_CLOCK_LF_SRC Possible LFCLK oscillator sources + * @{ */ + +#define NRF_CLOCK_LF_SRC_RC (0) /**< LFCLK RC oscillator. */ +#define NRF_CLOCK_LF_SRC_XTAL (1) /**< LFCLK crystal oscillator. */ +#define NRF_CLOCK_LF_SRC_SYNTH (2) /**< LFCLK Synthesized from HFCLK. */ + +/** @} */ + +/** @} */ + +/** @addtogroup NRF_SDM_TYPES Types + * @{ */ + +/**@brief Type representing LFCLK oscillator source. */ +typedef struct +{ + uint8_t source; /**< LF oscillator clock source, see @ref NRF_CLOCK_LF_SRC. */ + uint8_t rc_ctiv; /**< Only for ::NRF_CLOCK_LF_SRC_RC: Calibration timer interval in 1/4 second + units (nRF52: 1-32). + @note To avoid excessive clock drift, 0.5 degrees Celsius is the + maximum temperature change allowed in one calibration timer + interval. The interval should be selected to ensure this. + + @note Must be 0 if source is not ::NRF_CLOCK_LF_SRC_RC. */ + uint8_t rc_temp_ctiv; /**< Only for ::NRF_CLOCK_LF_SRC_RC: How often (in number of calibration + intervals) the RC oscillator shall be calibrated if the temperature + hasn't changed. + 0: Always calibrate even if the temperature hasn't changed. + 1: Only calibrate if the temperature has changed (legacy - nRF51 only). + 2-33: Check the temperature and only calibrate if it has changed, + however calibration will take place every rc_temp_ctiv + intervals in any case. + + @note Must be 0 if source is not ::NRF_CLOCK_LF_SRC_RC. + + @note For nRF52, the application must ensure calibration at least once + every 8 seconds to ensure +/-500 ppm clock stability. The + recommended configuration for ::NRF_CLOCK_LF_SRC_RC on nRF52 is + rc_ctiv=16 and rc_temp_ctiv=2. This will ensure calibration at + least once every 8 seconds and for temperature changes of 0.5 + degrees Celsius every 4 seconds. See the Product Specification + for the nRF52 device being used for more information.*/ + uint8_t accuracy; /**< External clock accuracy used in the LL to compute timing + windows, see @ref NRF_CLOCK_LF_ACCURACY.*/ +} nrf_clock_lf_cfg_t; + +/**@brief Fault Handler type. + * + * When certain unrecoverable errors occur within the application or SoftDevice the fault handler will be called back. + * The protocol stack will be in an undefined state when this happens and the only way to recover will be to + * perform a reset, using e.g. CMSIS NVIC_SystemReset(). + * If the application returns from the fault handler the SoftDevice will call NVIC_SystemReset(). + * + * @note This callback is executed in HardFault context, thus SVC functions cannot be called from the fault callback. + * + * @param[in] id Fault identifier. See @ref NRF_FAULT_IDS. + * @param[in] pc The program counter of the instruction that triggered the fault. + * @param[in] info Optional additional information regarding the fault. Refer to each Fault identifier for details. + * + * @note When id is set to @ref NRF_FAULT_ID_APP_MEMACC, pc will contain the address of the instruction being executed at the time when + * the fault is detected by the CPU. The CPU program counter may have advanced up to 2 instructions (no branching) after the one that triggered the fault. + */ +typedef void (*nrf_fault_handler_t)(uint32_t id, uint32_t pc, uint32_t info); + +/** @} */ + +/** @addtogroup NRF_SDM_FUNCTIONS Functions + * @{ */ + +/**@brief Enables the SoftDevice and by extension the protocol stack. + * + * @note Some care must be taken if a low frequency clock source is already running when calling this function: + * If the LF clock has a different source then the one currently running, it will be stopped. Then, the new + * clock source will be started. + * + * @note This function has no effect when returning with an error. + * + * @post If return code is ::NRF_SUCCESS + * - SoC library and protocol stack APIs are made available. + * - A portion of RAM will be unavailable (see relevant SDS documentation). + * - Some peripherals will be unavailable or available only through the SoC API (see relevant SDS documentation). + * - Interrupts will not arrive from protected peripherals or interrupts. + * - nrf_nvic_ functions must be used instead of CMSIS NVIC_ functions for reliable usage of the SoftDevice. + * - Interrupt latency may be affected by the SoftDevice (see relevant SDS documentation). + * - Chosen low frequency clock source will be running. + * + * @param p_clock_lf_cfg Low frequency clock source and accuracy. + If NULL the clock will be configured as an RC source with rc_ctiv = 16 and .rc_temp_ctiv = 2 + In the case of XTAL source, the PPM accuracy of the chosen clock source must be greater than or equal to the actual characteristics of your XTAL clock. + * @param fault_handler Callback to be invoked in case of fault, cannot be NULL. + * + * @retval ::NRF_SUCCESS + * @retval ::NRF_ERROR_INVALID_ADDR Invalid or NULL pointer supplied. + * @retval ::NRF_ERROR_INVALID_STATE SoftDevice is already enabled, and the clock source and fault handler cannot be updated. + * @retval ::NRF_ERROR_SDM_INCORRECT_INTERRUPT_CONFIGURATION SoftDevice interrupt is already enabled, or an enabled interrupt has an illegal priority level. + * @retval ::NRF_ERROR_SDM_LFCLK_SOURCE_UNKNOWN Unknown low frequency clock source selected. + * @retval ::NRF_ERROR_INVALID_PARAM Invalid clock source configuration supplied in p_clock_lf_cfg. + */ +SVCALL(SD_SOFTDEVICE_ENABLE, uint32_t, sd_softdevice_enable(nrf_clock_lf_cfg_t const * p_clock_lf_cfg, nrf_fault_handler_t fault_handler)); + + +/**@brief Disables the SoftDevice and by extension the protocol stack. + * + * Idempotent function to disable the SoftDevice. + * + * @post SoC library and protocol stack APIs are made unavailable. + * @post All interrupts that was protected by the SoftDevice will be disabled and initialized to priority 0 (highest). + * @post All peripherals used by the SoftDevice will be reset to default values. + * @post All of RAM become available. + * @post All interrupts are forwarded to the application. + * @post LFCLK source chosen in ::sd_softdevice_enable will be left running. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_SOFTDEVICE_DISABLE, uint32_t, sd_softdevice_disable(void)); + +/**@brief Check if the SoftDevice is enabled. + * + * @param[out] p_softdevice_enabled If the SoftDevice is enabled: 1 else 0. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_SOFTDEVICE_IS_ENABLED, uint32_t, sd_softdevice_is_enabled(uint8_t * p_softdevice_enabled)); + +/**@brief Sets the base address of the interrupt vector table for interrupts forwarded from the SoftDevice + * + * This function is only intended to be called when a bootloader is enabled. + * + * @param[in] address The base address of the interrupt vector table for forwarded interrupts. + + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_SOFTDEVICE_VECTOR_TABLE_BASE_SET, uint32_t, sd_softdevice_vector_table_base_set(uint32_t address)); + +/** @} */ + +#ifdef __cplusplus +} +#endif +#endif // NRF_SDM_H__ + +/** + @} +*/ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_soc.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_soc.h new file mode 100644 index 0000000..2c4d958 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_soc.h @@ -0,0 +1,964 @@ +/* + * Copyright (c) 2015 - 2018, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. + */ + +/** + * @defgroup nrf_soc_api SoC Library API + * @{ + * + * @brief APIs for the SoC library. + * + */ + +#ifndef NRF_SOC_H__ +#define NRF_SOC_H__ + +#include <stdint.h> +#include "nrf.h" +#include "nrf_svc.h" +#include "nrf_error.h" +#include "nrf_error_soc.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/**@addtogroup NRF_SOC_DEFINES Defines + * @{ */ + +/**@brief The number of the lowest SVC number reserved for the SoC library. */ +#define SOC_SVC_BASE (0x20) /**< Base value for SVCs that are available when the SoftDevice is disabled. */ +#define SOC_SVC_BASE_NOT_AVAILABLE (0x2C) /**< Base value for SVCs that are not available when the SoftDevice is disabled. */ + +/**@brief Guaranteed time for application to process radio inactive notification. */ +#define NRF_RADIO_NOTIFICATION_INACTIVE_GUARANTEED_TIME_US (62) + +/**@brief The minimum allowed timeslot extension time. */ +#define NRF_RADIO_MINIMUM_TIMESLOT_LENGTH_EXTENSION_TIME_US (200) + +/**@brief The maximum processing time to handle a timeslot extension. */ +#define NRF_RADIO_MAX_EXTENSION_PROCESSING_TIME_US (17) + +/**@brief The latest time before the end of a timeslot the timeslot can be extended. */ +#define NRF_RADIO_MIN_EXTENSION_MARGIN_US (79) + +#define SOC_ECB_KEY_LENGTH (16) /**< ECB key length. */ +#define SOC_ECB_CLEARTEXT_LENGTH (16) /**< ECB cleartext length. */ +#define SOC_ECB_CIPHERTEXT_LENGTH (SOC_ECB_CLEARTEXT_LENGTH) /**< ECB ciphertext length. */ + +#define SD_EVT_IRQn (SWI2_IRQn) /**< SoftDevice Event IRQ number. Used for both protocol events and SoC events. */ +#define SD_EVT_IRQHandler (SWI2_IRQHandler) /**< SoftDevice Event IRQ handler. Used for both protocol events and SoC events. + The default interrupt priority for this handler is set to 4 */ +#define RADIO_NOTIFICATION_IRQn (SWI1_IRQn) /**< The radio notification IRQ number. */ +#define RADIO_NOTIFICATION_IRQHandler (SWI1_IRQHandler) /**< The radio notification IRQ handler. + The default interrupt priority for this handler is set to 4 */ +#define NRF_RADIO_LENGTH_MIN_US (100) /**< The shortest allowed radio timeslot, in microseconds. */ +#define NRF_RADIO_LENGTH_MAX_US (100000) /**< The longest allowed radio timeslot, in microseconds. */ + +#define NRF_RADIO_DISTANCE_MAX_US (128000000UL - 1UL) /**< The longest timeslot distance, in microseconds, allowed for the distance parameter (see @ref nrf_radio_request_normal_t) in the request. */ + +#define NRF_RADIO_EARLIEST_TIMEOUT_MAX_US (128000000UL - 1UL) /**< The longest timeout, in microseconds, allowed when requesting the earliest possible timeslot. */ + +#define NRF_RADIO_START_JITTER_US (2) /**< The maximum jitter in @ref NRF_RADIO_CALLBACK_SIGNAL_TYPE_START relative to the requested start time. */ + +/**@} */ + +/**@addtogroup NRF_SOC_ENUMS Enumerations + * @{ */ + +/**@brief The SVC numbers used by the SVC functions in the SoC library. */ +enum NRF_SOC_SVCS +{ + SD_PPI_CHANNEL_ENABLE_GET = SOC_SVC_BASE, + SD_PPI_CHANNEL_ENABLE_SET = SOC_SVC_BASE + 1, + SD_PPI_CHANNEL_ENABLE_CLR = SOC_SVC_BASE + 2, + SD_PPI_CHANNEL_ASSIGN = SOC_SVC_BASE + 3, + SD_PPI_GROUP_TASK_ENABLE = SOC_SVC_BASE + 4, + SD_PPI_GROUP_TASK_DISABLE = SOC_SVC_BASE + 5, + SD_PPI_GROUP_ASSIGN = SOC_SVC_BASE + 6, + SD_PPI_GROUP_GET = SOC_SVC_BASE + 7, + SD_FLASH_PAGE_ERASE = SOC_SVC_BASE + 8, + SD_FLASH_WRITE = SOC_SVC_BASE + 9, + SD_FLASH_PROTECT = SOC_SVC_BASE + 10, + SD_PROTECTED_REGISTER_WRITE = SOC_SVC_BASE + 11, + SD_MUTEX_NEW = SOC_SVC_BASE_NOT_AVAILABLE, + SD_MUTEX_ACQUIRE = SOC_SVC_BASE_NOT_AVAILABLE + 1, + SD_MUTEX_RELEASE = SOC_SVC_BASE_NOT_AVAILABLE + 2, + SD_RAND_APPLICATION_POOL_CAPACITY_GET = SOC_SVC_BASE_NOT_AVAILABLE + 3, + SD_RAND_APPLICATION_BYTES_AVAILABLE_GET = SOC_SVC_BASE_NOT_AVAILABLE + 4, + SD_RAND_APPLICATION_VECTOR_GET = SOC_SVC_BASE_NOT_AVAILABLE + 5, + SD_POWER_MODE_SET = SOC_SVC_BASE_NOT_AVAILABLE + 6, + SD_POWER_SYSTEM_OFF = SOC_SVC_BASE_NOT_AVAILABLE + 7, + SD_POWER_RESET_REASON_GET = SOC_SVC_BASE_NOT_AVAILABLE + 8, + SD_POWER_RESET_REASON_CLR = SOC_SVC_BASE_NOT_AVAILABLE + 9, + SD_POWER_POF_ENABLE = SOC_SVC_BASE_NOT_AVAILABLE + 10, + SD_POWER_POF_THRESHOLD_SET = SOC_SVC_BASE_NOT_AVAILABLE + 11, + SD_POWER_RAM_POWER_SET = SOC_SVC_BASE_NOT_AVAILABLE + 13, + SD_POWER_RAM_POWER_CLR = SOC_SVC_BASE_NOT_AVAILABLE + 14, + SD_POWER_RAM_POWER_GET = SOC_SVC_BASE_NOT_AVAILABLE + 15, + SD_POWER_GPREGRET_SET = SOC_SVC_BASE_NOT_AVAILABLE + 16, + SD_POWER_GPREGRET_CLR = SOC_SVC_BASE_NOT_AVAILABLE + 17, + SD_POWER_GPREGRET_GET = SOC_SVC_BASE_NOT_AVAILABLE + 18, + SD_POWER_DCDC_MODE_SET = SOC_SVC_BASE_NOT_AVAILABLE + 19, + SD_APP_EVT_WAIT = SOC_SVC_BASE_NOT_AVAILABLE + 21, + SD_CLOCK_HFCLK_REQUEST = SOC_SVC_BASE_NOT_AVAILABLE + 22, + SD_CLOCK_HFCLK_RELEASE = SOC_SVC_BASE_NOT_AVAILABLE + 23, + SD_CLOCK_HFCLK_IS_RUNNING = SOC_SVC_BASE_NOT_AVAILABLE + 24, + SD_RADIO_NOTIFICATION_CFG_SET = SOC_SVC_BASE_NOT_AVAILABLE + 25, + SD_ECB_BLOCK_ENCRYPT = SOC_SVC_BASE_NOT_AVAILABLE + 26, + SD_ECB_BLOCKS_ENCRYPT = SOC_SVC_BASE_NOT_AVAILABLE + 27, + SD_RADIO_SESSION_OPEN = SOC_SVC_BASE_NOT_AVAILABLE + 28, + SD_RADIO_SESSION_CLOSE = SOC_SVC_BASE_NOT_AVAILABLE + 29, + SD_RADIO_REQUEST = SOC_SVC_BASE_NOT_AVAILABLE + 30, + SD_EVT_GET = SOC_SVC_BASE_NOT_AVAILABLE + 31, + SD_TEMP_GET = SOC_SVC_BASE_NOT_AVAILABLE + 32, + SVC_SOC_LAST = SOC_SVC_BASE_NOT_AVAILABLE + 37 +}; + +/**@brief Possible values of a ::nrf_mutex_t. */ +enum NRF_MUTEX_VALUES +{ + NRF_MUTEX_FREE, + NRF_MUTEX_TAKEN +}; + +/**@brief Power modes. */ +enum NRF_POWER_MODES +{ + NRF_POWER_MODE_CONSTLAT, /**< Constant latency mode. See power management in the reference manual. */ + NRF_POWER_MODE_LOWPWR /**< Low power mode. See power management in the reference manual. */ +}; + + +/**@brief Power failure thresholds */ +enum NRF_POWER_THRESHOLDS +{ + NRF_POWER_THRESHOLD_V17 = 4UL, /**< 1.7 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V18, /**< 1.8 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V19, /**< 1.9 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V20, /**< 2.0 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V21, /**< 2.1 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V22, /**< 2.2 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V23, /**< 2.3 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V24, /**< 2.4 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V25, /**< 2.5 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V26, /**< 2.6 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V27, /**< 2.7 Volts power failure threshold. */ + NRF_POWER_THRESHOLD_V28 /**< 2.8 Volts power failure threshold. */ +}; + + + +/**@brief DC/DC converter modes. */ +enum NRF_POWER_DCDC_MODES +{ + NRF_POWER_DCDC_DISABLE, /**< The DCDC is disabled. */ + NRF_POWER_DCDC_ENABLE /**< The DCDC is enabled. */ +}; + +/**@brief Radio notification distances. */ +enum NRF_RADIO_NOTIFICATION_DISTANCES +{ + NRF_RADIO_NOTIFICATION_DISTANCE_NONE = 0, /**< The event does not have a notification. */ + NRF_RADIO_NOTIFICATION_DISTANCE_800US, /**< The distance from the active notification to start of radio activity. */ + NRF_RADIO_NOTIFICATION_DISTANCE_1740US, /**< The distance from the active notification to start of radio activity. */ + NRF_RADIO_NOTIFICATION_DISTANCE_2680US, /**< The distance from the active notification to start of radio activity. */ + NRF_RADIO_NOTIFICATION_DISTANCE_3620US, /**< The distance from the active notification to start of radio activity. */ + NRF_RADIO_NOTIFICATION_DISTANCE_4560US, /**< The distance from the active notification to start of radio activity. */ + NRF_RADIO_NOTIFICATION_DISTANCE_5500US /**< The distance from the active notification to start of radio activity. */ +}; + + +/**@brief Radio notification types. */ +enum NRF_RADIO_NOTIFICATION_TYPES +{ + NRF_RADIO_NOTIFICATION_TYPE_NONE = 0, /**< The event does not have a radio notification signal. */ + NRF_RADIO_NOTIFICATION_TYPE_INT_ON_ACTIVE, /**< Using interrupt for notification when the radio will be enabled. */ + NRF_RADIO_NOTIFICATION_TYPE_INT_ON_INACTIVE, /**< Using interrupt for notification when the radio has been disabled. */ + NRF_RADIO_NOTIFICATION_TYPE_INT_ON_BOTH, /**< Using interrupt for notification both when the radio will be enabled and disabled. */ +}; + +/**@brief The Radio signal callback types. */ +enum NRF_RADIO_CALLBACK_SIGNAL_TYPE +{ + NRF_RADIO_CALLBACK_SIGNAL_TYPE_START, /**< This signal indicates the start of the radio timeslot. */ + NRF_RADIO_CALLBACK_SIGNAL_TYPE_TIMER0, /**< This signal indicates the NRF_TIMER0 interrupt. */ + NRF_RADIO_CALLBACK_SIGNAL_TYPE_RADIO, /**< This signal indicates the NRF_RADIO interrupt. */ + NRF_RADIO_CALLBACK_SIGNAL_TYPE_EXTEND_FAILED, /**< This signal indicates extend action failed. */ + NRF_RADIO_CALLBACK_SIGNAL_TYPE_EXTEND_SUCCEEDED /**< This signal indicates extend action succeeded. */ +}; + +/**@brief The actions requested by the signal callback. + * + * This code gives the SOC instructions about what action to take when the signal callback has + * returned. + */ +enum NRF_RADIO_SIGNAL_CALLBACK_ACTION +{ + NRF_RADIO_SIGNAL_CALLBACK_ACTION_NONE, /**< Return without action. */ + NRF_RADIO_SIGNAL_CALLBACK_ACTION_EXTEND, /**< Request an extension of the current + timeslot. Maximum execution time for this action: + @ref NRF_RADIO_MAX_EXTENSION_PROCESSING_TIME_US. + This action must be started at least + @ref NRF_RADIO_MIN_EXTENSION_MARGIN_US before + the end of the timeslot. */ + NRF_RADIO_SIGNAL_CALLBACK_ACTION_END, /**< End the current radio timeslot. */ + NRF_RADIO_SIGNAL_CALLBACK_ACTION_REQUEST_AND_END /**< Request a new radio timeslot and end the current timeslot. */ +}; + +/**@brief Radio timeslot high frequency clock source configuration. */ +enum NRF_RADIO_HFCLK_CFG +{ + NRF_RADIO_HFCLK_CFG_XTAL_GUARANTEED, /**< The SoftDevice will guarantee that the high frequency clock source is the + external crystal for the whole duration of the timeslot. This should be the + preferred option for events that use the radio or require high timing accuracy. + @note The SoftDevice will automatically turn on and off the external crystal, + at the beginning and end of the timeslot, respectively. The crystal may also + intentionally be left running after the timeslot, in cases where it is needed + by the SoftDevice shortly after the end of the timeslot. */ + NRF_RADIO_HFCLK_CFG_NO_GUARANTEE /**< This configuration allows for earlier and tighter scheduling of timeslots. + The RC oscillator may be the clock source in part or for the whole duration of the timeslot. + The RC oscillator's accuracy must therefore be taken into consideration. + @note If the application will use the radio peripheral in timeslots with this configuration, + it must make sure that the crystal is running and stable before starting the radio. */ +}; + +/**@brief Radio timeslot priorities. */ +enum NRF_RADIO_PRIORITY +{ + NRF_RADIO_PRIORITY_HIGH, /**< High (equal priority as the normal connection priority of the SoftDevice stack(s)). */ + NRF_RADIO_PRIORITY_NORMAL, /**< Normal (equal priority as the priority of secondary activities of the SoftDevice stack(s)). */ +}; + +/**@brief Radio timeslot request type. */ +enum NRF_RADIO_REQUEST_TYPE +{ + NRF_RADIO_REQ_TYPE_EARLIEST, /**< Request radio timeslot as early as possible. This should always be used for the first request in a session. */ + NRF_RADIO_REQ_TYPE_NORMAL /**< Normal radio timeslot request. */ +}; + +/**@brief SoC Events. */ +enum NRF_SOC_EVTS +{ + NRF_EVT_HFCLKSTARTED, /**< Event indicating that the HFCLK has started. */ + NRF_EVT_POWER_FAILURE_WARNING, /**< Event indicating that a power failure warning has occurred. */ + NRF_EVT_FLASH_OPERATION_SUCCESS, /**< Event indicating that the ongoing flash operation has completed successfully. */ + NRF_EVT_FLASH_OPERATION_ERROR, /**< Event indicating that the ongoing flash operation has timed out with an error. */ + NRF_EVT_RADIO_BLOCKED, /**< Event indicating that a radio timeslot was blocked. */ + NRF_EVT_RADIO_CANCELED, /**< Event indicating that a radio timeslot was canceled by SoftDevice. */ + NRF_EVT_RADIO_SIGNAL_CALLBACK_INVALID_RETURN, /**< Event indicating that a radio timeslot signal callback handler return was invalid. */ + NRF_EVT_RADIO_SESSION_IDLE, /**< Event indicating that a radio timeslot session is idle. */ + NRF_EVT_RADIO_SESSION_CLOSED, /**< Event indicating that a radio timeslot session is closed. */ + NRF_EVT_NUMBER_OF_EVTS +}; + +/**@} */ + + +/**@addtogroup NRF_SOC_STRUCTURES Structures + * @{ */ + +/**@brief Represents a mutex for use with the nrf_mutex functions. + * @note Accessing the value directly is not safe, use the mutex functions! + */ +typedef volatile uint8_t nrf_mutex_t; + +/**@brief Parameters for a request for a timeslot as early as possible. */ +typedef struct +{ + uint8_t hfclk; /**< High frequency clock source, see @ref NRF_RADIO_HFCLK_CFG. */ + uint8_t priority; /**< The radio timeslot priority, see @ref NRF_RADIO_PRIORITY. */ + uint32_t length_us; /**< The radio timeslot length (in the range 100 to 100,000] microseconds). */ + uint32_t timeout_us; /**< Longest acceptable delay until the start of the requested timeslot (up to @ref NRF_RADIO_EARLIEST_TIMEOUT_MAX_US microseconds). */ +} nrf_radio_request_earliest_t; + +/**@brief Parameters for a normal radio timeslot request. */ +typedef struct +{ + uint8_t hfclk; /**< High frequency clock source, see @ref NRF_RADIO_HFCLK_CFG. */ + uint8_t priority; /**< The radio timeslot priority, see @ref NRF_RADIO_PRIORITY. */ + uint32_t distance_us; /**< Distance from the start of the previous radio timeslot (up to @ref NRF_RADIO_DISTANCE_MAX_US microseconds). */ + uint32_t length_us; /**< The radio timeslot length (in the range [100..100,000] microseconds). */ +} nrf_radio_request_normal_t; + +/**@brief Radio timeslot request parameters. */ +typedef struct +{ + uint8_t request_type; /**< Type of request, see @ref NRF_RADIO_REQUEST_TYPE. */ + union + { + nrf_radio_request_earliest_t earliest; /**< Parameters for requesting a radio timeslot as early as possible. */ + nrf_radio_request_normal_t normal; /**< Parameters for requesting a normal radio timeslot. */ + } params; /**< Parameter union. */ +} nrf_radio_request_t; + +/**@brief Return parameters of the radio timeslot signal callback. */ +typedef struct +{ + uint8_t callback_action; /**< The action requested by the application when returning from the signal callback, see @ref NRF_RADIO_SIGNAL_CALLBACK_ACTION. */ + union + { + struct + { + nrf_radio_request_t * p_next; /**< The request parameters for the next radio timeslot. */ + } request; /**< Additional parameters for return_code @ref NRF_RADIO_SIGNAL_CALLBACK_ACTION_REQUEST_AND_END. */ + struct + { + uint32_t length_us; /**< Requested extension of the radio timeslot duration (microseconds) (for minimum time see @ref NRF_RADIO_MINIMUM_TIMESLOT_LENGTH_EXTENSION_TIME_US). */ + } extend; /**< Additional parameters for return_code @ref NRF_RADIO_SIGNAL_CALLBACK_ACTION_EXTEND. */ + } params; /**< Parameter union. */ +} nrf_radio_signal_callback_return_param_t; + +/**@brief The radio timeslot signal callback type. + * + * @note In case of invalid return parameters, the radio timeslot will automatically end + * immediately after returning from the signal callback and the + * @ref NRF_EVT_RADIO_SIGNAL_CALLBACK_INVALID_RETURN event will be sent. + * @note The returned struct pointer must remain valid after the signal callback + * function returns. For instance, this means that it must not point to a stack variable. + * + * @param[in] signal_type Type of signal, see @ref NRF_RADIO_CALLBACK_SIGNAL_TYPE. + * + * @return Pointer to structure containing action requested by the application. + */ +typedef nrf_radio_signal_callback_return_param_t * (*nrf_radio_signal_callback_t) (uint8_t signal_type); + +/**@brief AES ECB parameter typedefs */ +typedef uint8_t soc_ecb_key_t[SOC_ECB_KEY_LENGTH]; /**< Encryption key type. */ +typedef uint8_t soc_ecb_cleartext_t[SOC_ECB_CLEARTEXT_LENGTH]; /**< Cleartext data type. */ +typedef uint8_t soc_ecb_ciphertext_t[SOC_ECB_CIPHERTEXT_LENGTH]; /**< Ciphertext data type. */ + +/**@brief AES ECB data structure */ +typedef struct +{ + soc_ecb_key_t key; /**< Encryption key. */ + soc_ecb_cleartext_t cleartext; /**< Cleartext data. */ + soc_ecb_ciphertext_t ciphertext; /**< Ciphertext data. */ +} nrf_ecb_hal_data_t; + +/**@brief AES ECB block. Used to provide multiple blocks in a single call + to @ref sd_ecb_blocks_encrypt.*/ +typedef struct +{ + soc_ecb_key_t const * p_key; /**< Pointer to the Encryption key. */ + soc_ecb_cleartext_t const * p_cleartext; /**< Pointer to the Cleartext data. */ + soc_ecb_ciphertext_t * p_ciphertext; /**< Pointer to the Ciphertext data. */ +} nrf_ecb_hal_data_block_t; + +/**@} */ + +/**@addtogroup NRF_SOC_FUNCTIONS Functions + * @{ */ + +/**@brief Initialize a mutex. + * + * @param[in] p_mutex Pointer to the mutex to initialize. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_MUTEX_NEW, uint32_t, sd_mutex_new(nrf_mutex_t * p_mutex)); + +/**@brief Attempt to acquire a mutex. + * + * @param[in] p_mutex Pointer to the mutex to acquire. + * + * @retval ::NRF_SUCCESS The mutex was successfully acquired. + * @retval ::NRF_ERROR_SOC_MUTEX_ALREADY_TAKEN The mutex could not be acquired. + */ +SVCALL(SD_MUTEX_ACQUIRE, uint32_t, sd_mutex_acquire(nrf_mutex_t * p_mutex)); + +/**@brief Release a mutex. + * + * @param[in] p_mutex Pointer to the mutex to release. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_MUTEX_RELEASE, uint32_t, sd_mutex_release(nrf_mutex_t * p_mutex)); + +/**@brief Query the capacity of the application random pool. + * + * @param[out] p_pool_capacity The capacity of the pool. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_RAND_APPLICATION_POOL_CAPACITY_GET, uint32_t, sd_rand_application_pool_capacity_get(uint8_t * p_pool_capacity)); + +/**@brief Get number of random bytes available to the application. + * + * @param[out] p_bytes_available The number of bytes currently available in the pool. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_RAND_APPLICATION_BYTES_AVAILABLE_GET, uint32_t, sd_rand_application_bytes_available_get(uint8_t * p_bytes_available)); + +/**@brief Get random bytes from the application pool. + * + * @param[out] p_buff Pointer to unit8_t buffer for storing the bytes. + * @param[in] length Number of bytes to take from pool and place in p_buff. + * + * @retval ::NRF_SUCCESS The requested bytes were written to p_buff. + * @retval ::NRF_ERROR_SOC_RAND_NOT_ENOUGH_VALUES No bytes were written to the buffer, because there were not enough bytes available. +*/ +SVCALL(SD_RAND_APPLICATION_VECTOR_GET, uint32_t, sd_rand_application_vector_get(uint8_t * p_buff, uint8_t length)); + +/**@brief Gets the reset reason register. + * + * @param[out] p_reset_reason Contents of the NRF_POWER->RESETREAS register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_POWER_RESET_REASON_GET, uint32_t, sd_power_reset_reason_get(uint32_t * p_reset_reason)); + +/**@brief Clears the bits of the reset reason register. + * + * @param[in] reset_reason_clr_msk Contains the bits to clear from the reset reason register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_POWER_RESET_REASON_CLR, uint32_t, sd_power_reset_reason_clr(uint32_t reset_reason_clr_msk)); + +/**@brief Sets the power mode when in CPU sleep. + * + * @param[in] power_mode The power mode to use when in CPU sleep, see @ref NRF_POWER_MODES. @sa sd_app_evt_wait + * + * @retval ::NRF_SUCCESS The power mode was set. + * @retval ::NRF_ERROR_SOC_POWER_MODE_UNKNOWN The power mode was unknown. + */ +SVCALL(SD_POWER_MODE_SET, uint32_t, sd_power_mode_set(uint8_t power_mode)); + +/**@brief Puts the chip in System OFF mode. + * + * @retval ::NRF_ERROR_SOC_POWER_OFF_SHOULD_NOT_RETURN + */ +SVCALL(SD_POWER_SYSTEM_OFF, uint32_t, sd_power_system_off(void)); + +/**@brief Enables or disables the power-fail comparator. + * + * Enabling this will give a SoftDevice event (NRF_EVT_POWER_FAILURE_WARNING) when the power failure warning occurs. + * The event can be retrieved with sd_evt_get(); + * + * @param[in] pof_enable True if the power-fail comparator should be enabled, false if it should be disabled. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_POWER_POF_ENABLE, uint32_t, sd_power_pof_enable(uint8_t pof_enable)); + + +/**@brief Sets the power failure comparator threshold value. + * + * + * @param[in] threshold The power-fail threshold value to use, see @ref NRF_POWER_THRESHOLDS. + * + * @retval ::NRF_SUCCESS The power failure threshold was set. + * @retval ::NRF_ERROR_SOC_POWER_POF_THRESHOLD_UNKNOWN The power failure threshold is unknown. + */ +SVCALL(SD_POWER_POF_THRESHOLD_SET, uint32_t, sd_power_pof_threshold_set(uint8_t threshold)); + + +/**@brief Writes the NRF_POWER->RAM[index].POWERSET register. + * + * @param[in] index Contains the index in the NRF_POWER->RAM[index].POWERSET register to write to. + * @param[in] ram_powerset Contains the word to write to the NRF_POWER->RAM[index].POWERSET register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_POWER_RAM_POWER_SET, uint32_t, sd_power_ram_power_set(uint8_t index, uint32_t ram_powerset)); + +/**@brief Writes the NRF_POWER->RAM[index].POWERCLR register. + * + * @param[in] index Contains the index in the NRF_POWER->RAM[index].POWERCLR register to write to. + * @param[in] ram_powerclr Contains the word to write to the NRF_POWER->RAM[index].POWERCLR register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_POWER_RAM_POWER_CLR, uint32_t, sd_power_ram_power_clr(uint8_t index, uint32_t ram_powerclr)); + +/**@brief Get contents of NRF_POWER->RAM[index].POWER register, indicates power status of RAM[index] blocks. + * + * @param[in] index Contains the index in the NRF_POWER->RAM[index].POWER register to read from. + * @param[out] p_ram_power Content of NRF_POWER->RAM[index].POWER register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_POWER_RAM_POWER_GET, uint32_t, sd_power_ram_power_get(uint8_t index, uint32_t * p_ram_power)); + +/**@brief Set bits in the general purpose retention registers (NRF_POWER->GPREGRET*). + * + * @param[in] gpregret_id 0 for GPREGRET, 1 for GPREGRET2. + * @param[in] gpregret_msk Bits to be set in the GPREGRET register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_POWER_GPREGRET_SET, uint32_t, sd_power_gpregret_set(uint32_t gpregret_id, uint32_t gpregret_msk)); + +/**@brief Clear bits in the general purpose retention registers (NRF_POWER->GPREGRET*). + * + * @param[in] gpregret_id 0 for GPREGRET, 1 for GPREGRET2. + * @param[in] gpregret_msk Bits to be clear in the GPREGRET register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_POWER_GPREGRET_CLR, uint32_t, sd_power_gpregret_clr(uint32_t gpregret_id, uint32_t gpregret_msk)); + +/**@brief Get contents of the general purpose retention registers (NRF_POWER->GPREGRET*). + * + * @param[in] gpregret_id 0 for GPREGRET, 1 for GPREGRET2. + * @param[out] p_gpregret Contents of the GPREGRET register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_POWER_GPREGRET_GET, uint32_t, sd_power_gpregret_get(uint32_t gpregret_id, uint32_t *p_gpregret)); + +/**@brief Enable or disable the DC/DC regulator. + * + * @param[in] dcdc_mode The mode of the DCDC, see @ref NRF_POWER_DCDC_MODES. + * + * @retval ::NRF_SUCCESS + * @retval ::NRF_ERROR_INVALID_PARAM The DCDC mode is invalid. + */ +SVCALL(SD_POWER_DCDC_MODE_SET, uint32_t, sd_power_dcdc_mode_set(uint8_t dcdc_mode)); + + +/**@brief Request the high frequency crystal oscillator. + * + * Will start the high frequency crystal oscillator, the startup time of the crystal varies + * and the ::sd_clock_hfclk_is_running function can be polled to check if it has started. + * + * @see sd_clock_hfclk_is_running + * @see sd_clock_hfclk_release + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_CLOCK_HFCLK_REQUEST, uint32_t, sd_clock_hfclk_request(void)); + +/**@brief Releases the high frequency crystal oscillator. + * + * Will stop the high frequency crystal oscillator, this happens immediately. + * + * @see sd_clock_hfclk_is_running + * @see sd_clock_hfclk_request + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_CLOCK_HFCLK_RELEASE, uint32_t, sd_clock_hfclk_release(void)); + +/**@brief Checks if the high frequency crystal oscillator is running. + * + * @see sd_clock_hfclk_request + * @see sd_clock_hfclk_release + * + * @param[out] p_is_running 1 if the external crystal oscillator is running, 0 if not. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_CLOCK_HFCLK_IS_RUNNING, uint32_t, sd_clock_hfclk_is_running(uint32_t * p_is_running)); + +/**@brief Waits for an application event. + * + * An application event is either an application interrupt or a pended interrupt when the interrupt + * is disabled. + * + * When the application waits for an application event by calling this function, an interrupt that + * is enabled will be taken immediately on pending since this function will wait in thread mode, + * then the execution will return in the application's main thread. + * + * In order to wake up from disabled interrupts, the SEVONPEND flag has to be set in the Cortex-M + * MCU's System Control Register (SCR), CMSIS_SCB. In that case, when a disabled interrupt gets + * pended, this function will return to the application's main thread. + * + * @note The application must ensure that the pended flag is cleared using ::sd_nvic_ClearPendingIRQ + * in order to sleep using this function. This is only necessary for disabled interrupts, as + * the interrupt handler will clear the pending flag automatically for enabled interrupts. + * + * @note If an application interrupt has happened since the last time sd_app_evt_wait was + * called this function will return immediately and not go to sleep. This is to avoid race + * conditions that can occur when a flag is updated in the interrupt handler and processed + * in the main loop. + * + * @post An application interrupt has happened or a interrupt pending flag is set. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_APP_EVT_WAIT, uint32_t, sd_app_evt_wait(void)); + +/**@brief Get PPI channel enable register contents. + * + * @param[out] p_channel_enable The contents of the PPI CHEN register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_PPI_CHANNEL_ENABLE_GET, uint32_t, sd_ppi_channel_enable_get(uint32_t * p_channel_enable)); + +/**@brief Set PPI channel enable register. + * + * @param[in] channel_enable_set_msk Mask containing the bits to set in the PPI CHEN register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_PPI_CHANNEL_ENABLE_SET, uint32_t, sd_ppi_channel_enable_set(uint32_t channel_enable_set_msk)); + +/**@brief Clear PPI channel enable register. + * + * @param[in] channel_enable_clr_msk Mask containing the bits to clear in the PPI CHEN register. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_PPI_CHANNEL_ENABLE_CLR, uint32_t, sd_ppi_channel_enable_clr(uint32_t channel_enable_clr_msk)); + +/**@brief Assign endpoints to a PPI channel. + * + * @param[in] channel_num Number of the PPI channel to assign. + * @param[in] evt_endpoint Event endpoint of the PPI channel. + * @param[in] task_endpoint Task endpoint of the PPI channel. + * + * @retval ::NRF_ERROR_SOC_PPI_INVALID_CHANNEL The channel number is invalid. + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_PPI_CHANNEL_ASSIGN, uint32_t, sd_ppi_channel_assign(uint8_t channel_num, const volatile void * evt_endpoint, const volatile void * task_endpoint)); + +/**@brief Task to enable a channel group. + * + * @param[in] group_num Number of the channel group. + * + * @retval ::NRF_ERROR_SOC_PPI_INVALID_GROUP The group number is invalid + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_PPI_GROUP_TASK_ENABLE, uint32_t, sd_ppi_group_task_enable(uint8_t group_num)); + +/**@brief Task to disable a channel group. + * + * @param[in] group_num Number of the PPI group. + * + * @retval ::NRF_ERROR_SOC_PPI_INVALID_GROUP The group number is invalid. + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_PPI_GROUP_TASK_DISABLE, uint32_t, sd_ppi_group_task_disable(uint8_t group_num)); + +/**@brief Assign PPI channels to a channel group. + * + * @param[in] group_num Number of the channel group. + * @param[in] channel_msk Mask of the channels to assign to the group. + * + * @retval ::NRF_ERROR_SOC_PPI_INVALID_GROUP The group number is invalid. + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_PPI_GROUP_ASSIGN, uint32_t, sd_ppi_group_assign(uint8_t group_num, uint32_t channel_msk)); + +/**@brief Gets the PPI channels of a channel group. + * + * @param[in] group_num Number of the channel group. + * @param[out] p_channel_msk Mask of the channels assigned to the group. + * + * @retval ::NRF_ERROR_SOC_PPI_INVALID_GROUP The group number is invalid. + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_PPI_GROUP_GET, uint32_t, sd_ppi_group_get(uint8_t group_num, uint32_t * p_channel_msk)); + +/**@brief Configures the Radio Notification signal. + * + * @note + * - The notification signal latency depends on the interrupt priority settings of SWI used + * for notification signal. + * - To ensure that the radio notification signal behaves in a consistent way, the radio + * notifications must be configured when there is no protocol stack or other SoftDevice + * activity in progress. It is recommended that the radio notification signal is + * configured directly after the SoftDevice has been enabled. + * - In the period between the ACTIVE signal and the start of the Radio Event, the SoftDevice + * will interrupt the application to do Radio Event preparation. + * - Using the Radio Notification feature may limit the bandwidth, as the SoftDevice may have + * to shorten the connection events to have time for the Radio Notification signals. + * + * @param[in] type Type of notification signal, see @ref NRF_RADIO_NOTIFICATION_TYPES. + * @ref NRF_RADIO_NOTIFICATION_TYPE_NONE shall be used to turn off radio + * notification. Using @ref NRF_RADIO_NOTIFICATION_DISTANCE_NONE is + * recommended (but not required) to be used with + * @ref NRF_RADIO_NOTIFICATION_TYPE_NONE. + * + * @param[in] distance Distance between the notification signal and start of radio activity, see @ref NRF_RADIO_NOTIFICATION_DISTANCES. + * This parameter is ignored when @ref NRF_RADIO_NOTIFICATION_TYPE_NONE or + * @ref NRF_RADIO_NOTIFICATION_TYPE_INT_ON_INACTIVE is used. + * + * @retval ::NRF_ERROR_INVALID_PARAM The group number is invalid. + * @retval ::NRF_ERROR_INVALID_STATE A protocol stack or other SoftDevice is running. Stop all + * running activities and retry. + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_RADIO_NOTIFICATION_CFG_SET, uint32_t, sd_radio_notification_cfg_set(uint8_t type, uint8_t distance)); + +/**@brief Encrypts a block according to the specified parameters. + * + * 128-bit AES encryption. + * + * @note: + * - The application may set the SEVONPEND bit in the SCR to 1 to make the SoftDevice sleep while + * the ECB is running. The SEVONPEND bit should only be cleared (set to 0) from application + * main or low interrupt level. + * + * @param[in, out] p_ecb_data Pointer to the ECB parameters' struct (two input + * parameters and one output parameter). + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_ECB_BLOCK_ENCRYPT, uint32_t, sd_ecb_block_encrypt(nrf_ecb_hal_data_t * p_ecb_data)); + +/**@brief Encrypts multiple data blocks provided as an array of data block structures. + * + * @details: Performs 128-bit AES encryption on multiple data blocks + * + * @note: + * - The application may set the SEVONPEND bit in the SCR to 1 to make the SoftDevice sleep while + * the ECB is running. The SEVONPEND bit should only be cleared (set to 0) from application + * main or low interrupt level. + * + * @param[in] block_count Count of blocks in the p_data_blocks array. + * @param[in,out] p_data_blocks Pointer to the first entry in a contiguous array of + * @ref nrf_ecb_hal_data_block_t structures. + * + * @retval ::NRF_SUCCESS + */ +SVCALL(SD_ECB_BLOCKS_ENCRYPT, uint32_t, sd_ecb_blocks_encrypt(uint8_t block_count, nrf_ecb_hal_data_block_t * p_data_blocks)); + +/**@brief Gets any pending events generated by the SoC API. + * + * The application should keep calling this function to get events, until ::NRF_ERROR_NOT_FOUND is returned. + * + * @param[out] p_evt_id Set to one of the values in @ref NRF_SOC_EVTS, if any events are pending. + * + * @retval ::NRF_SUCCESS An event was pending. The event id is written in the p_evt_id parameter. + * @retval ::NRF_ERROR_NOT_FOUND No pending events. + */ +SVCALL(SD_EVT_GET, uint32_t, sd_evt_get(uint32_t * p_evt_id)); + +/**@brief Get the temperature measured on the chip + * + * This function will block until the temperature measurement is done. + * It takes around 50 us from call to return. + * + * @param[out] p_temp Result of temperature measurement. Die temperature in 0.25 degrees Celsius. + * + * @retval ::NRF_SUCCESS A temperature measurement was done, and the temperature was written to temp + */ +SVCALL(SD_TEMP_GET, uint32_t, sd_temp_get(int32_t * p_temp)); + +/**@brief Flash Write +* +* Commands to write a buffer to flash +* +* If the SoftDevice is enabled: +* This call initiates the flash access command, and its completion will be communicated to the +* application with exactly one of the following events: +* - @ref NRF_EVT_FLASH_OPERATION_SUCCESS - The command was successfully completed. +* - @ref NRF_EVT_FLASH_OPERATION_ERROR - The command could not be started. +* +* If the SoftDevice is not enabled no event will be generated, and this call will return @ref NRF_SUCCESS when the + * write has been completed +* +* @note +* - This call takes control over the radio and the CPU during flash erase and write to make sure that +* they will not interfere with the flash access. This means that all interrupts will be blocked +* for a predictable time (depending on the NVMC specification in the device's Product Specification +* and the command parameters). +* - The data in the p_src buffer should not be modified before the @ref NRF_EVT_FLASH_OPERATION_SUCCESS +* or the @ref NRF_EVT_FLASH_OPERATION_ERROR have been received if the SoftDevice is enabled. +* - This call will make the SoftDevice trigger a hardfault when the page is written, if it is +* protected. +* +* +* @param[in] p_dst Pointer to start of flash location to be written. +* @param[in] p_src Pointer to buffer with data to be written. +* @param[in] size Number of 32-bit words to write. Maximum size is the number of words in one +* flash page. See the device's Product Specification for details. +* +* @retval ::NRF_ERROR_INVALID_ADDR Tried to write to a non existing flash address, or p_dst or p_src was unaligned. +* @retval ::NRF_ERROR_BUSY The previous command has not yet completed. +* @retval ::NRF_ERROR_INVALID_LENGTH Size was 0, or higher than the maximum allowed size. +* @retval ::NRF_ERROR_FORBIDDEN Tried to write to an address outside the application flash area. +* @retval ::NRF_SUCCESS The command was accepted. +*/ +SVCALL(SD_FLASH_WRITE, uint32_t, sd_flash_write(uint32_t * p_dst, uint32_t const * p_src, uint32_t size)); + + +/**@brief Flash Erase page +* +* Commands to erase a flash page +* If the SoftDevice is enabled: +* This call initiates the flash access command, and its completion will be communicated to the +* application with exactly one of the following events: +* - @ref NRF_EVT_FLASH_OPERATION_SUCCESS - The command was successfully completed. +* - @ref NRF_EVT_FLASH_OPERATION_ERROR - The command could not be started. +* +* If the SoftDevice is not enabled no event will be generated, and this call will return @ref NRF_SUCCESS when the +* erase has been completed +* +* @note +* - This call takes control over the radio and the CPU during flash erase and write to make sure that +* they will not interfere with the flash access. This means that all interrupts will be blocked +* for a predictable time (depending on the NVMC specification in the device's Product Specification +* and the command parameters). +* - This call will make the SoftDevice trigger a hardfault when the page is erased, if it is +* protected. +* +* +* @param[in] page_number Page number of the page to erase +* +* @retval ::NRF_ERROR_INTERNAL If a new session could not be opened due to an internal error. +* @retval ::NRF_ERROR_INVALID_ADDR Tried to erase to a non existing flash page. +* @retval ::NRF_ERROR_BUSY The previous command has not yet completed. +* @retval ::NRF_ERROR_FORBIDDEN Tried to erase a page outside the application flash area. +* @retval ::NRF_SUCCESS The command was accepted. +*/ +SVCALL(SD_FLASH_PAGE_ERASE, uint32_t, sd_flash_page_erase(uint32_t page_number)); + + +/**@brief Flash Protection set + * + * Commands to set the flash protection configuration registers. + This sets the CONFIGx registers of the BPROT peripheral. + * + * @note Not all parameters are valid for all products. Some bits in each parameter may not be + * valid for your product. Please refer your Product Specification for more details. + * + * @note To read the values read them directly. They are only write-protected. + * + * @note It is possible to use @ref sd_protected_register_write instead of this function. + * + * @param[in] block_cfg0 Value to be written to the configuration register. + * @param[in] block_cfg1 Value to be written to the configuration register. + * @param[in] block_cfg2 Value to be written to the configuration register. + * @param[in] block_cfg3 Value to be written to the configuration register. + * + * @retval ::NRF_ERROR_NOT_SUPPORTED Non-zero value supplied to one or more of the unsupported parameters. + * @retval ::NRF_SUCCESS Values successfully written to configuration registers. + */ +SVCALL(SD_FLASH_PROTECT, uint32_t, sd_flash_protect(uint32_t block_cfg0, uint32_t block_cfg1, uint32_t block_cfg2, uint32_t block_cfg3)); + +/**@brief Opens a session for radio timeslot requests. + * + * @note Only one session can be open at a time. + * @note p_radio_signal_callback(@ref NRF_RADIO_CALLBACK_SIGNAL_TYPE_START) will be called when the radio timeslot + * starts. From this point the NRF_RADIO and NRF_TIMER0 peripherals can be freely accessed + * by the application. + * @note p_radio_signal_callback(@ref NRF_RADIO_CALLBACK_SIGNAL_TYPE_TIMER0) is called whenever the NRF_TIMER0 + * interrupt occurs. + * @note p_radio_signal_callback(@ref NRF_RADIO_CALLBACK_SIGNAL_TYPE_RADIO) is called whenever the NRF_RADIO + * interrupt occurs. + * @note p_radio_signal_callback() will be called at ARM interrupt priority level 0. This + * implies that none of the sd_* API calls can be used from p_radio_signal_callback(). + * + * @param[in] p_radio_signal_callback The signal callback. + * + * @retval ::NRF_ERROR_INVALID_ADDR p_radio_signal_callback is an invalid function pointer. + * @retval ::NRF_ERROR_BUSY If session cannot be opened. + * @retval ::NRF_ERROR_INTERNAL If a new session could not be opened due to an internal error. + * @retval ::NRF_SUCCESS Otherwise. + */ + SVCALL(SD_RADIO_SESSION_OPEN, uint32_t, sd_radio_session_open(nrf_radio_signal_callback_t p_radio_signal_callback)); + +/**@brief Closes a session for radio timeslot requests. + * + * @note Any current radio timeslot will be finished before the session is closed. + * @note If a radio timeslot is scheduled when the session is closed, it will be canceled. + * @note The application cannot consider the session closed until the @ref NRF_EVT_RADIO_SESSION_CLOSED + * event is received. + * + * @retval ::NRF_ERROR_FORBIDDEN If session not opened. + * @retval ::NRF_ERROR_BUSY If session is currently being closed. + * @retval ::NRF_SUCCESS Otherwise. + */ + SVCALL(SD_RADIO_SESSION_CLOSE, uint32_t, sd_radio_session_close(void)); + +/**@brief Requests a radio timeslot. + * + * @note The request type is determined by p_request->request_type, and can be one of @ref NRF_RADIO_REQ_TYPE_EARLIEST + * and @ref NRF_RADIO_REQ_TYPE_NORMAL. The first request in a session must always be of type @ref NRF_RADIO_REQ_TYPE_EARLIEST. + * @note For a normal request (@ref NRF_RADIO_REQ_TYPE_NORMAL), the start time of a radio timeslot is specified by + * p_request->distance_us and is given relative to the start of the previous timeslot. + * @note A too small p_request->distance_us will lead to a @ref NRF_EVT_RADIO_BLOCKED event. + * @note Timeslots scheduled too close will lead to a @ref NRF_EVT_RADIO_BLOCKED event. + * @note See the SoftDevice Specification for more on radio timeslot scheduling, distances and lengths. + * @note If an opportunity for the first radio timeslot is not found before 100 ms after the call to this + * function, it is not scheduled, and instead a @ref NRF_EVT_RADIO_BLOCKED event is sent. + * The application may then try to schedule the first radio timeslot again. + * @note Successful requests will result in nrf_radio_signal_callback_t(@ref NRF_RADIO_CALLBACK_SIGNAL_TYPE_START). + * Unsuccessful requests will result in a @ref NRF_EVT_RADIO_BLOCKED event, see @ref NRF_SOC_EVTS. + * @note The jitter in the start time of the radio timeslots is +/- @ref NRF_RADIO_START_JITTER_US us. + * @note The nrf_radio_signal_callback_t(@ref NRF_RADIO_CALLBACK_SIGNAL_TYPE_START) call has a latency relative to the + * specified radio timeslot start, but this does not affect the actual start time of the timeslot. + * @note NRF_TIMER0 is reset at the start of the radio timeslot, and is clocked at 1MHz from the high frequency + * (16 MHz) clock source. If p_request->hfclk_force_xtal is true, the high frequency clock is + * guaranteed to be clocked from the external crystal. + * @note The SoftDevice will neither access the NRF_RADIO peripheral nor the NRF_TIMER0 peripheral + * during the radio timeslot. + * + * @param[in] p_request Pointer to the request parameters. + * + * @retval ::NRF_ERROR_FORBIDDEN If session not opened or the session is not IDLE. + * @retval ::NRF_ERROR_INVALID_ADDR If the p_request pointer is invalid. + * @retval ::NRF_ERROR_INVALID_PARAM If the parameters of p_request are not valid. + * @retval ::NRF_SUCCESS Otherwise. + */ + SVCALL(SD_RADIO_REQUEST, uint32_t, sd_radio_request(nrf_radio_request_t const * p_request)); + +/**@brief Write register protected by the SoftDevice + * + * This function writes to a register that is write-protected by the SoftDevice. Please refer to your + * SoftDevice Specification for more details about which registers that are protected by SoftDevice. + * This function can write to the following protected peripheral: + * - BPROT + * + * @note Protected registers may be read directly. + * @note Register that are write-once will return @ref NRF_SUCCESS on second set, even the value in + * the register has not changed. See the Product Specification for more details about register + * properties. + * + * @param[in] p_register Pointer to register to be written. + * @param[in] value Value to be written to the register. + * + * @retval ::NRF_ERROR_INVALID_ADDR This function can not write to the reguested register. + * @retval ::NRF_SUCCESS Value successfully written to register. + * + */ +SVCALL(SD_PROTECTED_REGISTER_WRITE, uint32_t, sd_protected_register_write(volatile uint32_t * p_register, uint32_t value)); + +/**@} */ + +#ifdef __cplusplus +} +#endif +#endif // NRF_SOC_H__ + +/**@} */ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_svc.h b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_svc.h new file mode 100644 index 0000000..292c692 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/headers/nrf_svc.h @@ -0,0 +1,90 @@ +/* + * Copyright (c) 2012 - 2017, Nordic Semiconductor ASA + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without modification, + * are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form, except as embedded into a Nordic + * Semiconductor ASA integrated circuit in a product or a software update for + * such product, 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. + * + * 3. Neither the name of Nordic Semiconductor ASA nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * 4. This software, with or without modification, must only be used with a + * Nordic Semiconductor ASA integrated circuit. + * + * 5. Any software provided in binary form under this license must not be reverse + * engineered, decompiled, modified and/or disassembled. + * + * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS + * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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 NRF_SVC__ +#define NRF_SVC__ + +#include "stdint.h" + +#ifdef __cplusplus +extern "C" { +#endif + +#ifdef SVCALL_AS_NORMAL_FUNCTION +#define SVCALL(number, return_type, signature) return_type signature +#else + +#ifndef SVCALL +#if defined (__CC_ARM) +#define SVCALL(number, return_type, signature) return_type __svc(number) signature +#elif defined (__GNUC__) +#ifdef __cplusplus +#define GCC_CAST_CPP (uint16_t) +#else +#define GCC_CAST_CPP +#endif +#define SVCALL(number, return_type, signature) \ + _Pragma("GCC diagnostic push") \ + _Pragma("GCC diagnostic ignored \"-Wreturn-type\"") \ + __attribute__((naked)) \ + __attribute__((unused)) \ + static return_type signature \ + { \ + __asm( \ + "svc %0\n" \ + "bx r14" : : "I" (GCC_CAST_CPP number) : "r0" \ + ); \ + } \ + _Pragma("GCC diagnostic pop") + +#elif defined (__ICCARM__) +#define PRAGMA(x) _Pragma(#x) +#define SVCALL(number, return_type, signature) \ +PRAGMA(swi_number = (number)) \ + __swi return_type signature; +#else +#define SVCALL(number, return_type, signature) return_type signature +#endif +#endif // SVCALL + +#endif // SVCALL_AS_NORMAL_FUNCTION + +#ifdef __cplusplus +} +#endif +#endif // NRF_SVC__ diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/hex/s132_nrf52_6.0.0_licence-agreement.txt b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/hex/s132_nrf52_6.0.0_licence-agreement.txt new file mode 100644 index 0000000..a71adee --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/hex/s132_nrf52_6.0.0_licence-agreement.txt @@ -0,0 +1,35 @@ +Copyright (c) 2007 - 2018, Nordic Semiconductor ASA +All rights reserved. + +Redistribution and use in source and binary forms, with or without modification, +are permitted provided that the following conditions are met: + +1. Redistributions of source code must retain the above copyright notice, this + list of conditions and the following disclaimer. + +2. Redistributions in binary form, except as embedded into a Nordic + Semiconductor ASA integrated circuit in a product or a software update for + such product, 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. + +3. Neither the name of Nordic Semiconductor ASA nor the names of its + contributors may be used to endorse or promote products derived from this + software without specific prior written permission. + +4. This software, with or without modification, must only be used with a + Nordic Semiconductor ASA integrated circuit. + +5. Any software provided in binary form under this license must not be reverse + engineered, decompiled, modified and/or disassembled. + +THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS +OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES +OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE +DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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. diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/hex/s132_nrf52_6.0.0_softdevice.hex b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/hex/s132_nrf52_6.0.0_softdevice.hex new file mode 100644 index 0000000..f30de08 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/hex/s132_nrf52_6.0.0_softdevice.hex @@ -0,0 +1,9278 @@ +:020000040000FA +:1000000000040020E90800007D050000C908000088 +:1000100087050000910500009B050000000000001E +:100020000000000000000000000000000D090000BA +:10003000A505000000000000AF050000B9050000A4 +:10004000C3050000CD050000D7050000E105000054 +:10005000EB050000F5050000FF05000009060000A3 +:10006000130600001D0600002706000031060000F0 +:100070003B060000450600004F0600005906000040 +:10008000630600006D060000770600008106000090 +:100090008B060000950600009F060000A9060000E0 +:1000A000B3060000BD060000C7060000D106000030 +:1000B000DB060000E5060000EF060000F906000080 +:1000C000030700000D0700001707000021070000CC +:1000D0002B070000350700003F070000490700001C +:1000E000530700005D07000067070000710700006C +:1000F0007B070000850700008F07000099070000BC +:10010000A30700001FB500F003F88DE80F001FBD26 +:1001100000F0E0BB1FB56FF00100009040100390AD +:10012000029001904FF010208069000B420900F00E +:100130001F045DF822300120A04083434DF8223097 +:10014000684600F045F91FBDF0B54FF6FF734FF458 +:10015000B4751A466E1E11E0A94201D3344600E080 +:100160000C46091B30F8027B641E3B441A44F9D14B +:100170009CB204EB134394B204EB12420029EBD17E +:1001800098B200EB134002EB124140EA0140F0BD8F +:10019000DE4992B00446D1E90001CDE91001FF2209 +:1001A0004021684600F03CFB94E80F008DE80F000A +:1001B000684610A902E004C841F8042D8842FAD12B +:1001C00010216846FFF7C0FF1090AA208DF8440068 +:1001D000FFF7A0FF00F0F3F84FF01024A069102201 +:1001E0006946803000F002F9A069082210A900F0E9 +:1001F000FDF800F0D8F84FF080510A6949690068AD +:100200004A43824201D8102070470020704710B541 +:10021000D0E900214FF0805002EB8103026944696C +:100220006243934209D84FF01022536903EB8103D4 +:100230000169406941438B4201D9092010BD5069D1 +:10024000401C01D0002010BD0F2010BD70B501680A +:100250000446AF4D4FF01020072952D2DFE801F0DD +:10026000330419293C1E2500D4E902656468294637 +:10027000304600F0CDF82A462146304600F0B6F868 +:10028000AA002146304600F09FFA002800D0032043 +:1002900070BD00F051FB4FF4805007E0201DFFF7C8 +:1002A000AAFF0028F4D100F047FB60682860002016 +:1002B00070BD241D94E80700920000F085FA002824 +:1002C000F6D00E2070BD8069401C12D0201DFFF7B3 +:1002D0009EFF0028F6D109E08069401C09D0201D4E +:1002E000FFF789FF0028EDD1606820B12046FFF7B5 +:1002F0004FFF042070BDFFF70DFF00F060F800F025 +:1003000052F8072070BD10B50C46182802D0012005 +:10031000086010BD2068FFF799FF206010BD4FF006 +:100320001024A069401C05D0A569A66980353079E4 +:10033000AA2808D06069401C2DD060690068401C64 +:1003400029D060692CE010212846FFF7FDFE3168B6 +:1003500081421CD1A16901F18002C03105E030B1B8 +:1003600008CA51F8040D984201D1012000E0002094 +:100370008A42F4D158B1286810B1042803D0FEE7AE +:10038000284600F057F862496868086008E000F005 +:1003900016F800F008F84FF480500168491C01D0AD +:1003A00000F0A4FAFEE7BFF34F8F5A4801685A4A9B +:1003B00001F4E06111430160BFF34F8FFEE74FF09E +:1003C00010208169491C02D0806900F0AEB87047E6 +:1003D000524A01681160121D416811604F4A8168DC +:1003E00010321160111DC068086070472DE9F0419E +:1003F00017460D460646002406E03046296800F000 +:10040000A7F8641C2D1D361DBC42F6D3BDE8F08153 +:1004100070B50C4605464FF4806608E0284600F0AB +:1004200084F8B44205D3A4F5806405F58055002C0A +:10043000F4D170BD4168044609B1012500E00025F2 +:100440004FF010267069A268920000F0BDF9C8B1A3 +:10045000204600F01AF89DB17669A56864684FF4EB +:10046000002084420AD2854208D229463046FFF74E +:10047000CFFF2A4621463046FFF7B8FFFFF79FFF20 +:10048000FFF791FFFFF746FEF8E72DE9FF414FF038 +:100490001024616980680D0B01EB800000F6FF708D +:1004A000010B0020009001900290024603906846E4 +:1004B00001230BE0560902F01F0C50F8267003FAD6 +:1004C0000CFC47EA0C0740F82670521CAA42F1D3F4 +:1004D0000AE04A0901F01F0650F8225003FA06F616 +:1004E000354340F82250491C8029F2D3A169090BF9 +:1004F0004A0901F01F0150F822408B409C4340F80C +:100500002240FFF765FFBDE8FF8100005C090000A5 +:10051000000000200CED00E00400FA050006004099 +:10052000144801680029FCD07047134A0221116069 +:1005300010490B68002BFCD00F4B1B1D186008687E +:100540000028FCD00020106008680028FCD070470C +:10055000094B10B501221A60064A1468002CFCD021 +:10056000016010680028FCD0002018601068002886 +:10057000FCD010BD00E4014004E5014008208F4993 +:1005800009680958084710208C4909680958084724 +:1005900014208A49096809580847182087490968BA +:1005A0000958084730208549096809580847382004 +:1005B00082490968095808473C2080490968095858 +:1005C000084740207D4909680958084744207B496D +:1005D00009680958084748207849096809580847B0 +:1005E0004C20764909680958084750207349096822 +:1005F0000958084754207149096809580847582084 +:100600006E490968095808475C206C49096809580F +:100610000847602069490968095808476420674904 +:100620000968095808476820644909680958084753 +:100630006C20624909680958084770205F490968B9 +:100640000958084774205D49096809580847782007 +:100650005A490968095808477C20584909680958C7 +:10066000084780205549096809580847842053499C +:1006700009680958084788205049096809580847F7 +:100680008C204E4909680958084790204B49096851 +:10069000095808479420494909680958084798208B +:1006A00046490968095808479C204449096809587F +:1006B0000847A0204149096809580847A4203F4934 +:1006C000096809580847A8203C490968095808479B +:1006D000AC203A49096809580847B02037490968E9 +:1006E00009580847B4203549096809580847B8200F +:1006F0003249096809580847BC2030490968095837 +:100700000847C0202D49096809580847C4202B49CB +:10071000096809580847C82028490968095808473E +:10072000CC202649096809580847D0202349096880 +:1007300009580847D4202149096809580847D82092 +:100740001E49096809580847DC201C4909680958EE +:100750000847E0201949096809580847E420174963 +:10076000096809580847E8201449096809580847E2 +:10077000EC201249096809580847F0200F49096818 +:1007800009580847F4200D49096809580847F82016 +:100790000A49096809580847FC20084909680958A6 +:1007A00008475FF480700549096809580847000048 +:1007B00003480449024A034B704700000000002030 +:1007C000680900006809000040EA010310B59B07B2 +:1007D0000FD1042A0DD310C808C9121F9C42F8D0AB +:1007E00020BA19BA884201D9012010BD4FF0FF305C +:1007F00010BD1AB1D30703D0521C07E0002010BD72 +:1008000010F8013B11F8014B1B1B07D110F8013BFD +:1008100011F8014B1B1B01D1921EF1D1184610BDDE +:1008200002F0FF0343EA032242EA024200F005B865 +:100830007047704770474FF000020429C0F01280E3 +:1008400010F0030C00F01B80CCF1040CBCF1020F83 +:1008500018BF00F8012BA8BF20F8022BA1EB0C0158 +:1008600000F00DB85FEAC17C24BF00F8012B00F84E +:10087000012B48BF00F8012B70474FF0000200B574 +:10088000134694469646203922BFA0E80C50A0E8B3 +:100890000C50B1F12001BFF4F7AF090728BFA0E861 +:1008A0000C5048BF0CC05DF804EB890028BF40F82D +:1008B000042B08BF704748BF20F8022B11F0804F6F +:1008C00018BF00F8012B7047014B1B68DB68184705 +:1008D0000000002009480A497047FFF7FBFFFFF7B7 +:1008E00011FC00BD20BFFDE7064B1847064A10600B +:1008F000016881F30888406800470000680900002B +:10090000680900001F030000000000201EF0040F13 +:100910000CBFEFF30881EFF3098188690238007892 +:10092000182803D100E00000074A1047074A126860 +:100930002C3212681047000000B5054B1B68054AB1 +:100940009B58984700BD00000703000000000020EE +:100950005809000004000000001000000000000022 +:0809600000FFFFFF0090D0032F +:10100000E0120020D1430200192F000043430200E8 +:10101000192F0000192F0000192F000000000000F8 +:101020000000000000000000000000002944020051 +:10103000192F000000000000192F0000192F0000D8 +:101040009144020097440200192F0000192F00005C +:10105000192F0000192F0000192F0000192F000070 +:101060009D440200192F0000192F0000A344020024 +:10107000192F0000A9440200AF440200B544020049 +:10108000192F0000192F0000192F0000192F000040 +:10109000192F0000192F0000192F0000192F000030 +:1010A000192F0000BB440200192F0000192F000067 +:1010B000192F0000192F0000192F0000192F000010 +:1010C000C1440200192F0000192F0000192F000041 +:1010D000192F0000192F0000192F0000192F0000F0 +:1010E000192F0000192F0000192F0000192F0000E0 +:1010F000192F0000192F0000192F0000192F0000D0 +:10110000192F0000192F000000F002F823F04DF90C +:101110000AA090E8000C82448344AAF10107DA4552 +:1011200001D123F042F9AFF2090EBAE80F0013F033 +:10113000010F18BFFB1A43F0010318479038020053 +:10114000B03802000A444FF0000C10F8013B13F0D5 +:10115000070408BF10F8014B1D1108BF10F8015B10 +:10116000641E05D010F8016B641E01F8016BF9D103 +:1011700013F0080F1EBF10F8014BAD1C0C1B09D15A +:101180006D1E58BF01F801CBFAD505E014F8016BCC +:1011900001F8016B6D1EF9D59142D6D3704700005E +:1011A0000023002400250026103A28BF78C1FBD870 +:1011B000520728BF30C148BF0B6070471FB500F011 +:1011C0003DF88DE80F001FBD1EF0040F0CBFEFF3BC +:1011D0000880EFF30980014A10470000752E0000D7 +:1011E0008269034981614FF001001044704700009B +:1011F000F511000001B41EB400B512F00FFE01B4E9 +:101200000198864601BC01B01EBD0000F0B4404606 +:10121000494652465B460FB402A0013001B506486C +:10122000004700BF01BC86460FBC804689469246F7 +:101230009B46F0BC704700000911000023F0B2B8D3 +:1012400070B51A4C054609202070A01C00F05FF80C +:101250005920A08029462046BDE8704008F05CB8BF +:1012600008F065B870B50C461149097829B1A0F1AC +:1012700060015E2908D3012013E0602804D06928AA +:1012800002D043F201000CE020CC0A4E94E80E009C +:1012900006EB8000A0F58050241FD0F8806E284611 +:1012A000B047206070BD012070470000080000209A +:1012B0001C0000202845020010B504460021012032 +:1012C00000F03DF800210B2000F039F8042119202E +:1012D00000F035F804210D2000F031F804210E2033 +:1012E00000F02DF804210F2000F029F80421C84354 +:1012F00000F025F80621162000F021F8062115201F +:1013000000F01DF82046FFF79BFF002010BDA8212C +:1013100001807047FFF7A4BF11487047104870471D +:10132000104A10B514680F4B0F4A08331A60FFF7C4 +:1013300099FF0C48001D046010BD704770474907B5 +:10134000090E002806DA00F00F0000F1E02080F816 +:10135000141D704700F1E02080F800147047000071 +:1013600003F900421005024001000001FE4800217F +:1013700001604160018170472DE9F743044692B056 +:101380009146406813F00EF840B1606813F013F80E +:1013900020B9607800F00300022801D0012000E0AD +:1013A0000020F14E3072484612F0B8FF18B11020FC +:1013B00015B0BDE8F0834946012001F018FF002870 +:1013C000F6D101258DF842504FF4C050ADF84000E1 +:1013D000002210A9284606F047FC0028E8D18DF825 +:1013E00042504FF428504FF00008ADF840004746F7 +:1013F0001C216846CDF81C8022F07BFF9DF81C0064 +:1014000008AA20F00F00401C20F0F00010308DF8EA +:101410001C0020788DF81D0061789DF81E0061F396 +:10142000420040F001008DF81E009DF800000AA95E +:1014300040F002008DF800002089ADF83000ADF8D2 +:101440003270608907AFADF834000B97606810AC5C +:101450000E900A94684606F0FCF90028A8D1BDF861 +:10146000200030808DF8425042F60120ADF8400057 +:101470009DF81E0008AA20F00600801C20F0010044 +:101480008DF81E000220ADF83000ADF8340013A82E +:101490000E900AA9684606F0DCF9002888D1BDF84C +:1014A00020007080311D484600F033F9002887D1B4 +:1014B0008DF8425042F6A620ADF840001C21684647 +:1014C000CDF81C8022F015FF9DF81C00ADF83450BB +:1014D00020F00F00401C20F0F00010308DF81C00B0 +:1014E0009DF81D0008AA20F0FF008DF81D009DF852 +:1014F0001E000AA920F0060040F00100801C8DF8B3 +:101500001E009DF800008DF8445040F002008DF858 +:101510000000CDE90A4711A80E90ADF8305068469A +:1015200006F097F9002899D1BDF82000F08000203E +:101530003EE73EB504460820ADF80000204612F014 +:10154000EDFE08B110203EBD2146012001F04FFE06 +:101550000028F8D12088ADF804006088ADF80600B6 +:10156000A088ADF80800E088ADF80A007E4801AB1D +:101570006A468088002106F071FDBDF80010082938 +:10158000E1D003203EBD1FB5044600200290082094 +:10159000ADF80800CDF80CD0204612F0BFFE10B117 +:1015A000102004B010BD704802AA81884FF6FF7069 +:1015B00006F096FF0028F4D1BDF80810082901D0E4 +:1015C0000320EEE7BDF800102180BDF80210618015 +:1015D000BDF80410A180BDF80610E180E1E701B577 +:1015E00082B00220ADF800005F4802AB6A46408836 +:1015F000002106F033FDBDF80010022900D00320C1 +:101600000EBD1CB5002100910221ADF80010019023 +:1016100012F0AAFE08B110201CBD53486A4641884A +:101620004FF6FF7006F05CFFBDF800100229F3D002 +:1016300003201CBDFEB54C4C06461546207A0F46CD +:10164000C00705D0084612F069FE18B11020FEBD93 +:101650000F20FEBDF82D01D90C20FEBD304612F042 +:101660005DFE18BB208801A905F03CFE0028F4D1DE +:1016700030788DF80500208801A906F0CEFC0028FE +:10168000EBD100909DF800009DF8051040F002009D +:101690008DF80000090703D040F008008DF8000025 +:1016A0002088694606F056FC0028D6D1ADF80850CF +:1016B00020883B4602AA002106F0D0FCBDF80810A5 +:1016C000A942CAD00320FEBD7CB50546002000908B +:1016D00001900888ADF800000C462846019512F0EC +:1016E00061FE18B9204612F03FFE08B110207CBD03 +:1016F00015B1BDF8000050B11B486A4601884FF68D +:10170000FF7006F0EDFEBDF8001021807CBD0C20BE +:101710007CBD30B593B0044600200D4600901421E6 +:1017200001A822F0E6FD1C2108A822F0E2FD9DF8A8 +:101730000000CDF808D020F00F00401C20F0F00091 +:1017400010308DF800009DF8010020F0FF008DF8AA +:1017500001009DF8200040F002008DF820000120DB +:101760008DF8460002E000000C02002042F6042042 +:10177000ADF8440011A801902088ADF83C006088C5 +:10178000ADF83E00A088ADF84000E088ADF842001A +:101790009DF8020006AA20F00600801C20F001003F +:1017A0008DF802000820ADF80C00ADF810000FA86D +:1017B000059001A908A806F04CF8002803D1BDF84F +:1017C00018002880002013B030BD0000F0B5007B69 +:1017D000059F1E4614460D46012800D0FFDF0C2051 +:1017E00030803A203880002C08D0287A032806D090 +:1017F000287B012800D0FFDF17206081F0BDA88979 +:10180000FBE72DE9F04786B0144691F80C900E9A4C +:101810000D46B9F1010F0BD01021007B2E8A8846AE +:10182000052807D0062833D0FFDF06B0BDE8F087D3 +:101830000221F2E7E8890C2100EB400001EB4000B7 +:10184000188033201080002CEFD0E88960810027B9 +:101850001AE00096688808F1020301AA696900F09D +:1018600084FF06EB0800801C07EB470186B204EBFF +:101870004102BDF8040090810DF1060140460E3290 +:1018800010F018FE7F1CBFB26089B842E1D8CCE7E7 +:1018900034201080E889B9F1010F11D0122148439A +:1018A0000E301880002CC0D0E88960814846B9F11C +:1018B000010F00D00220207300270DF1040A1FE061 +:1018C0000621ECE70096688808F1020301AA69691D +:1018D00000F04BFF06EB0800801C86B2B9F1010F47 +:1018E00012D007EBC70004EB4000BDF80410C18123 +:1018F00010220AF10201103022F05AFC7F1CBFB204 +:101900006089B842DED890E707EB470104EB41025B +:10191000BDF80400D0810AF102014046103210F0F7 +:10192000C9FDEBE72DE9F0470E4688B090F80CC0F2 +:1019300096F80C80378AF5890C20109902F10C0476 +:101940004FF0000ABCF1030F08D0BCF1040F3ED0E9 +:10195000BCF1070F7DD0FFDF08B067E705EB850C12 +:1019600000EB4C00188031200880002AF4D0A8F148 +:10197000060000F0FF09558125E0182101A822F09A +:10198000B8FC00977088434601AA716900F0EDFE2B +:10199000BDF804002080BDF80600E080BDF8080016 +:1019A0002081A21C0DF10A01484610F083FDB9F117 +:1019B000000F00D018B184F804A0A4F802A007EB2F +:1019C000080087B20A346D1EADB2D6D2C4E705EB6B +:1019D000850C00EB4C00188032200880002ABBD018 +:1019E000A8F1050000F0FF09558137E000977088E5 +:1019F000434601AA716900F0B8FE9DF80600BDF8E3 +:101A00000410E1802179420860F3000162F3410192 +:101A1000820862F38201C20862F3C301020962F321 +:101A20000411420962F34511820962F386112171A2 +:101A3000C0096071BDF80700208122460DF109013F +:101A4000484610F037FD18B184F802A0A4F800A0B1 +:101A500000E007E007EB080087B20A346D1EADB264 +:101A6000C4D279E7A8F1020084B205FB08F000F1C6 +:101A70000E0CA3F800C035230B80002AA6D0558198 +:101A80009481009783B270880E32716900F06DFE08 +:101A900062E72DE9F84F1E460A9D0C4681462AB1A1 +:101AA000607A00F58070D080E089108199F80C0090 +:101AB0000C274FF000084FF00E0A0D2873D2DFE814 +:101AC00000F09E070E1C28303846556A7373730069 +:101AD000214648460095FFF779FEBDE8F88F207B48 +:101AE0009146082802D0032800D0FFDF378030203D +:101AF0000AE000BFA9F80A80EFE7207B914604289E +:101B000000D0FFDF378031202880B9F1000FF1D1FC +:101B1000E3E7207B9146042800D0FFDF37803220A6 +:101B2000F2E7207B9146022800D0FFDF3780332088 +:101B3000EAE7207B1746022800D0FFDF3420A6F812 +:101B400000A02880002FC8D0A7F80A80C5E7207B16 +:101B50001746042800D0FFDF3520A6F800A0288013 +:101B6000002FBAD04046A7F80A8012E0207B174623 +:101B7000052802D0062800D0FFDF10203080362054 +:101B80002880002FA9D0E0897881A7F80E80B9F8C5 +:101B90000E00B881A1E7207B9146072800D0FFDF27 +:101BA00037803720B0E72AE04FF0120018804FF05E +:101BB00038001700288090D0E0897881A7F80E803F +:101BC000A7F8108099F80C000A2805D00B2809D036 +:101BD0000C280DD0FFDF80E7207B0A2800D0FFDF34 +:101BE00001200AE0207B0B2800D0FFDF042004E066 +:101BF000207B0C2800D0FFDF052038736DE7FFDF66 +:101C00006BE770B50C46054601F025FC20B1007865 +:101C1000222804D2082070BD43F2020070BD0521C5 +:101C200028460EF0C5FE206008B1002070BD0320DC +:101C300070BD30B44880087820F00F00C01C20F040 +:101C4000F000903001F8080B1DCA81E81D0030BC7F +:101C500007F0E3BB2DE9FF4784B0002782460297D7 +:101C600007989046894612300AF014F9401D20F07A +:101C70000306079828B907A95046FFF7C2FF0028B6 +:101C800054D1B9F1000F05D00798017B19BB052588 +:101C900004681BE098F80000092803D00D2812D032 +:101CA000FFDF46E0079903254868B0B3497B4288C7 +:101CB0007143914239D98AB2B3B2011D0EF0EBFCE7 +:101CC0000446078002E0079C042508340CB12088F4 +:101CD00010B1032D29D02CE00798012112300AF011 +:101CE0000BF9ADF80C00024602AB2946504608F04D +:101CF000F0F9070001D1A01C029007983A46123073 +:101D0000C8F80400A8F802A003A94046029B0AF004 +:101D100000F9D8B10A2817D200E006E0DFE800F0A9 +:101D200007091414100B0D141412132014E60020CC +:101D300012E6112010E608200EE643F203000BE63F +:101D4000072009E60D2007E6032005E6BDF80C0094 +:101D50002346CDE900702A465046079900F015FD4C +:101D600057B9032D08D10798B3B2417B406871433E +:101D70008AB2011D0EF0A3FCB9F1000FD7D007996C +:101D800081F80C90D3E72DE9FE4F91461A881C4646 +:101D90008A468046FAB102AB494608F09AF9050036 +:101DA00019D04046A61C27880EF046FF324607266B +:101DB00029463B4600960EF054FB20882346CDE989 +:101DC00000504A465146404600F0DFFC002020808B +:101DD0000120BDE8FE8F0020FBE710B586B01C4651 +:101DE000AAB104238DF800301388ADF8083052886A +:101DF000ADF80A208A788DF80E200988ADF80C100D +:101E000000236A462146FFF725FF06B010BD1020CB +:101E1000FBE770B50D4605210EF0CAFD040000D1A8 +:101E2000FFDF294604F11200BDE870400AF04DB80A +:101E30002DE9F8430D468046002607F0EBFA0446EC +:101E40002878102878D2DFE800F0773B345331311E +:101E5000123131310831313131312879001FC0B2AE +:101E6000022801D0102810D114BBFFDF35E004B9DF +:101E7000FFDF052140460EF09BFD007B032806D0C6 +:101E800004280BD0072828D0FFDF072655E0287943 +:101E9000801FC0B2022820D050B1F6E72879401F39 +:101EA000C0B2022819D0102817D0EEE704B9FFDF1E +:101EB00013E004B9FFDF287901280ED1172137E09C +:101EC000052140460EF074FD070000D1FFDF07F149 +:101ED0001201404609F0D6FF2CB12A462146404661 +:101EE000FFF7A7FE29E01321404602F0A7FD24E0FA +:101EF00004B9FFDF052140460EF05AFD060000D16F +:101F0000FFDF694606F1120009F0C6FF060000D0A7 +:101F1000FFDFA988172901D2172200E00A46BDF881 +:101F20000000824202D9014602E005E01729C5D32C +:101F3000404600F03AFCD0E7FFDF3046BDE8F883CA +:101F4000401D20F0030219B102FB01F0001D00E06A +:101F500000201044704713B5009848B1002468462B +:101F60000EF043FB002C02D1F74A009911601CBD12 +:101F700001240020F4E72DE9F0470C461546242102 +:101F8000204622F0B6F905B9FFDFA87860732888EB +:101F9000DFF8B4A3401D20F00301AF788946DAF8DA +:101FA00000000EF040FB060000D1FFDF4FF00008FC +:101FB0002660A6F8008077B109FB07F1091D0AD059 +:101FC000DAF800000EF02FFB060000D1FFDF66609C +:101FD000C6F8008001E0C4F80480298804F11200EA +:101FE000BDE8F04709F040BF2DE9F047804601F118 +:101FF00012000D46814609F04DFF401DD24F20F0E2 +:1020000003026E7B1446296838680EF037FB3EB138 +:1020100004FB06F2121D03D0696838680EF02EFB2F +:1020200005200EF06DFC044605200EF071FC201A10 +:10203000012802D138680EF0EBFA49464046BDE867 +:10204000F04709F026BF70B5054605210EF0B0FC3B +:10205000040000D1FFDF04F112012846BDE8704002 +:1020600009F010BF2DE9F04F91B04FF0000BADF823 +:1020700034B0ADF804B047880C46054692460521B9 +:1020800038460EF095FC060000D1FFDF24B1A78092 +:10209000A4F806B0A4F808B0297809220B20B2EB06 +:1020A000111F7DD12A7A04F1100138274FF00C0856 +:1020B0004FF001090391102A73D2DFE802F072F2A7 +:1020C000F1F07F08D2888D9F3DDBF3EEB6B6307B12 +:1020D000022800D0FFDFA88908EBC001ADF804108A +:1020E0003021ADF83410002C25D06081B5F80E9069 +:1020F00000271DE004EBC708317C88F80E10F18939 +:10210000A8F80C10CDF800906888042304AA296967 +:1021100000F02BFBBDF81010A8F8101009F1040016 +:10212000BDF812107F1C1FFA80F9A8F81210BFB278 +:102130006089B842DED80DE1307B022800D0FFDF95 +:10214000E98908EBC100ADF804003020ADF8340097 +:10215000287B0A90001FC0B20F90002CEBD0618149 +:10216000B5F81090002725E0CDF8009068886969DF +:1021700003AA0A9B00F0F9FA0A9804EBC70848443E +:102180001FFA80F908F10C0204A90F9810F092F9D7 +:1021900018B188F80EB0A8F80CB0BDF80C1001E02A +:1021A000D4E0CFE0A8F81010BDF80E107F1CA8F8FE +:1021B0001210BFB26089B842D6D8CBE00DA800900B +:1021C00001AB224629463046FFF71BFBC2E0307BBD +:1021D000082805D0FFDF03E0307B082800D0FFDFB0 +:1021E000E8891030ADF804003620ADF83400002C3A +:1021F0003FD0A9896181F189A18127E0307B09283D +:1022000000D0FFDFA88900F10C01ADF804103721E0 +:10221000ADF83410002C2CD06081E8890090AB8997 +:10222000688804F10C02296956E0E88939211030E8 +:1022300080B2ADF80400ADF83410002C74D0A98938 +:102240006181287A0E280AD002212173E989E1816F +:10225000288A0090EB8968886969039A3CE001212B +:10226000F3E70DA8009001AB224629463046FFF760 +:1022700059FB6FE0307B0A2800D0FFDF1220ADF859 +:102280000400ADF834704CB3A9896181A4F810B092 +:10229000A4F80EB084F80C905CE020E002E031E09D +:1022A00039E042E0307B0B2800D0FFDF288AADF810 +:1022B00034701230ADF8040084B104212173A9896F +:1022C0006181E989E181298A2182688A00902B8ACB +:1022D000688804F11202696900F047FA3AE0307B3D +:1022E0000C2800D0FFDF1220ADF80400ADF83470E8 +:1022F0003CB305212173A4F80AB0A4F80EB0A4F8E9 +:1023000010B027E00DA8009001AB224629463046C8 +:10231000FFF75CFA1EE00DA8009001AB22462946AB +:102320003046FFF7B6FB15E034E03B21ADF8040082 +:10233000ADF8341074B3A4F80690A4F808B084F88B +:102340000AB007E0FFDF05E010000020297A01292C +:1023500017D0FFDFBDF80400AAF800006CB1BDF88B +:1023600034002080BDF804006080BDF834003928B6 +:1023700003D03C2801D086F80CB011B00020BDE895 +:10238000F08F3C21ADF80400ADF8341014B1697A37 +:10239000A172DFE7AAF80000EFE72DE9F8435688BD +:1023A0000F4680461546052130460EF001FB04001D +:1023B00000D1FFDF123400943B46414630466A6844 +:1023C00009F0DBFEBAE570B50D4605210EF0F0FA16 +:1023D000040000D1FFDF294604F11200BDE870407F +:1023E00009F065BD70B50D4605210EF0E1FA040057 +:1023F00000D1FFDF294604F11200BDE8704009F06A +:1024000083BD70B5054605210EF0D2FA040000D157 +:10241000FFDF04F1080321462846BDE8704004228E +:10242000B1E470B5054605210EF0C2FA040000D1F2 +:10243000FFDF214628462368BDE870400522A2E45C +:1024400070B5064605210EF0B3FA040000D1FFDF97 +:1024500004F1120009F01EFD401D20F0030511E0FB +:10246000011D00880322431821463046FFF78BFCEC +:1024700000280BD0607BABB2684382B26068011D5C +:102480000EF053F9606841880029E9D170BD70B53C +:102490000E46054606F0BEFF040000D1FFDF012016 +:1024A000207266726580207820F00F00C01C20F03A +:1024B000F00030302070BDE8704006F0AEBF2DE96E +:1024C000F0438BB00D461446814606A9FFF799FBF1 +:1024D000002814D14FF6FF7601274FF420588CB115 +:1024E00003208DF800001020ADF8100007A805901B +:1024F00007AA204604A90FF0FCFF78B107200BB013 +:10250000BDE8F0830820ADF808508DF80E708DF806 +:102510000000ADF80A60ADF80C800CE00698A178D8 +:1025200001742188C1818DF80E70ADF80850ADF8A6 +:102530000C80ADF80A606A4602214846069BFFF708 +:1025400089FBDCE708B501228DF8022042F6020281 +:10255000ADF800200A4603236946FFF73EFC08BD9C +:1025600008B501228DF8022042F60302ADF80020E2 +:102570000A4604236946FFF730FC08BD00B587B062 +:1025800079B102228DF800200A88ADF80820498828 +:10259000ADF80A1000236A460521FFF75BFB07B080 +:1025A00000BD1020FBE709B1072316E407207047A0 +:1025B00070B588B00D461446064606A9FFF721FB04 +:1025C00000280ED17CB10620ADF808508DF800002F +:1025D000ADF80A40069B6A460821DC813046FFF7C9 +:1025E00039FB08B070BD05208DF80000ADF808502B +:1025F000F0E700B587B059B107238DF80030ADF88A +:102600000820039100236A460921FFF723FBC6E750 +:102610001020C4E770B588B00C460646002506A910 +:10262000FFF7EFFA0028DCD106980121123009F0FB +:1026300063FC9CB12178062921D2DFE801F0200556 +:1026400005160318801E80B2C01EE28880B20AB14F +:10265000A3681BB1824203D90C20C2E71020C0E757 +:10266000042904D0A08850B901E00620B9E7012967 +:1026700013D0022905D004291CD005292AD007200F +:10268000AFE709208DF800006088ADF80800E08809 +:10269000ADF80A00A068039023E00A208DF800003E +:1026A0006088ADF80800E088ADF80A00A0680A2547 +:1026B000039016E00B208DF800006088ADF808004C +:1026C000A088ADF80A00E088ADF80C00A0680B25E2 +:1026D000049006E00C208DF8000060788DF808006A +:1026E0000C256A4629463046069BFFF7B3FA78E781 +:1026F00000B587B00D228DF80020ADF8081000233A +:102700006A461946FFF7A6FA49E700B587B071B1E6 +:1027100002228DF800200A88ADF808204988ADF81B +:102720000A1000236A460621FFF794FA37E71020C3 +:1027300035E770B586B0064601200D46ADF80810A5 +:102740008DF80000014600236A463046FFF782FA02 +:10275000040008D12946304605F09AFC0021304695 +:1027600005F0B4FC204606B070BDF8B51C46154611 +:102770000E46069F0EF04EFA2346FF1DBCB23146B0 +:102780002A4600940DF039FEF8BD30B41146DDE95B +:1027900002423CB1032903D0002330BC08F022BB25 +:1027A0000123FAE71A8030BC704770B50C46054625 +:1027B000FFF72FFB2146284605F079FC2846BDE8A7 +:1027C0007040012105F082BC4FF0E0224FF400413F +:1027D0000020C2F88011204908702049900208604A +:1027E000704730B51C4D04462878A04218BF002C15 +:1027F00002D0002818BFFFDF2878A04208BF30BDF4 +:102800002C701749154A0020ECB1164DDFF858C05E +:10281000131F012C0DD0022C1CBFFFDF30BD086040 +:1028200003200860CCF800504FF4000010601860DE +:1028300030BD086002200860CCF800504FF04070B6 +:102840001060186030BD086008604FF06070106064 +:1028500030BD00B5FFDF00BD1800002008F50140C5 +:1028600000F500408C02002014F5004070B50B20EC +:1028700000F0B5F9082000F0B2F900210B2000F0BB +:10288000C4F90021082000F0C0F9EC4C0125656076 +:10289000A5600020C4F84001C4F84401C4F8480110 +:1028A0000B2000F0A7F9082000F0A4F90B2000F09D +:1028B0008BF9256070BD10B50B2000F090F9082051 +:1028C00000F08DF9DD48012141608160DC490A6832 +:1028D000002AFCD10021C0F84011C0F84411C0F812 +:1028E00048110B2000F086F9BDE81040082000F0E8 +:1028F00081B910B50B2000F07DF9BDE8104008202B +:1029000000F078B900B530B1012806D0022806D011 +:10291000FFDF002000BDCB4800BDCB4800BDCA484A +:10292000001D00BD70B5C9494FF000400860C84D9A +:10293000C00BC5F80803C74800240460C5F840412F +:102940000820C43500F04BF9C5F83C41C24804707A +:1029500070BD08B5B94A002128B1012811D002285C +:102960001CD0FFDF08BD4FF48030C2F80803C2F866 +:102970004803B3483C300160C2F84011BDE808404C +:10298000D0E74FF40030C2F80803C2F84803AC485F +:1029900040300160C2F84411AB480CE04FF4802095 +:1029A000C2F80803C2F84803A54844300160C2F8E1 +:1029B0004811A548001D0068009008BD70B5164676 +:1029C0000D460446022800D9FFDF00229B48012360 +:1029D00004F110018B4000EB8401C1F8405526B191 +:1029E000C1F84021C0F8043303E0C0F80833C1F84F +:1029F0004021C0F8443370BD2DE9F0411C46154616 +:102A000030B1012834D0022839D0FFDFBDE8F08191 +:102A1000891E002221F07F411046FFF7CFFF012CD5 +:102A200024D000208C4E8A4F012470703C6189496B +:102A300000203C3908600220091D086085490420F7 +:102A40003039086083483D350560C7F800420820EA +:102A500000F0D0F82004C7F80403082000F0B4F810 +:102A60007A49E007091F08603470CFE70120D9E7F1 +:102A7000012B02D00022012005E00122FBE7012BFF +:102A800004D000220220BDE8F04197E70122F9E7D7 +:102A90006B480068704770B500F0C7F8674C054692 +:102AA000D4F840010026012809D1D4F80803C00356 +:102AB00005D54FF48030C4F80803C4F84061D4F859 +:102AC000440101280CD1D4F80803800308D54FF441 +:102AD0000030C4F80803C4F84461012010F0CDFCB4 +:102AE000D4F8480101280CD1D4F80803400308D5D4 +:102AF0004FF48020C4F80803C4F84861022010F0A5 +:102B0000BCFC5648056070BD70B500F08EF8524DA3 +:102B10000446287858B1FFF705FF687820B10020F7 +:102B200085F8010010F0A9FC4C48046070BD03203A +:102B3000F8E74FF0E0214FF40010C1F800027047B1 +:102B4000152000F057B8424901200861082000F024 +:102B500051B83F494FF47C10C1F8080300200246E9 +:102B600001EB8003C3F84025C3F84021401CC0B2EC +:102B70000628F5D37047410A43F609525143C0F382 +:102B8000080010FB02F000F5807001EB5020704748 +:102B900010B5430B48F2376463431B0C5C020C60B6 +:102BA0002F4C03FB04002F4B4CF2F72443435B0DE7 +:102BB00013FB04F404EB402000F580704012107009 +:102BC00008681844086010BD00F01F020121914000 +:102BD0004009800000F1E020C0F80011704700F0CB +:102BE0001F02012191404009800000F1E020C0F85F +:102BF0008011704700F01F020121914040098000C0 +:102C000000F1E020C0F8801270474907090E002843 +:102C100006DA00F00F0000F1E02080F8141D704784 +:102C200000F1E02080F8001470470C48001F006895 +:102C30000A4A0D49121D11607047000000B00040A3 +:102C400004B500404081004044B1004008F5014017 +:102C500000800040408500403800002014050240FC +:102C6000F7C2FFFF6F0C0100010000010A4810B518 +:102C70000468094909480831086010F092FC0648C8 +:102C8000001D046010BD0649002008604FF0E021DF +:102C90000220C1F8800270471005024001000001C7 +:102CA000FC1F004010B50D2000F06FF8C4B26FF0AB +:102CB000040000F06AF8C0B2844200D0FFDF3A4955 +:102CC0000120086010BD70B50D2000F048F8374CA9 +:102CD0000020C4F800010125C4F804530D2000F0C1 +:102CE00049F825604FF0E0216014C1F8000170BD83 +:102CF00010B50D2000F033F82C480121416000216F +:102D0000C0F80011BDE810400D2000F033B828488D +:102D100010B5046826492748083108602349D1F8CE +:102D20000001012804D0FFDF2148001D046010BD10 +:102D30001D48001D00680022C0B2C1F8002110F03B +:102D4000E7FFF1E710B51948D0F800110029FBD0D2 +:102D5000FFF7DDFFBDE810400D2000F00BB800F0DC +:102D60001F02012191404009800000F1E020C0F8DD +:102D70008011704700F01F0201219140400980003E +:102D800000F1E020C0F880127047002806DA00F059 +:102D90000F0000F1E02090F8140D03E000F1E020B6 +:102DA00090F800044009704704D5004000D000406E +:102DB000100502400100000110B5202000F082F84B +:102DC000202000F08AF84A49202081F8000449496F +:102DD00000060860091D48480860FEF79DFA45494D +:102DE000C83108604548D0F8041341F00101C0F82B +:102DF0000413D0F8041341F08071C0F804133C4967 +:102E000001201C39C1F8000110BD10B5202000F0D0 +:102E100059F8384800210160001D0160354A481EFC +:102E2000E83A1060354AC2F80803324BC8331960DB +:102E3000C2F80001C2F8600131490860BDE81040E5 +:102E4000202000F04AB82B492E48EC390860704722 +:102E500028492C48E8390860704726480160001D61 +:102E6000521E0260704723490120E8390860BFF311 +:102E70004F8F704770B51F4A8069E83A2149116049 +:102E80001E49D1F8006100231F4D1D4A5C1E1EB172 +:102E9000A84206D300210FE0D1F8606186B1A842B4 +:102EA00009D2C1F80031C1F860311460BDE870404A +:102EB000202000F012B81168BDE8704021F040BA3F +:102EC000FFDF70BD00F01F0201219140400980002A +:102ED00000F1E020C0F88011704700F01F020121CE +:102EE00091404009800000F1E020C0F88012704756 +:102EF00020E000E000060240C41400200000024070 +:102F00000004024001000001006002000F4A126844 +:102F10000D498A420CD118470C4A12680A4B9A4252 +:102F200006D101B510F06EFFFFF78DFFBDE801403F +:102F3000074909680958084706480749054A064BE2 +:102F40007047000000000000BEBAFECAB0000020BA +:102F500004000020E0120020E012002070B50C46B2 +:102F6000054609F0A7FA21462846BDE870400AF058 +:102F70008CBB10B511F0B0FBFFF726FC11F04CFA3A +:102F8000BDE8104011F0FEBA0120810708607047CB +:102F9000012081074860704712480068C00700D0D0 +:102FA000012070470F48001F0068C00700D00120B3 +:102FB00070470C4808300068C00700D001207047F7 +:102FC000084810300068704706490C310A68D2037F +:102FD00006D5096801F00301814201D10120704743 +:102FE000002070470C0400407047704770477047DE +:102FF000704770477047704770470004050600002F +:103000002CFFFFFFDBE5B15100600200A800FFFFCD +:1030100084000000808D5B0016425791AD5F58BC64 +:103020008E702F5A0FAA100DBCD52BFD30B5FC4D5C +:103030000446062CA9780ED2DFE804F0030E0E0E2B +:103040000509FFDF08E0022906D0FFDF04E00329BD +:1030500002D0FFDF00E0FFDFAC7030BD30B50446CA +:103060001038EF4D07280CD2DFE800F0040C060CF6 +:103070000C0C0C00FFDF05E0287E112802D0FFDFDA +:1030800000E0FFDF2C7630BD2DE9F0410FF09CFB16 +:10309000044610F038FD201AC5B206200DF030FCB1 +:1030A000044606200DF034FC211ADD4C207E122847 +:1030B00018D000200F1807200DF022FC064607202C +:1030C0000DF026FC301A3918207E13280CD0002071 +:1030D0000144A078042809D000200844281AC0B26E +:1030E000BDE8F0810120E5E70120F1E70120F4E7E8 +:1030F000CB4810B590F825004108C94800F12600DA +:1031000005D00BF0B6FABDE8104005F0AFBF0BF0EC +:1031100089FAF8E730B50446A1F120000D460A28E7 +:103120004AD2DFE800F005070C1C2328353A3F445B +:10313000FFDF42E0207820283FD1FFDF3DE0B848A4 +:103140008178052939D0007E122836D020782428AD +:1031500033D0252831D023282FD0FFDF2DE0207851 +:1031600022282AD0232828D8FFDF26E0207822280A +:1031700023D0FFDF21E0207822281ED024281CD075 +:1031800026281AD0272818D0292816D0FFDF14E0C7 +:103190002078252811D0FFDF0FE0207825280CD0DB +:1031A000FFDF0AE02078252807D0FFDF05E0207840 +:1031B000282802D0FFDF00E0FFDF257030BD10B50A +:1031C000012803D0022805D0FFDF10BDBDE8104064 +:1031D00003202BE79248007E122800D0FFDF002159 +:1031E000052011F04FF8BDE81040112036E71FB55B +:1031F00004466A46002001F01FFEB4B1BDF802206B +:103200004FF6FF700621824201D1ADF80210BDF8E1 +:103210000420824201D1ADF80410BDF808108142AB +:1032200003D14FF44860ADF8080068460BF089FF01 +:1032300005F01CFF04B010BD70B514460D460646DF +:1032400011F06CF858B90DB1A54201D90C2070BD30 +:10325000002408E056F8240011F060F808B11020AE +:1032600070BD641CE4B2AC42F4D3002070BD2DE903 +:10327000F04105461F4690460E460024006811F0B6 +:103280009AF808B110202BE728680028A88802D0F7 +:10329000B84202D84FE00028F5D0092020E728687E +:1032A000025DB2B1611C475C152F2DD03BDC3AD2D8 +:1032B000DFE807F03912222228282A2A3131393949 +:1032C00039393939393939392200025D32BB641C48 +:1032D000A4B2A142F9D833E0022ADED1A21C805C5C +:1032E00088F80000072801D2400701D40A20F7E639 +:1032F000307840F0010015E0D043C00707E0012A14 +:1033000007D010E00620EBE61007A0F1805000285F +:10331000F5D01846E4E63078820701D50B20DFE6C9 +:1033200040F0020030702868005D084484B2A8882C +:10333000A04202D2B1E74FF4485381B2A142AED8C5 +:103340000020CDE610B5027843F202235408012292 +:10335000022C12D003DC3CB1012C16D106E0032C68 +:1033600010D07F2C11D112E0002011E080790324CD +:10337000B4EB901F09D10A700BE08079B2EB901F7B +:1033800003D1F8E780798009F5D0184610BDFF20F9 +:103390000870002010BD224991F82E2042B191F80A +:1033A0002F10022909D0032909D043F202207047C7 +:1033B00001461B48253001F092BD032100E00121A8 +:1033C00001700020704738B50C460546694601F08B +:1033D00086FD00280DD19DF80010207861F347008C +:1033E000207055F8010FC4F80100A888A4F8050062 +:1033F000002038BD38B51378B0B1022814D0FF28AA +:103400001BD008A46D46246800944C7905EB9414F5 +:10341000247864F34703137003280AD010E00000F7 +:10342000D80100200302FF0123F0FE0313700228DD +:10343000F2D1D8B240F0010005E043F0FE00107078 +:10344000107820F0010010700868C2F80100888828 +:10345000A2F8050038BD02210DF0AABA38B50C4615 +:103460000978222901D2082038BDADF800008DF876 +:10347000022068460BF044F905F0F8FD050003D181 +:1034800021212046FFF746FE284638BD1CB5002006 +:103490008DF80000CDF80100ADF80500FE4890F869 +:1034A0002E00022801D0012000E000208DF8070046 +:1034B00068460BF056FB002800D0FFDF1CBD002241 +:1034C0000A80437892B263F345120A8043785B081E +:1034D00063F386120A8000780C282BD2DFE800F014 +:1034E0002A06090E1116191C1F220C2742F0110082 +:1034F00009E042F01D0008800020704742F01100F2 +:1035000012E042F0100040F00200F4E742F0100038 +:10351000F1E742F00100EEE742F0010004E042F082 +:103520000200E8E742F0020040F00400E3E742F066 +:103530000400E0E7072070472DE9FF478AB0002527 +:10354000BDF82C6082461C4690468DF81C507007D2 +:1035500003D5606810F0E2FE68B9CF4F4FF0010963 +:1035600097F82E0058B197F82F00022807D160680D +:1035700010F021FF18B110200EB0BDE8F087300721 +:1035800002D5A089802816D8700705D4B8F1000F9D +:1035900002D097F8240070B1E07DC0F300108DF8E0 +:1035A0001B00617D072041B1012906D00229E3D02B +:1035B0000429E1D12CE00720DEE749468DF8179079 +:1035C000F00609D4A27D072032B1012A04D0022AD4 +:1035D00005D0042AD0D11BE08DF8191002E002209A +:1035E0008DF819008DF815806068B0B107A9FFF754 +:1035F000A9FE0028C0D19DF81C00FF280AD06068F1 +:1036000050F8011FCDF80F108088ADF8130008E0C6 +:103610000620B1E743F20220AEE7CDF80F50ADF837 +:103620001350E07B0028F3D1207C0028F0D1607C8F +:103630000028EDD1A07C0028EAD1E07CC006E7D1CB +:103640008DF800A0BDF82C00ADF80200A068019034 +:10365000A068029004F10F0001F035FC8DF80C0019 +:103660000DF10D00FFF797FE00B1FFDF9DF81C0084 +:103670008DF80E008DF816508DF81850E07D08A9D1 +:1036800000F00F008DF81A0068460BF036FF05F0C9 +:10369000EDFC71E7F0B59DB000228DF868208DF843 +:1036A00058208DF8602005468DF86C2012921392F8 +:1036B0001492159219B10FC912AC84E80F00764C20 +:1036C000A078052801D004280CD11298616888429E +:1036D00000D120B91498E168884203D110B10820C4 +:1036E0001DB0F0BD1F26334618AA1AA912A8FFF76D +:1036F000BEFD0028F4D133461BAA16A914A8FFF773 +:10370000B6FD0028ECD19DF85800C00701D00A2072 +:10371000E6E7A08A410708D4A17D31B19DF8601089 +:10372000890702D043F20120DAE79DF86010C9074B +:1037300009D0400707D4208818B144F2506188426C +:1037400001D90720CCE78DF8005003268DF80160E1 +:1037500001278DF80270BDF84C208DF8032001A8D8 +:10376000129920F025FD68460BF028FF05F07EFC3D +:103770000028B5D18DF824508DF825608DF826707D +:10378000BDF854208DF827200AA8149920F010FDC8 +:1037900009A80BF060FF05F069FC0028A0D112AD6C +:1037A000241D95E80F0084E80F00002098E770B50D +:1037B00086B00D46040005D010F0FDFD20B11020AC +:1037C00006B070BD0820FBE72078C107A98802D0A9 +:1037D000FF2902D303E01F2901D20920F0E7800767 +:1037E00061D4FFF751FC38B12078C0F3C101012941 +:1037F00004D0032902D005E01320E1E7264991F81F +:10380000241041B1C0074FF000054FF0010604D06D +:103810008DF80F6003E00720D2E78DF80F5068465F +:10382000FFF7B9FD00B1FFDF2078C0F3C1008DF8CC +:1038300001008DF80250607808B98DF80260607858 +:10384000C00705D09DF8020040F001008DF802008D +:103850006078800705D59DF8020040F002008DF8E1 +:1038600002006078400705D59DF8020040F0040092 +:103870008DF802002078C0F380008DF80300608886 +:10388000ADF80600A088ADF80A00207A58B9607A31 +:1038900048B9A07A38B901E0D8010020E07A10B91F +:1038A000207BC00601D006208AE704F1080001F061 +:1038B0000AFB8DF80E0068460BF087F905F0D6FB81 +:1038C00000288BD18DF810608DF81150ADF8125092 +:1038D000ADF8145004A80BF0FDF905F0C7FB002863 +:1038E0008BD1E08864280AD248B1012001F001FBA5 +:1038F000002891D12078C00705D0152004E064216C +:10390000B0FBF1F0F2E71320FFF7A8FB002057E728 +:103910002DE9FF470220FF4E8DF804000027708E2E +:10392000ADF80600B84643F202094CE001A80CF0DD +:10393000A6FF050006D0708EA8B3A6F83280ADF8B9 +:1039400006803EE0039CA07F01072DD504F12400F2 +:103950000090A28EBDF80800214604F1360301F064 +:1039600054FC050005D04D452AD0112D3CD0FFDF79 +:103970003AE0A07F20F00801E07F420862F3C7111F +:10398000A177810861F30000E07794F8210000F04E +:103990001F0084F820002078282826D129212046DD +:1039A000FFF7B8FB21E014E040070AD5BDF8080096 +:1039B00004F10E0101F0ABFA05000DD04D4510D118 +:1039C00000257F1CFFB202200CF09AFF401CB84279 +:1039D000ACD8052D11D008E0A07F20F00400A0771E +:1039E00003E0112D00D0FFDF0025BDF80600708632 +:1039F000052D04D0284604B0BFE5A6F8328000208B +:103A0000F9E770B50646FFF726FD054605F002FD0D +:103A1000040000D1FFDF6680207820F00F00801CBA +:103A200020F0F000203020700620207295F83E0033 +:103A30006072BDE8704005F0F0BC2DE9F04786B03B +:103A4000040000D1FFDF2078B24D20F00F00801C71 +:103A500020F0F0007030207060680178491F1B2949 +:103A600033D2DFE801F0FE32323255FD320EFDFD79 +:103A700042FC32323278FCFCFB323232FCFCFAF986 +:103A8000FC00C6883046FFF7E6FC0546304607F0E6 +:103A9000A7F8E0B16068007A85F83E002121284649 +:103AA000FFF738FB3046FEF7CEFA304603F016FE3D +:103AB0003146012010F0E6FBA87F20F01000A87727 +:103AC000FFF726FF002800D0FFDF06B055E520787D +:103AD00020F0F000203020700620207266806068A0 +:103AE000007A607205F099FCD8E7C5882846FFF790 +:103AF000B2FC00B9FFDF60680079012800D0FFDF69 +:103B00006068017A06B02846BDE8F04707F044BC7B +:103B1000C6883046FFF79FFC050000D1FFDF05F0A7 +:103B20007CFC606831460089288160684089688132 +:103B300060688089A881012010F0A4FB0020A8758E +:103B4000A87F00F003000228BFD1FFF7E1FE0028A4 +:103B5000BBD0FFDFB9E70079022811D000B1FFDF49 +:103B600005F05BFC6668B6F806A0307A361D0128C1 +:103B70000CD0687E814605F0E5F9070009D107E021 +:103B800006B00220BDE8F047FFF719BBE878F1E77F +:103B9000FFDF0022022150460CF001FF040000D19B +:103BA000FFDF22212046FFF7B5FA3079012800D047 +:103BB0000220A17F804668F30101A177308B20812C +:103BC000708B6081B08BA08184F822908DF8088082 +:103BD000B8680090F86801906A46032150460CF0DE +:103BE000DEFE00B9FFDFB888ADF81000B8788DF8B8 +:103BF000120004AA052150460CF0D1FE00B9FFDFE7 +:103C0000B888ADF80C00F8788DF80E0003AA0421EE +:103C100050460CF0C4FE00B9FFDF062106F1120089 +:103C200001F093F938B37079800700D5FFDF71791F +:103C3000E07D61F34700E075D6F80600A061708969 +:103C4000A083062106F10C0001F07FF9E8B195F898 +:103C500025004108607805E032E02AE047E03FE0D7 +:103C600021E035E061F347006070D5F82600C4F824 +:103C70000200688D12E0E07D20F0FE00801CE075FF +:103C8000D6F81200A061F08ADAE7607820F0FE0032 +:103C9000801C6070F068C4F80200308AE080404602 +:103CA000FFF78DFA11E706B02046BDE8F04701F0B6 +:103CB00035BD05F0B2FB15F8300F40F0020005E00D +:103CC00005F0ABFB15F8300F40F004002870FCE65F +:103CD000287E132809D01528E4D11620FFF7BEF955 +:103CE00006B0BDE8F04705F098BB1420F6E7A978C8 +:103CF000052909D00429D5D105F08FFB022006B093 +:103D0000BDE8F047FFF792B900790028CAD0E878FB +:103D100002E00000D801002001F0BCF805F07DFBB6 +:103D20000320ECE72DE9F05F054600784FF000082E +:103D30000009DFF820A891460C46464601287AD0B3 +:103D400001274FF0020C4FF6FF73022874D00728AA +:103D50000BD00A2871D0FFDFA9F8006014B1A4F8D5 +:103D6000008066800020BDE8F09F696804F10800CB +:103D70000A78172A70D010DC4FF0000B142A31D0CB +:103D800006DC052A6DD0092A0FD0102A7ED11FE04B +:103D9000152A7CD0162AF9D1F0E01B3A052A75D2F3 +:103DA000DFE802F009C5FDDAFC00C8884FF0120810 +:103DB0001026214675E14FF01C080A26D4B38888E6 +:103DC000A0806868807920726868C0796072C3E7F3 +:103DD0004FF01B0814266CB303202072686880889B +:103DE000A080B9E70A793C2AB6D00D1D4FF0100823 +:103DF0002C26FCB16988A180298B6182298B2182C4 +:103E0000698BA182A98BE1826B790246A91D1846B4 +:103E1000FFF7F0FA2879012810D084F80FC0FF20AE +:103E20002076C4F81CB0C4F820B0C4F824B0C4F89C +:103E300028B091E712E013E13BE135E1E7730AF1C5 +:103E4000040084F818B090E80E00DAF81000C4E915 +:103E50000930C4E907127FE7A8E002E0A9F8006092 +:103E600080E72C264FF01D08002CF7D00546A380D4 +:103E7000887B2A880F1D60F300022A80887B400817 +:103E800060F341022A80887B800801E0E6E0ADE033 +:103E900060F382022A80887BB91CC00860F3C302E9 +:103EA0002A80B87A0011401C60F3041202F07F00EF +:103EB00028807878AA1CFFF79DFA387D05F1090261 +:103EC00007F11501FFF796FA387B01F04DF82874D9 +:103ED000787B01F049F86874F87EA874787AE87401 +:103EE00097F83B002875B87B6875A5F816B0DAF826 +:103EF0001C00A861397ABAF82000884201D2014634 +:103F000010E0B87AC0F3411002280BD0012809D084 +:103F1000288820F060002880A1840A4607F11C014F +:103F2000A86998E0288820F060004030F3E7112667 +:103F30004FF02008002C91D0A380686804F10A0299 +:103F4000007920726868007B607269688B1D48790F +:103F50001946FFF74FFAFFE60A264FF02108002C1A +:103F6000E9D08888A0806868807920726868C07904 +:103F700060729AF8301021F004018BE00B264FF0AC +:103F80002208002CD7D0C888A080686800792072E9 +:103F90006868007A00F0E8FF607201E052E039E002 +:103FA0006868407A00F0E0FFA072D5E61C264FF06A +:103FB0002608002CBFD0A3806868407960726868CA +:103FC000007AA0720AF1040090E80E00DAF81000FE +:103FD000C4E90530C4E90312686800793C2803D0BD +:103FE00043287DD0FFDFB7E62772B5E610264FF0F5 +:103FF0002408002C9FD08888A08068688079208160 +:104000006868807A608168680089A08168688089B2 +:10401000E081A1E610264FF02308002C8BD0888881 +:10402000A0806868C08820816868008960816868AD +:104030004089A08168688089E0819AF8301021F079 +:10404000020127E030264FF02508002C88D0A380FD +:1040500069682822496820F0ABF87DE64A4677E097 +:10406000287A012803D0022817D0FFDF74E6102633 +:104070004FF01F08002C85D06888A080A889208177 +:10408000E8896081288AA081688AE0819AF83010E6 +:1040900021F001018AF830105EE64FF01208102678 +:1040A000688800F03FFF57E62846BDE8F05F01F062 +:1040B000BFBC287A07284DD2DFE800F04C38384AD8 +:1040C0004A4A040009264FF01108002C92D06F884C +:1040D0003846FFF7C0F990F822A0A780687A00E080 +:1040E0002DE02072042138460CF074FC052138467E +:1040F0000CF070FC002138460CF06CFC01213846B5 +:104100000CF068FC032138460CF064FC02213846B0 +:104110000CF060FC062138460CF05CFC07213846A8 +:104120000CF058FC504600F0B5FE15E614264FF092 +:104130001B08002C8AD0A380287A012802D084F89A +:1041400008C009E62772DAE90710C4E9031003E69C +:104150002146A9E7FFDFFFE570B5FE4D287E122856 +:1041600001D0082070BD0AF0C3FF04F07FFF0400F7 +:1041700002D1687E00F08EFE0021052010F082F84A +:10418000204670BD1CB5F348007E132801D20820DC +:104190001CBD00208DF8000068460AF09BFD04F06D +:1041A00065FF0028F4D10021052010F06BF81120E4 +:1041B000FEF754FF00201CBD70B5012805D005286E +:1041C00025D0062800D0FFDF70BD8DB22846FFF74E +:1041D00042F9040000D1FFDF20782128F4D005F057 +:1041E00019F968B1017821F00F01891C21F0F00163 +:1041F000103101700221017245800020A07528E075 +:1042000021462846BDE870401322FFF727B9D14860 +:10421000047EA4F1120005281FD2DFE800F0060397 +:1042200003030300FFF7AEFF01E0FFF795FF00284F +:10423000CAD105F0EFF80028C6D0017821F00F01AF +:10424000891C21F0F00120310170132C07D00221CC +:104250000172BDE8704005F0E0B8FFDF70BD0121DC +:10426000F6E72DE9F04116460C00804600D1FFDF4D +:10427000307820F00F00801C20F0F00010303070FB +:104280002078012804D0022818D0FFDFBDE8F08193 +:104290004046FFF7E0F8050000D1FFDF0320A875D6 +:1042A00005F0BBF894E80F00083686E80F00A9482F +:1042B00010F8301F41F001010170E7E74046FFF7B9 +:1042C000CAF8050000D1FFDFA1884FF6FF70002774 +:1042D000814202D1E288824203D0814201D1E0884A +:1042E00040B105F09AF894E80F00083686E80F0010 +:1042F000AF75CBE7A87D0128C8D1782300224146BD +:104300000FF016FF0220A875C0E738B505460C4629 +:10431000084610F003F818BB203D062D4AD2DFE80E +:1043200005F0031B373C4230002106200FF080FFD0 +:1043300008B1112038BDA01C0AF0AFFF04F096FEB2 +:10434000050038D100220823114606200FF0F0FEA8 +:10435000062830D0FFDF2EE0606810F023F808B1A7 +:10436000102038BD618820886A460BF05FFB04F09E +:104370007DFE05001FD16068E8B1BDF80010018026 +:1043800019E0A07800F0010120880BF085FB0EE019 +:10439000206801F0FBFD05460DE0207800F00100EB +:1043A0000AF033F903E0618820880BF0C4FA04F0C6 +:1043B0005DFEF0E70725284638BD70B505460C467A +:1043C00008460FF0D1FF08B1102070BD202D07D096 +:1043D000212D0DD0222D0BD0252D09D0072070BD09 +:1043E0002088A11C0AF006FABDE8704004F03EBE29 +:1043F000062070BD57482530704708B53421554810 +:104400001FF077FF0120FEF711FE1120FEF726FEB8 +:1044100050496846263104F093FF4E489DF800202D +:1044200010F8251F62F3470121F0010101700021FE +:1044300041724FF46171A0F8071002218172FEF7FA +:1044400057FE00B1FFDFFCF791FF01F032F908BD24 +:1044500010B50C46402120461FF029FFA07F20F018 +:104460000300A077202020700020A07584F823008E +:1044700010BD70472DE9FC4107460FF04FFF10B10A +:104480001020BDE8FC81334E06F12501D6F8250049 +:104490000090B6F82950ADF8045096F82B408DF8EE +:1044A00006403846FEF78FFF0028EAD1FEF720FECF +:1044B0000028E6D0009946F8251FB580B471E0E7E2 +:1044C00010B504460FF050FF08B1102010BD214870 +:1044D0002049224690F8250026314008FEF78AFF41 +:1044E000002010BDFEB50D4604004FF0000712D0AD +:1044F0000822FEF7A1FE002812D1002609E000BF25 +:1045000054F826006946FEF71DFF002808D1761CE6 +:10451000F6B2AE42F4D309F07CFF10B143F20320AF +:10452000FEBD0C4E86F8247024B300271EE000BFA9 +:1045300054F8270002A9FEF705FF00B1FFDF9DF840 +:1045400008008DF8000054F8270050F8011FCDF83E +:10455000011001E0D80100208088ADF80500684610 +:1045600009F0A1FF00B1FFDF7F1CFFB2AF42DFD334 +:1045700086F824500020FEBD2DE9F0478AB015468C +:10458000894604001ED00F4608222946FEF754FE35 +:10459000002810D1002613E054F826006946103098 +:1045A00000F09DFC002806D147B157F826000FF017 +:1045B000B5FE18B110200AB0BDE8F087761CF6B23F +:1045C000AE42E9D30026A5F101081BE006F1010A7D +:1045D0000AF0FF0712E000BF54F82600017C4A08E9 +:1045E00054F827100B7CB2EB530F05D10622113083 +:1045F00011311FF0B1FD58B17F1CFFB2AF42EBD3B8 +:104600000AF0FF064645E1DB4E4624B1012003E0F7 +:1046100043F20520CFE7002009F076FF10B909F03A +:1046200087FF10B143F20420C5E75CB300270DF10A +:10463000170825E054F827006946103000F04FFCB9 +:1046400000B1FFDF54F82700102250F8111FCDF8F9 +:1046500001108088ADF8050054F827100DF107000F +:104660001FF0A6FD96B156F82710102240461FF005 +:104670009FFD684609F0F0FE00B1FFDF7F1CFFB22E +:10468000AF42D7D3FEF702FF002094E7404601F087 +:1046900071FCEEE730B585B004460FF03FFE18B967 +:1046A00060680FF088FE10B1102005B030BD608842 +:1046B0004AF2B811884206D82078FB4D28B101286B +:1046C00006D0022804D00720EFE7FEF711FD18E01E +:1046D0006078022804D0032802D043F20220E4E7E5 +:1046E00085F82F00C1B200200090ADF80400022927 +:1046F0002CD0032927D0FFDF684609F0BAFF04F069 +:10470000B5FC0028D1D1606801F027FC207858B1B1 +:1047100001208DF800000DF1010001F02BFC68462E +:104720000BF018FA00B1FFDF207885F82E00FEF7B5 +:10473000ADFE608860B1A88580B209F0DDFE00B1F1 +:10474000FFDF0020B1E78DF80500D5E74020FAE74C +:104750004FF46170EFE710B504460FF005FE20B985 +:10476000606838B10FF01EFE08B1102010BD6068FF +:1047700001F000FCCC4830F82C1F6180C1786170DA +:1047800080782070002010BD2DE9F843144689463A +:1047900006460FF0E9FDA0B948460FF00CFE80B9BF +:1047A00020460FF008FE60B9BF4DA878012800D15F +:1047B0003CB13178FF2906D049B143F20400BDE88D +:1047C000F8831020FBE7012801D00420F7E74FF021 +:1047D0000008A4B3052811D004280FD0694620464C +:1047E000FEF76DFE0028EAD1207D48B1012809D0EE +:1047F000022809D0032809D00720E0E70820DEE7D7 +:10480000424604E0012202E0022200E003222346A5 +:10481000174600200099FEF78FFE0028CFD1A0890F +:104820002880A07BE875BDF80000A882AF75BDF8B0 +:104830000000000701D5A08988B1A08928804946D9 +:104840000020FEF727FF0028B9D1A87805280BD053 +:10485000042809D0287DC00703D0032002E080206F +:10486000ECE70220FEF7E2FB86F800800020A6E7D6 +:104870007CB58D4C05460E46A078022803D003284F +:1048800001D008207CBD15B143F204007CBD072097 +:104890000CF03EF810B9A078032806D0FEF7F4FB20 +:1048A00028B1A078032804D009E012207CBD132091 +:1048B0007CBD304600F0CDFA0028F9D1E670012029 +:1048C0008DF800008DF801008DF802502088ADF8B9 +:1048D0000400E07D8DF8060068460AF0EAFF04F067 +:1048E000C5FB0028E4D1A078032805D05FF00400C0 +:1048F000FEF79CFB00207CBDE07800F0BAFA0520B2 +:10490000F6E71CB510B143F204001CBD664CA0785C +:10491000042803D0052801D008201CBD00208DF8F4 +:10492000000001218DF801108DF8020068460AF0A0 +:10493000C0FF04F09BFB0028EFD1A078052805D02C +:104940005FF00200FEF772FB00201CBDE07800F073 +:10495000A1FA0320F6E72DE9FC4180460E46032527 +:1049600008460FF028FD002866D14046FEF773FD8B +:10497000040004D02078222804D2082081E543F2E4 +:1049800002007EE5A07F00F003073EB1012F0CD0AE +:1049900000203146FEF72BFC0500EFD1012F06D099 +:1049A000022F1AD0FFDF28466BE50120F1E7A07D3A +:1049B0003146022801D011B107E0112061E56846B7 +:1049C000FCF7E1FD0028D9D16946404606F0A7FC76 +:1049D0000500E8D10120A075E5E7A07D032804D1FA +:1049E000314890F83000C00701D02EB30EE026B158 +:1049F000A07F40071ED4002100E00121404606F0C0 +:104A0000AEFC0500CFD1A075002ECCD0314640467B +:104A100000F07DFA05461128C5D1A07F4107C2D418 +:104A2000316844F80E1F7168616040F00400207422 +:104A30000025B8E71125B6E7102022E570B50C4631 +:104A40000546FEF708FD010005D022462846BDE8D0 +:104A50007040FEF703BD43F2020070BD10B501289F +:104A600007D1114B9B78012B00D011B143F2040008 +:104A700010BD09F084FDBDE8104004F0F7BA012331 +:104A800000F012BA00231A46194600F00DBA70B5AC +:104A900006460C4608460FF041FC18B920680FF096 +:104AA00063FC18B1102070BDD8010020F74D2A7E9C +:104AB000112A04D0132A00D33EB10820F3E721467F +:104AC0003046FEF774FE60B1EDE70920132A0DD0E1 +:104AD000142A0BD0A188FF29E5D31520FEF7BEFAD2 +:104AE0000020D4E90012C5E90712DCE7A1881F29DC +:104AF000D9D31320F2E72DE9F047DFF8908307467A +:104B000090B098F818009A4615460C46132803D31F +:104B1000FFF738FB002822D120460FF0FFFBA0BB97 +:104B200028460FF0FBFB80BB20784FF00101C00747 +:104B30004FF0000602D08DF83A1001E08DF83A608F +:104B40002078C0F3C1008DF800006278072042B1E0 +:104B5000012A06D0022A02D0042A00D1062010B071 +:104B60002AE58DF809106088ADF80A00A088ADF834 +:104B7000100020788946C0F3C10001281FD0032807 +:104B80001DD038460FF0CAFB08B11020E7E738788F +:104B9000400808D0012809D0022807D0032805D0F2 +:104BA00043F20220DBE78DF8026001E08DF802900D +:104BB00057F8010FCDF80300B888ADF807000DF1E4 +:104BC0000100FEF7E8FB08B10320C8E72888ADF82C +:104BD00016006888ADF81C00A888ADF82200E888A7 +:104BE000ADF82800ADF82E60ADF8346068460AF0E4 +:104BF000BDF8E8B998F818004546112801D00820FA +:104C0000ADE706200BF084FE38B12078C0F3C10078 +:104C1000012804D0032802D004E012209FE795F871 +:104C2000240028B1FEF730FA022803D2132096E7B9 +:104C3000072094E7504600F00CF900288FD185F842 +:104C400019A068460AF051FA04F010FA002886D13B +:104C5000687E00F00EF9E08864280AD248B101208D +:104C600000F047F9040091D11220FEF7F7F9204631 +:104C700075E76421B0FBF1F0F2E770B50646154622 +:104C80000C4608460FF070FB18B928460FF06CFB75 +:104C900008B1102007E72A46214630460AF0A9FE4F +:104CA00004F0E4F90028F5D121787F29F2D105201C +:104CB000F9E67CB505460C4608460FF02FFB08B117 +:104CC00010207CBD2846FEF7C6FB20B100782228C4 +:104CD00004D208207CBD43F202007CBD6B4890F8F2 +:104CE0003000400701D511207CBD2178C80802D1D1 +:104CF0006078C20801D007207CBD890801D18008F6 +:104D000001D006207CBDADF8005020788DF802005F +:104D100060788DF803000220ADF80400684609F0C1 +:104D200042FF04F0A3F97CBD70B586B014460D4671 +:104D30000646FEF790FB28B10078222805D208200D +:104D400006B0B0E643F20200FAE728460FF033FB64 +:104D500020B944B120460FF025FB08B11020EFE741 +:104D600000202060A080494890F83000800701D5DD +:104D70001120E5E703A9304609F0BDFD18B100BFD9 +:104D800004F074F9DCE7ADF80060BDF81400ADF88C +:104D90000200BDF81600ADF80400BDF81000BDF823 +:104DA0001210ADF80600ADF808107DB1298809B1E0 +:104DB000ADF80610698809B1ADF80210A98809B1EB +:104DC000ADF80810E98809B1ADF80410DCB1BDF800 +:104DD0000610814201D9081A2080BDF80210BDF8E2 +:104DE0001400814201D9081A6080BDF80800BDF89E +:104DF0000410BDF816200144BDF812001044814291 +:104E000001D9081AA080684609F0AAFEB8E71CB5C7 +:104E10001F490968CDE90010684609F0AAFF04F0AF +:104E200025F91CBD1CB5002000900190684609F0D2 +:104E3000A0FF04F01BF91CBD108008885080488832 +:104E40009080C88810818888D0800020508190810F +:104E5000704710B5044604F075F830B1407830B1B1 +:104E6000204604F07EFB002010BD052010BD12205E +:104E700010BD10B504F066F8040000D1FFDF6078C3 +:104E800000B9FFDF6078401E607010BDD8010020BF +:104E90009C46020010B504F055F8040000D1FFDF75 +:104EA0006078401C6070F0E71CB5ADF800008DF82C +:104EB00002308DF803108DF8042068460AF05EFD7C +:104EC00004F0D4F81CBD0CB52DA2D2E90012CDE936 +:104ED00000120079694601EB501000780CBD027891 +:104EE000520804D0012A02D043F202207047FEF794 +:104EF00029BA10B548B183000022114605200FF0F1 +:104F000017F9052801D00320BFE70020BDE71FB532 +:104F10006A46FFF791FF68460AF04CF904F0A6F8DC +:104F200004B0B2E770B50C0006460DD0FEF793FA58 +:104F3000050000D1FFDFA6802889208128896081B3 +:104F40006889A081A889E081ADE510B500231A46E3 +:104F500003E0845C2343521CD2B28A42F9D30BB1E2 +:104F6000002092E7012090E700B530B1012803D07E +:104F7000022801D0FFDF002000BDFF2000BD00009F +:104F8000070605040302010010B504460FF0C6F938 +:104F900008B1102010BD2078C0F30210042807D8F3 +:104FA0006078072804D3A178102901D8814201D262 +:104FB000072010BDE078410706D421794A0703D4C1 +:104FC000000701D4080701D5062010BD002010BD40 +:104FD00010B513785C08837F64F3C7138377137865 +:104FE0009C08C37F64F30003C3771078C309487833 +:104FF00063F34100487013781C090B7864F347137E +:105000000B701378DB0863F3000048705078487128 +:1050100010BD10B5C4780B7864F300030B70C4782E +:10502000640864F341030B70C478A40864F382033A +:105030000B70C478E40864F3C3030B700379117830 +:1050400063F30001117003795B0863F34101117090 +:1050500003799B0863F3820111700079C00860F343 +:10506000C301117010BD70B514460D46064604F01C +:10507000D1F980B10178182221F00F01891C21F0AB +:10508000F001A03100F8081B21461FF0D6F8BDE85A +:10509000704004F0C2B929463046BDE87040132282 +:1050A000FEF7DCB92DE9F047064608A8894690E8E6 +:1050B00030041F469046142128461FF01AF900219B +:1050C000CAF80010B8F1000F03D0B9F1000F03D1F6 +:1050D00014E03878C00711D020680FF045F9C0BB44 +:1050E000B8F1000F07D12068123028602068143012 +:1050F00068602068A8602168CAF8001038788007C6 +:1051000024D560680FF04EF918BBB9F1000F21D01B +:10511000FFF770F90168C6F868118188A6F86C116C +:10512000807986F86E0101F002FDF94FEF60626848 +:1051300062B196F8680106F2691140081032FEF774 +:1051400059F91022394660681FF032F80020BDE896 +:10515000F08706E0606820B1E8606068C6F8640126 +:10516000F4E71020F3E730B5054608780C4620F048 +:105170000F00401C20F0F001103121700020607001 +:1051800095F8230030B104280FD0052811D0062847 +:1051900014D0FFDF20780121B1EB101F04D295F865 +:1051A000200000F01F00607030BD21F0F0002030C2 +:1051B00002E021F0F00030302070EBE721F0F00049 +:1051C0004030F9E7F0B591B0022715460C46064687 +:1051D0003A46ADF80870092103AB04F07AFF049059 +:1051E000002810D004208DF804008DF80170E03400 +:1051F000099605948DF818500AA968460DF0CAF86A +:1052000000B1FFDF012011B0F0BD10B588B00C4631 +:105210000A99ADF80000C3B11868CDF802005868CB +:10522000CDF80600ADF80A20102203A81EF0C0FF3A +:1052300068460AF062F803F019FF002803D1A17F45 +:1052400041F01001A17708B010BD0020CDF8020098 +:10525000E6E72DE9F84F0646808A0D4680B2824681 +:10526000FEF7F9F804463078DFF8A48200274FF003 +:105270000509A8F120080F2870D2DFE800F06FF2CE +:105280003708387D8CC8F1F0EFF35FF3F300A07FAF +:1052900000F00300022809D05FF0000080F0010157 +:1052A00050460BF085FB050003D101E00120F5E736 +:1052B000FFDF98F85C10C90702D0D8F860000BE057 +:1052C000032105F11D000EF004FDD5F81D009149E4 +:1052D000B0FBF1F201FB1200C5F81D0070686867B1 +:1052E000B068A8672078252800D0FFDFCAE0A07F3B +:1052F00000F00300022809D05FF0000080F00101F7 +:1053000050460BF055FB060003D101E00120F5E704 +:10531000FFDF3078810702D52178252904D040F0BD +:1053200001003070BDE8F88F02202870307F2871AE +:1053300006F11D002D36C5E90206F3E7A07F00F057 +:105340000300022808D0002080F0010150460BF035 +:105350002FFB040004D102E00120F5E7A7E1FFDF05 +:105360002078C10604D5072028703D346C60D9E749 +:1053700040F008002070D5E7E07F000700D5FFDF90 +:10538000307CB28800F0010301B05046BDE8F04F18 +:10539000092105F027BD04B9FFDF716821B1102292 +:1053A00004F124001EF004FF28212046FDF7B2FE80 +:1053B000A07F00F0030002280ED104F12400002396 +:1053C00000901A4621465046FFF71FFF112807D0CC +:1053D00029212046FDF79EFE307A84F82000A1E7BF +:1053E000A07F000700D5FFDF14F81E0F40F0080073 +:1053F0002070E782A761E761C109607861F341002D +:10540000014660F382016170307AE0708AE7A07F24 +:1054100000F00300022809D05FF0000080F00101D5 +:1054200050460BF0C5FA040003D101E00120F5E776 +:10543000FFDF022104F185000EF04BFC04202870F0 +:1054400004F5B4706860B4F88500288230481038DC +:105450007C346C61C5E9028064E703E024E15BE031 +:105460002DE015E0A07F00F00300022807D0002007 +:1054700080F0010150460BF09BFA18B901E00120C1 +:10548000F6E7FFDF324621465046BDE8F84FEAE531 +:1054900004B9FFDF20782128A1D93079012803D170 +:1054A000E07F40F00800E077324621465046FFF7A3 +:1054B000DAFD2046BDE8F84F2321FDF72BBE3279F7 +:1054C000AA8005F108030921504604F002FEE860B5 +:1054D00010B185F8009025E7A07F00F003000228B6 +:1054E00008D0002080F0010150460BF061FA040062 +:1054F00003D101E00120F5E7FFDF04F1620102239F +:105500001022081F0BF0DBF807703179417009E7B2 +:105510003802002040420F00A07F00F00300022864 +:1055200008D0002080F0010150460BF041FA050040 +:1055300003D101E00120F5E7FFDF95F8840000F0DA +:10554000030001287AD1A07F00F00307E07F10F06C +:10555000010602D0022F04D133E095F8A000C00765 +:105560002BD0D5F8601121B395F88320087C62F325 +:1055700087000874A17FCA09D5F8601162F3410061 +:105580000874D5F8601166F300000874AEB1D5F860 +:105590006001102204F1240188351EF009FE287EE6 +:1055A00040F001002876287820F0010005F88809ED +:1055B00000E016B1022F04D02DE095F88800C00756 +:1055C00027D0D5F85C1121B395F88320087C62F3CD +:1055D00087000874A17FCA09D5F85C1162F3410005 +:1055E0000874D5F85C1166F3000008748EB1D5F824 +:1055F0005C01102204F1240188351EF0D9FD2878C1 +:1056000040F0010005F8180B287820F0010005F89B +:10561000A009022F44D0002000EB400005EBC000A1 +:1056200090F88800800709D595F87C00D5F86421AA +:10563000400805F17D011032FDF7DCFE8DF8009089 +:1056400095F884006A4600F003008DF8010095F893 +:1056500088108DF8021095F8A0008DF803002146FF +:10566000504601F04DFA2078252805D0212807D092 +:10567000FFDF2078222803D922212046FDF74AFDAA +:10568000A07F00F0030002280CD0002080F0010170 +:1056900050460BF09FF900283FF44FAEFFDF41E684 +:1056A0000120B9E70120F1E7706847703AE6FFDFB3 +:1056B00038E670B5FE4C002584F85C5025660CF089 +:1056C00036FE04F11001204603F060FE84F83050ED +:1056D00070BD70B50D46FDF7BEFE040000D1FFDFC2 +:1056E0004FF4B87128461EF004FE04F1240028612E +:1056F000A07F00F00300022808D0012105F1E0009E +:105700000CF016FE002800D0FFDF70BD0221F5E787 +:105710000A46014602F1E0000CF02ABE70B50546CB +:10572000406886B001780A2906D00D2933D00E29A9 +:105730002FD0FFDF06B070BD86883046FDF78BFEA8 +:10574000040000D1FFDF20782128F3D028281BD1C6 +:10575000686802210E3001F0C8F9A8B16868082114 +:10576000801D01F0C2F978B104F1240130460AF03D +:10577000A2F803F07BFC00B1FFDF06B02046BDE8D5 +:1057800070402921FDF7C6BC06B0BDE8704003F0AB +:1057900044BE012101726868C6883046FDF75BFE91 +:1057A000040000D1FFDFA07F00F00301022902D135 +:1057B00020F01000A077207821280AD06868017AAC +:1057C00009B1007980B1A07F00F00300022862D007 +:1057D000FFDFA07F00F003000228ABD1FEF798F8AE +:1057E0000028A7D0FFDFA5E703F017FEA17F08067A +:1057F0002BD5E07FC00705D094F8200000F01F00F3 +:10580000102820D05FF0050084F823002078292894 +:105810001DD02428DDD1314604200EF033FD222195 +:105820002046FDF777FCA07F00F00300022830D06F +:105830005FF0000080F0010130460BF0CBF800284B +:10584000C7D0FFDFC5E70620DEE70420DCE701F074 +:105850000300022808D0002080F0010130460BF040 +:10586000A7F8050003D101E00120F5E7FFDF2521BE +:105870002046FDF74FFC03208DF80000694605F136 +:10588000E0000CF06CFD0228A3D00028A1D0FFDFBF +:105890009FE70120CEE703F0C0FD9AE72DE9F04332 +:1058A00087B09946164688460746FDF7D4FD0400A2 +:1058B0004BD02078222848D3232846D0E07F000709 +:1058C00043D4A07F00F00300022809D05FF000005D +:1058D00080F0010138460BF06BF8050002D00CE0B7 +:1058E0000120F5E7A07F00F00300022805D0012188 +:1058F000002238460BF053F805466946284601F069 +:1059000026F9009800B9FFDF45B10098E035056140 +:105910002078222806D0242804D007E0009900200F +:10592000086103E025212046FDF7F4FB00980121E2 +:1059300041704762868001A9C0E902890CF02AFD06 +:10594000022802D0002800D0FFDF07B0BDE8F083B6 +:1059500070B586B00546FDF77EFD017822291ED977 +:10596000807F00F00300022808D0002080F00101B1 +:1059700028460BF01DF804002FD101E00120F5E7C7 +:10598000FFDF2AE0B4F85E0004F1620630440178DB +:10599000427829B121462846FFF714FCB0B9C9E680 +:1059A000ADF804200921284602AB04F092FB0390D5 +:1059B0000028F4D005208DF80000694604F1E000CD +:1059C0000CF0CDFC022801D000B1FFDF0223102231 +:1059D000314604F15E000AF0A8FEB4F86000002829 +:1059E000D0D1A7E610B586B00446FDF734FD0178A6 +:1059F00022291BD9807F00F00300022808D0002054 +:105A000080F0010120460AF0D3FF040003D101E039 +:105A10000120F5E7FFDF06208DF80000694604F15C +:105A2000E0000CF09CFC002800D0FFDF06B010BDA9 +:105A30002DE9F05F05460C460027007890460109E5 +:105A40003E4604F1080BBA4602297DD0072902D050 +:105A50000A2909D146E0686801780A2905D00D298C +:105A600030D00E292ED0FFDFBCE114271C26002CDD +:105A70006BD08088A080FDF7EEFC5FEA000900D1C2 +:105A8000FFDF99F817005A46400809F11801FDF7A1 +:105A9000B1FC6868C0892082696851F8060FC4F8B3 +:105AA00012004868C4F81600A07E20F0060001E04D +:105AB0001802002040F00100A07699F81E0040F086 +:105AC00020014DE01A270A26002CD1D0C088A080E2 +:105AD000FDF7C1FC050000D1FFDF59462846FFF75E +:105AE00042FB7FE10CB1A88BA080287A0B287DD0E7 +:105AF00006DC01287BD0022808D0032804D135E039 +:105B00000D2875D00E2874D0FFDF6BE11E27092603 +:105B1000002CADD0A088FDF79EFC5FEA000900D103 +:105B2000FFDF287B00F003000128207A1BD020F043 +:105B300001002072297B890861F341002072297BD2 +:105B4000C90861F3820001E041E1F2E02072297BA3 +:105B5000090961F3C300207299F81E0040F040016A +:105B600089F81E103EE140F00100E2E713270D2600 +:105B7000002CAAD0A088FDF76EFC8146807F00F043 +:105B80000300022808D0002080F00101A0880AF05C +:105B90000FFF050003D101E00120F5E7FFDF99F8D1 +:105BA0001E0000F00302022A50D0686F817801F0D5 +:105BB00003010129217A4BD021F001012172837860 +:105BC0009B0863F3410121728378DB0863F3820150 +:105BD000217283781B0963F3C3012172037863F395 +:105BE00006112172437863F3C71103E061E0A9E075 +:105BF00090E0A1E0217284F809A0C178A172022A84 +:105C000029D00279E17A62F30001E1720279520847 +:105C100062F34101E1720279920862F38201E1725A +:105C20000279D20862F3C301E1724279217B62F307 +:105C3000000121734279520862F3410121734279D4 +:105C4000920862F382012173407928E0A86FADE7E2 +:105C500041F00101B2E74279E17A62F30001E172B9 +:105C60004279520862F34101E1724279920862F38B +:105C70008201E1724279D20862F3C301E1720279D2 +:105C8000217B62F3000121730279520862F3410122 +:105C900021730279920862F3820121730079C008AE +:105CA00060F3C301217399F80000232831D926211C +:105CB00040E018271026E4B3A088FDF7CCFB83460C +:105CC000807F00F00300022809D0002080F001014D +:105CD000A0880AF06DFE5FEA000903D101E001200F +:105CE000F4E7FFDFE868A06099F8000040F00401E5 +:105CF00089F8001099F80100800708D50120207369 +:105D00009BF8000023286DD92721584651E084F8DC +:105D10000CA067E015270F265CB1A088FDF79BFB60 +:105D2000814606225946E86808F059F90120A07317 +:105D3000A2E041E048463CE016270926E4B3287B70 +:105D400020724FE0287B19270E26ACB3C4F808A0B8 +:105D5000A4F80CA0012807D0022805D0032805D0FC +:105D6000042803D0FFDF0DE0207207E0697B0428E0 +:105D700001F00F0141F0800121721ED0607A20F005 +:105D800003006072A088FDF766FB054600782128B5 +:105D900028D0232800D0FFDFA87F00F003000228CE +:105DA00013D0002080F00101A0880AF013FE222108 +:105DB0002846FDF7AFF915E004E0607A20F0030013 +:105DC000401CDEE7A8F8006011E00120EAE70CB112 +:105DD0006888A080287A03282ED004280AD00528B5 +:105DE00050D0FFDFA8F800600CB12780668000204B +:105DF000BDE8F09F15270F26002CE3D0A088FDF703 +:105E00002AFB807F00F00300022809D05FF0000029 +:105E100080F00101A0880AF0CBFD050003D101E06C +:105E20000120F5E7FFDFD5F81D000622594608F0EE +:105E3000D6F884F80EA0D5E717270926002CC1D084 +:105E4000A088FDF708FB8146807F00F00300022850 +:105E500008D0002080F00101A0880AF0A9FD05000B +:105E600003D101E00120F5E7FFDF6878800701D565 +:105E7000022000E00120207299F800002328B1D907 +:105E8000272157E719270E26002C9BD0A088FDF765 +:105E9000E2FA5FEA000900D1FFDFC4F808A0A4F825 +:105EA0000CA084F808A0A07A40F00300A07299F832 +:105EB0001E10C90961F38200A07299F81F2099F899 +:105EC0001E1012EAD11F05D099F8201001F01F0111 +:105ED00010292BD020F00800A07299F81F10607ACA +:105EE00061F3C3006072697A01F003010129A2D154 +:105EF00040F00400607299F81E0000F003000228D0 +:105F0000E87A16D0217B60F300012173AA7A607BC6 +:105F100062F300006073EA7A520862F34101217370 +:105F2000A97A490861F3410060735BE740F008001B +:105F3000D2E7617B60F300016173AA7A207B62F390 +:105F400000002073EA7A520862F341016173A97A72 +:105F5000490861F34100207344E710B5FE4C30B1AD +:105F60000146102204F120001EF022F9012084F8DD +:105F7000300010BD10B5044600F0D9FDF6492046AA +:105F80001022BDE8104020311EF012B970B5F24D5C +:105F900006004FF0000413D00EF0C0F908B1102431 +:105FA0000CE00621304608F001F8411C05D02866B7 +:105FB0005FF0010085F85C0000E00724204670BD1A +:105FC0000020F7E7007810F00F0204D0012A05D076 +:105FD000022A0CD110E0000909D10AE000090128C9 +:105FE00007D0022805D0032803D0042801D00720B9 +:105FF00070470870002070470620704705282AD295 +:10600000DFE800F003070F171F00087820F0FF00FB +:106010001EE0087820F00F00401C20F0F000103047 +:1060200016E0087820F00F00401C20F0F00020302F +:106030000EE0087820F00F00401C20F0F000303017 +:1060400006E0087820F00F00401C20F0F0004030FF +:10605000087000207047072070472DE9F041804606 +:1060600088B00D46002708460EF0A5F9A8B94046AD +:10607000FDF7F1F9040003D02078222815D104E0BF +:1060800043F2020008B0BDE8F08145B9A07F4106A7 +:1060900003D500F00300022801D01020F2E7A07F12 +:1060A000C10601D4010702D50DB10820EAE7E17F5E +:1060B000090701D50D20E5E700F00300022805D10E +:1060C00025B12846FEF760FF0700DBD1A07F00F076 +:1060D0000300022808D0002080F0010140460AF0A9 +:1060E00067FC060002D00FE00120F5E7A07F00F07A +:1060F000030002280ED0002080F00101002240465B +:106100000AF04DFC060007D0A07F00F00300022833 +:1061100004D009E00120EFE70420B3E725B12A46C7 +:1061200031462046FEF754FF6946304600F00FFD29 +:10613000009800B9FFDF0099022006F1E0024870E4 +:10614000C1F824804A6100220A81A27F02F0030282 +:10615000022A1CD001200871287800F00102087E74 +:1061600062F3010008762A78520862F3820008760A +:106170002A78920862F3C30008762A78D20862F37C +:106180000410087624212046FCF7C4FF33E035B321 +:106190000871301D88613078400908777078C0F345 +:1061A00040004877287800F00102887F62F3010000 +:1061B0008877A27FD20962F382008877E27F62F358 +:1061C000C3008877727862F304108877A878C8775C +:1061D00001F1210228462031FEF71BFF03E00320D6 +:1061E00008710520087625212046FCF793FFA07F43 +:1061F00020F04000A07701A900980CF0CBF802280D +:1062000001D000B1FFDF38463CE72DE9FF4F534A8C +:106210000D4699B09A4607CA0BAB002783E80700E2 +:106220001998FDF718F9060006D03078262806D010 +:1062300008201DB0BDE8F08F43F20200F9E7B07FFF +:1062400000F00309B9F1020F03D00020284302D067 +:1062500006E00120FAE71B98FEF796FE0028E8D139 +:10626000B07F00F00300022801D11B9979BB0228FE +:1062700008D0002080F0010119980AF099FB040071 +:1062800003D101E00120F5E7FFDF852D28D007DCF1 +:10629000F5B1812D1ED0822D1ED0832D08D11DE099 +:1062A000862D1FD0882D1FD0892D1FD08A2D1FD05D +:1062B0000F2020710F281DD003F0ACF8E0B10120B1 +:1062C0008DF84000201D11902079B8B167E111E0F0 +:1062D0000020EEE70120ECE70220EAE70320E8E7F0 +:1062E0000520E6E70620E4E70820E2E70920E0E7EA +:1062F0000A20DEE707209CE711209AE7B9F1020F98 +:1063000003D0A56F03D1A06F02E0656FFAE7606F5D +:10631000804632D04FF0010000904FF00200019013 +:10632000214630461B9AFEF753FE1B98007800F07A +:106330000101A87861F30100A870B17FC90961F378 +:106340008200A870F17F61F3C300A870617861F3E7 +:106350000410A870207803E018020020A446020070 +:10636000400928706078C0F3400068701B988078FE +:10637000E87000206871287103E00220009001207D +:106380000190A87898F80210C0F3C000C1F3C001D2 +:1063900008405FEA000B2CD050460DF0BFFF90BBC9 +:1063A000DAF80C000DF0BAFF68BBDAF81C000DF04B +:1063B000B5FF40BBDAF80C00A060DAF81C00E06022 +:1063C00098F80100617800F0010041EA4000607037 +:1063D00098F80210C0B2C1F30011891E0840607025 +:1063E00000202077019906F1170002290CD0012125 +:1063F0000BE098F80110607801F00101FD2242EAFB +:1064000041010840E3E732E0002104EB81014861EB +:106410000099701C022901D0012100E0002104EB49 +:1064200081014861A87800F00300012858D198F84C +:10643000020000F00300012852D1B9F1020F04D08C +:106440002A1D691D1B98FEF7E4FD297998F80400C0 +:1064500001408DF83810687998F8052010408DF8C3 +:106460003C0001433CD050460DF058FF08B11020CD +:10647000DFE60AF110010491B9F1020F18D00846C5 +:106480005FF0000104F18C03CDE9000304F5AE7266 +:1064900002920EAB5A462046FEF704FE0028E7D1D2 +:1064A000B9F1020F08D0504608D14FF0010107E0C2 +:1064B00050464FF00101E5E70498F5E74FF0000181 +:1064C00004F1A403CDE9000304F5B072029281F057 +:1064D00001010FAB5A462046FEF7E4FD0028C7D164 +:1064E0006078800734D4A87898F80210C0F3800050 +:1064F000C1F3800108432BD0297898F800000BAA3B +:10650000B9F1020F06D032F811204300DA4002F050 +:1065100003070AE032F810204B00DA4012F00307BC +:1065200005D0012F0BD0022F0BD0032F07D0BBF1CA +:10653000000F0DD0012906D0042904D008E002275D +:10654000F5E70127F3E7012801D0042800D104274B +:10655000B07F40F08000B077F17F6BF30001F177FE +:10656000607881074FF003000CD5A071BBF1000FDC +:1065700015D100BF8DF85C0017AA3146199800F0BC +:10658000BFFA0CE00221022F18D0012F18D0042FDF +:1065900022D00020A071B07F20F08000B0772521AC +:1065A0003046FCF7B7FD10A904F1E0000BF0D7FE70 +:1065B00010B1022800D0FFDF00203AE6A171D9E730 +:1065C000A1710D2104F120001DF093FE207840F010 +:1065D000020020700420CDE70120A071DFE72DE943 +:1065E000F04387B09046894604460025FCF733FF08 +:1065F000060006D03078272806D0082007B0BDE86E +:10660000F08343F20200F9E7B07F00F003000228B4 +:1066100008D0002080F0010120460AF0C9F90400EA +:1066200003D101E00120F5E7FFDFA7795FEA090068 +:1066300005D0012821D0B9F1020F26D110E0B8F120 +:10664000000F22D1012F05D0022F05D0032F05D036 +:10665000FFDF2DE00C252BE0012529E0022527E0B6 +:1066600040460DF05BFEB0B9032F0ED1102241461B +:1066700004F11D001DF09CFD1AE0012F02D0022F35 +:1066800003D104E0B8F1000F12D00720B6E740466E +:106690000DF044FE08B11020B0E7102104F11D00F8 +:1066A0001DF005FE0621404607F080FCC4F81D00E1 +:1066B0002078252140F0020020703046FCF72AFDAA +:1066C0002078C10713D020F00100207002208DF83F +:1066D000000004F11D0002908DF804506946C3309B +:1066E0000BF03DFE022803D010B1FFDF00E025775C +:1066F000002083E730B587B00D460446FCF7ABFEBB +:10670000A0B1807F00F00300022812D05FF00000EB +:1067100080F0010120460AF04BF904000ED0284613 +:106720000DF0FCFD38B1102007B030BD43F202007F +:10673000FAE70120ECE72078400701D40820F3E7CE +:10674000294604F13D00202205461DF031FD207848 +:1067500040F01000207001070FD520F008002070D5 +:1067600007208DF80000694604F1E00001950BF068 +:10677000F6FD022801D000B1FFDF0020D4E770B59C +:106780000D460646FCF767FE18B10178272921D18E +:1067900002E043F2020070BD807F00F00300022897 +:1067A00008D0002080F0010130460AF001F9040011 +:1067B00003D101E00120F5E7FFDFA079022809D12C +:1067C0006078C00706D02A4621463046FEF7FAFC1C +:1067D00010B10FE0082070BDB4F860000E280BD295 +:1067E00004F1620102231022081F09F068FF012151 +:1067F00001704570002070BD112070BD70B5064657 +:1068000014460D4608460DF089FD18B920460DF0D6 +:10681000ABFD08B1102070BDA6F57F40FF380ED04B +:106820003046FCF718FE38B1417822464B08811CEF +:106830001846FCF7DFFD07E043F2020070BD20467A +:10684000FDF73EFE0028F9D11021E01D0DF041FAC0 +:10685000E21D294604F1170000F089F9002070BDFF +:106860002DE9F04104468AB01546884600270846BF +:106870000DF0A1FD18B928460DF09DFD18B11020AE +:106880000AB0BDE8F0812046FCF7E5FD060003D024 +:10689000307827281BD102E043F20200F0E7B07FF6 +:1068A00000F00300022809D05FF0000080F0010131 +:1068B00020460AF07DF8040003D101E00120F5E74D +:1068C000FFDF2078400702D56078800701D40820D8 +:1068D000D6E7B07F00F00300022803D0A06F03D1F9 +:1068E000A16F02E0606FFAE7616F407800B19DB17F +:1068F000487810B1B8F1000F0ED0ADB1EA1D06A86E +:10690000E16800F034F9102206A905F117001DF026 +:1069100023FC18B1042707E00720B1E71022E91D86 +:1069200004F12D001DF044FCB8F1000F06D0102238 +:1069300008F1070104F11D001DF03AFC2078252123 +:1069400040F0020020703046FCF7E4FB2078C107DD +:1069500015D020F00100207002208DF8000004F115 +:106960001D000290103003908DF804706946B3301A +:106970000BF0F5FC022803D010B1FFDF00E0277711 +:1069800000207DE7F8B515460E460746FCF763FD87 +:10699000040004D02078222804D00820F8BD43F257 +:1069A0000200F8BDA07F00F00300022802D043F2ED +:1069B0000500F8BD30460DF0B1FC18B928460DF0C1 +:1069C000ADFC08B11020F8BD00953288B31C2146FB +:1069D0003846FEF71AFC112815D00028F3D1297C7F +:1069E0004A08A17F62F3C711A177297CE27F61F396 +:1069F0000002E277297C890884F82010A17F21F029 +:106A00004001A177F8BDA17F0907FBD4D6F80200A9 +:106A1000C4F83600D6F80600C4F83A003088A086DC +:106A20001022294604F124001DF0C2FB287C4108F5 +:106A3000E07F61F34100E077297C61F38200E07739 +:106A4000287C800884F82100A07F40F00800A0770F +:106A50000020D3E770B50D4606460BB1072070BD88 +:106A6000FCF7F9FC040007D02078222802D3A07F8D +:106A7000800604D4082070BD43F2020070BDADB1A1 +:106A80002946304608F017FF02F0F0FA297C4A0840 +:106A9000A17F62F3C711A177297CE27F61F3000235 +:106AA000E277297C890884F8201004E0304608F059 +:106AB0002AFF02F0DBFAA17F21F02001A17770BD4F +:106AC00070B50D46FCF7C7FC040005D028460DF054 +:106AD0004BFC20B1102070BD43F2020070BD29466E +:106AE0002046FEF740FB002070BD04E010F8012BAB +:106AF0000AB100207047491E89B2F7D201207047C1 +:106B000070B51546064602F085FC040000D1FFDF93 +:106B1000207820F00F00801C20F0F0002030207042 +:106B200066802868A060BDE8704002F076BC10B5B1 +:106B3000134C94F83000002808D104F12001A1F191 +:106B400010000BF04EFC012084F8300010BD10B195 +:106B500090F8B9202AB10A4890F8350018B1002001 +:106B600003E0B83001E0064834300860704708B5EB +:106B70000023009313460A460AF015F908BD0000E9 +:106B80001802002018B18178012938D101E01020C5 +:106B90007047018842F60112881A914231D018DC00 +:106BA00042F60102A1EB020091422AD00CDC41B373 +:106BB000B1F5C05F25D06FF4C050081821D0A0F502 +:106BC0007060FF381BD11CE001281AD002280AD1BE +:106BD00017E0B0F5807F14D008DC012811D002281E +:106BE0000FD003280DD0FF2809D10AE0B0F5817F2E +:106BF00007D0A0F58070033803D0012801D0002011 +:106C000070470F2070470A281ED007DC18D2DFE833 +:106C100000F0191B1F1F171F231D1F21102815D03F +:106C200008DC0B2812D00C2810D00D2816D00F2805 +:106C300006D10DE011280BD084280BD087280FD067 +:106C400003207047002070470520704707207047D9 +:106C50000F20704704207047062070470C207047B3 +:106C600043F20200704738B50C46050041D0694632 +:106C7000FFF7A8F9002819D19DF80010607861F39A +:106C8000020060706946681CFFF79CF900280DD16E +:106C90009DF80010607861F3C5006070A978C1F3B9 +:106CA0004101012903D0022905D0072038BD2178F0 +:106CB00021F0200102E0217841F0200121704107FC +:106CC00004D0A978C90861F386106070607810F06C +:106CD000380F07D0A978090961F3C710607010F068 +:106CE000380F02D16078400603D5207840F040008C +:106CF0002070002038BD70B504460020088015467D +:106D00006068FFF7B0FF002816D12089A18988426A +:106D100011D860688078C0070AD0B1F5007F0AD822 +:106D200040F20120B1FBF0F200FB1210288007E0D6 +:106D3000B1F5FF7F01D90C2070BD01F2012129803E +:106D4000002070BD10B50478137864F3000313704D +:106D50000478640864F3410313700478A40864F3AE +:106D6000820313700478E40864F3C3031370047897 +:106D7000240964F3041313700478640964F345135D +:106D800013700078800960F38613137031B10878AE +:106D9000C10701D1800701D5012000E0002060F388 +:106DA000C713137010BD4278530702D002F00703D7 +:106DB00006E012F0380F02D0C2F3C20300E0012354 +:106DC0004A7863F302024A70407810F0380F02D01C +:106DD000C0F3C20005E0430702D000F0070000E066 +:106DE000012060F3C5024A7070472DE9F04F95B05D +:106DF0000D00824612D0122128461DF058FA4FF697 +:106E0000FF7B05AA0121584606F01BFF00242646F9 +:106E100037464FF420586FF4205972E0102015B017 +:106E2000BDE8F08F9DF81E0001280AD1BDF81C10A6 +:106E300041450BD011EB09000AD001280CD00228E3 +:106E40000CD0042C0ED0052C0FD10DE0012400E055 +:106E50000224BDF81A6008E0032406E00424BDF80B +:106E60001A7002E0052400E00624BDF81A1051450E +:106E700047D12C74BEB34FF0000810AA4FF0070A98 +:106E8000CDE90282CDE900A80DF13C091023CDF82F +:106E9000109042463146584606F086FF08BBBDF8C2 +:106EA0003C002A46C0B210A90BF004FBC8B9AE8161 +:106EB000CFB1CDE900A80DF1080C0AAE40468CE830 +:106EC0004102132300223946584606F06DFF40B9AF +:106ED000BDF83C00F11CC01EC0B22A1D0BF0EAFA3E +:106EE00010B103209BE70AE0BDF82900E881062CD9 +:106EF00005D19DF81E00A872BDF81C002881002055 +:106F00008DE705A806F0A9FE00288BD0FFF77BFED1 +:106F100085E72DE9F0471C46DDE90978DDF820908A +:106F200015460E00824600D1FFDF0CB1208818B153 +:106F3000D5B11120BDE8F087022D01D0012100E07C +:106F4000002106F1140005F06BFDA8F800000246D0 +:106F50003B462946504603F0BCF8C9F8000008B982 +:106F6000A41C3C600020E5E71320E3E7F0B41446DE +:106F7000DDE904528DB1002314B1022C09D101E0E6 +:106F8000012306E00D7CEE0703D025F00105012367 +:106F90000D742146F0BC03F025BF1A80F0BC704789 +:106FA0002DE9FE4F91461A881C468A468046FAB162 +:106FB00002AB494603F08DF8050019D04046A61CE7 +:106FC000278809F039FE3246072629463B460096B7 +:106FD00009F047FA20882346CDE900504A46514639 +:106FE0004046FFF7C3FF002020800120BDE8FE8F50 +:106FF0000020FBE72DE9F04786B09146DDE90E461B +:107000000F46824603AA05A904A8109D8DE8070033 +:107010009846324621465046FFF77BFF049909B156 +:10702000012200E000222A70002818D1F94A03AB9F +:107030001060059A009104F11400CDE901204A4640 +:107040003946504606F0A3F8A8B1092811D2DFE866 +:1070500000F005080510100A0C0C0E00002006B008 +:1070600068E71120FBE70720F9E70820F7E70D2084 +:10707000F5E70320F3E7BDF80C100498CDE9000113 +:107080004346324621465046FFF770FFE6E72DE9BA +:10709000F04389B00D46DDE9108781461C4616464F +:1070A000142103A81DF025F9012002218DF81010EC +:1070B0008DF80C008DF81170ADF8146064B1A278F1 +:1070C000D20709D08DF81600E088ADF81A00A08824 +:1070D000ADF81800A068079008A80095CDE9011048 +:1070E000424603A948466B68FFF784FF09B0BDE834 +:1070F000F083F0B58BB0002406460694079407276A +:10710000089405A80994019400970294CDE90340DE +:107110000D4610232246304606F046FE78B90AA8EE +:1071200006A9019400970294CDE90310BDF814302C +:1071300000222946304606F00DFC002801D0FFF75A +:1071400062FD0BB0F0BD06F0ADBA2DE9FC410C4676 +:107150008046002602F05EF9054620780D287DD293 +:10716000DFE800F0BC0713B325BD49496383AF9541 +:107170009B00A848006820B1417841F0100141709F +:10718000ADE0404602F076F9A9E00421404609F05E +:107190000FFC070000D1FFDF07F11401404605F0A6 +:1071A000D3FBA5BB13214046FDF748FC97E0042123 +:1071B000404609F0FDFB070000D1FFDFE088ADF895 +:1071C00000000020B8819DF80000010704D5C0062A +:1071D00002D5A088B88105E09DF8010040067ED563 +:1071E000A088F88105B9FFDF22462946404601F014 +:1071F00063FC022673E0E188ADF800109DF80110F1 +:1072000009060FD5072803D006280AD00AE024E093 +:107210000421404609F0CCFB060000D1FFDFA08826 +:10722000F0810226CDB9FFDF17E00421404609F0C6 +:10723000BFFB070000D1FFDF07F1140006F069FA79 +:1072400090F0010F02D1E079000648D5387C022683 +:1072500040F00200387405B9FFDF00E03EE022464E +:107260002946404601F028FC39E00421404609F057 +:107270009FFB017C002D01F00206C1F3400161710A +:10728000017C21F002010174E7D1FFDFE5E702266E +:107290000121404602F020F921E00421404609F096 +:1072A00087FB0546606800902089ADF80400012244 +:1072B0006946404602F031F9287C20F0020028742B +:1072C0000DE0002DC9D1FFDFC7E7022600214046AF +:1072D000FBF788F8002DC0D1FFDFBEE7FFDF3046A7 +:1072E000BDE8FC813EB50C0009D001466B4601AA01 +:1072F000002006F0DBFD20B1FFF785FC3EBD10202D +:107300003EBD00202080A0709DF8050002A900F07D +:107310000700FEF773FE50B99DF8080020709DF835 +:10732000050002A9C0F3C200FEF768FE08B1032001 +:107330003EBD9DF8080060709DF80500C109A07869 +:1073400061F30410A0709DF80510890961F3C30072 +:10735000A0709DF80410890601D5022100E00121EA +:1073600061F342009DF8001061F30000A07000205E +:107370003EBD70B5144606460D4651EA040005D0E0 +:1073800075B108460DF00EF878B901E0072070BD20 +:107390002946304606F0EBFD10B1BDE8704032E4FE +:1073A00054B120460CF0FEFF08B1102070BD2146FC +:1073B0003046BDE8704095E7002070BD2DE9FC5FC8 +:1073C0000C4690460546002701780822007A3E4682 +:1073D000B2EB111F7ED104F10A0100910A31821E25 +:1073E0004FF0020A04F1080B0191092A73D2DFE879 +:1073F00002F0ECDF05F427277AA9CD006888042184 +:1074000009F0D6FA060000D1FFDFB08920B152277B +:107410000726C2E07C02002051271026002C7DD0D8 +:107420006888A0800120A071A88900220099FFF738 +:10743000A0FF002873D1A8892081288AE081D1E0AB +:10744000B5F81290072824D1E87B000621D55127F2 +:1074500009F1140086B2002CE1D0A889002200991D +:10746000FFF787FF00285AD16888A08084F806A01B +:10747000A88920810120A073288A2082A4F8129074 +:10748000A88A009068884B46A969019A01F0F1FA30 +:10749000A8E0502709F1120086B2002C3ED0A8893E +:1074A00000225946FFF765FF002838D16888A08080 +:1074B000A889E080287A072813D002202073288A20 +:1074C000E081E87BC0096073A4F81090A88A00905E +:1074D000688801E083E080E04B4604F11202A9696C +:1074E000D4E70120EAE7B5F81290512709F114001A +:1074F00086B2002C66D06888042109F059FA8346C8 +:107500006888A080A88900220099FFF732FF002830 +:107510006ED184F806A0A889208101E052E067E0DE +:107520000420A073288A2082A4F81290A88A0090D0 +:1075300068884B46A969019A01F09BFAA989ABF8C2 +:107540000E104FE06888FBF786FF07466888042125 +:1075500009F02EFA064607B9FFDF06B9FFDF687BA0 +:10756000C00702D05127142601E0502712264CB341 +:107570006888A080502F06D084F806A0287B594642 +:1075800001F087FA2EE0287BA11DF9E7FE49A889C2 +:107590004989814205D1542706269CB16888A0807C +:1075A00020E053270BE06888A080A889E08019E0DC +:1075B0006888042109F0FCF900B9FFDF5527082687 +:1075C000002CF0D1A8F8006011E056270726002C07 +:1075D000F8D06888A080002013E0FFDF02E00128D7 +:1075E00008D0FFDFA8F800600CB12780668000207B +:1075F000BDE8FC9F57270726002CE3D06888A080B1 +:10760000687AA071EEE7401D20F0030009B1414304 +:10761000091D01EB4000704713B5DB4A00201071D3 +:10762000009848B10024684608F0DFFF002C02D122 +:10763000D64A009911601CBD01240020F4E770B502 +:107640000D46064686B014465C2128461CF051FEC5 +:1076500004B9FFDFA0786874A2782188284601F079 +:1076600042FA0020A881E881228805F11401304601 +:1076700005F04FF96A460121304606F0E2FA19E0BA +:107680009DF80300000715D5BDF806103046FFF73A +:1076900030FD9DF80300BDF8061040F010008DF895 +:1076A0000300BDF80300ADF81400FF233046059A2F +:1076B00006F028FC684606F0D0FA0028E0D006B0B4 +:1076C00070BD10B50C4601F1140005F059F90146E2 +:1076D000627C2046BDE8104001F03ABA70B505461C +:1076E000042109F065F9040000D1FFDF04F1140161 +:1076F0000C46284605F028F921462846BDE870408A +:1077000005F029B970B58AB00C460646FBF7A3FE12 +:10771000050014D02878222827D30CB1A08890B176 +:1077200001208DF80C0003208DF8100000208DF84A +:10773000110054B1A088ADF81800206807E043F2AA +:1077400002000AB070BD0920FBE7ADF818000590F3 +:107750000421304609F02CF9040000D1FFDF04F1C8 +:10776000140005F024F9000701D40820E9E701F02E +:1077700051FE60B108A802210094CDE9011095F8EE +:10778000232003A930466368FFF734FCD9E71120B2 +:10779000D7E72DE9F04FB2F802A0834689B015462D +:1077A00089465046FBF757FE07460421504609F02C +:1077B000FFF80026044605964FF002080696ADF83D +:1077C0001C6007B9FFDF04B9FFDF4146504603F0F4 +:1077D00070FE50B907AA06A905A88DE80700424621 +:1077E000214650466368FFF794FB674807AB066085 +:1077F000DDE9051204F11400CDF80090CDE9032075 +:10780000CDE9013197F82320594650466B6805F0C1 +:1078100017F906000AD0022E04D0032E14D0042E2D +:1078200000D0FFDF09B03046BDE8F08FBDF81C0086 +:107830000028F7D00599CDE9001042462146504670 +:107840006368FFF793FBEDE7687840F00800687025 +:10785000E8E72DE9F04F9BB004464FF000084A4896 +:10786000ADF85480ADF83080ADF85080A0F80880B5 +:10787000ADF81480ADF81880ADF82080ADF81C800C +:10788000007916460D464746012808D0022806D042 +:10789000032804D0042802D008201BB0C4E72046E7 +:1078A0000CF03CFDD0BB28460CF038FDB0BB606846 +:1078B0000CF081FD90BB606848B1608921898842E5 +:1078C00002D8B1F5007F01D90C20E6E780460BAA6B +:1078D00006A92846FFF70FFA0028DED168688078ED +:1078E000C0F34100022808D19DF8190010F0380FAC +:1078F00003D028690CF056FD80B905A92069FFF76F +:10790000B2F90028C9D1206950B1607880079DF88C +:10791000150000F0380002D5D0B301E011E0B8BB8B +:107920009DF8140080060ED59DF8150010F0380F54 +:1079300003D060680CF036FD18B960680CF03BFDB0 +:1079400008B11020A9E707A96069FFF78CF90028A2 +:10795000A3D1606940B19DF81D0000F00701012925 +:107960003FD110F0380F3CD008A9A069FFF77BF990 +:10797000002892D19DF81C00800632D49DF820008A +:1079800080062ED4A06904E07C02002014000020B0 +:1079900027E040B19DF8210000F00701012920D126 +:1079A00010F0380F1DD0E06818B10078C8B11C285D +:1079B00017D20EAA611C2046FFF7C4F90120B94670 +:1079C00060F30F27BA4607468DF84E0042F60300D3 +:1079D000ADF84C000DF13B0217A928680AF089FDAB +:1079E00008B1072059E79DF85C0016A9CDF8009072 +:1079F000C01CCDE9019100F0FF0B00230BF2012226 +:107A0000514613A806F060F8F0BBBDF85800099085 +:107A1000FE482A8929690092CDE901106B89BDF8D9 +:107A20002C202868069906F04FF801007ED12078B6 +:107A30004FF0020AC10601D480062BD5ADF80C9098 +:107A4000606950B907A906A8FFF7ADF99DF81D00B8 +:107A500020F00700401C8DF81D009DF81C008DF8DB +:107A60004E7040F0C8008DF81C0042F60210ADF8D0 +:107A70004C000CA903AACDF800A0CDE901210023F8 +:107A800040F2032213A800E01EE0079906F01CF85C +:107A900001004BD1DD484D4608385B460089ADF802 +:107AA00039000EA8CDE90290CDF80490CDF81090E1 +:107AB0004FF007090022CDF80090BDF858104FF69E +:107AC000FF7005F047FF10B1FFF79DF8E5E69DF860 +:107AD0003800000625D52946012060F30F218DF8D6 +:107AE0004E704FF42450ADF84C00ADF81050627851 +:107AF0009DF81000002362F300008DF810006278FA +:107B0000CDF800A0520862F341008DF8100004AADD +:107B1000CDE9012540F2032213A805F0D5FF0100AD +:107B200004D1606888B32069A8B900E086E005A99F +:107B300006A8FFF738F96078800706D49DF815008D +:107B400020F038008DF8150005E09DF8140040F095 +:107B500040008DF814008DF84E7042F60110ADF81B +:107B60004C00208940F20121B0FBF1F201FB12022E +:107B7000606814ABCDF80080CDE90103002313A8A1 +:107B8000059905F0A1FF010058D12078C00729D040 +:107B9000ADF80C50A06950B908A906A8FFF703F981 +:107BA0009DF8210020F00700401C8DF821009DF871 +:107BB00020008DF84E7040F040008DF8200042F615 +:107BC0000310ADF84C0015A903AACDF800A0CDE92B +:107BD0000121002340F2032213A8089905F074FF45 +:107BE00001002BD1E06868B32946012060F30F2122 +:107BF0008DF84E7042F60410ADF84C00E06800239A +:107C000002788DF8602040788DF86100E06818AA4D +:107C10004088ADF86200E06800798DF86400E068A3 +:107C2000C088ADF86500CDF80090CDE901254FF48E +:107C3000027213A805F048FF010003D0099800F074 +:107C4000B3FF2AE6714803210838017156B1008953 +:107C50003080BDF850007080BDF83000B080BDF8B5 +:107C60005400F080002018E670B501258AB0164651 +:107C70000B46012802D0022816D104E08DF80E50E0 +:107C80004FF4205003E08DF80E5042F60100ADF89D +:107C90000C005BB10024601C60F30F2404AA08A947 +:107CA00018460AF026FC18B107204AE5102048E5DE +:107CB00004A99DF820205548CDE90021801E02909E +:107CC0000023214603A802F2012205F0FDFE10B1B7 +:107CD000FEF799FF35E54D4808380EB1C18831806F +:107CE000057100202DE5F0B593B0074601268DF80B +:107CF0003E6041F60100ADF83C0012AA0FA93046E3 +:107D0000FFF7B2FF002848D1404C0025083CE7B3FC +:107D10001C2102A81CF0EDFA9DF808008DF83E60C9 +:107D200040F020008DF8080042F60520ADF83C0038 +:107D30000E959DF83A00119520F00600801C8DF8F4 +:107D40003A009DF838006A4620F0FF008DF83800B0 +:107D50009DF8390009A920F0FF008DF839000420B2 +:107D6000ADF82C00ADF830000EA80A9011A80D90C7 +:107D70000FA80990ADF82E5002A8FFF76AFD002861 +:107D80000BD1BDF80000608100E008E0BDF8040000 +:107D9000A081401CE0812571002013B0F0BD6581F9 +:107DA000A581BDF84800F4E72DE9F74F1749A0B0C9 +:107DB0000024083917940A79A146012A04D0022A1E +:107DC00002D0082023B02FE5CA88824201D00620C5 +:107DD000F8E721988A46824201D10720F2E7012084 +:107DE0002146ADF848004FF6FF7860F30F21ADF85B +:107DF0004A808DF86E0042F6020B06918DF87240B3 +:107E0000ADF86CB0ADF870401CA901E08402002010 +:107E10001391ADF8508012A805F043FF00252E46BF +:107E20002F460DAB072212A9404605F03DFF78B161 +:107E30000A285DD195B38EB3ADF86450ADF8666095 +:107E40009DF85E008DF8144019AC012864D06BE0F9 +:107E50009DF83A001FB3012859D1BDF83810594593 +:107E60001FD118A809A901940294CDE90310072095 +:107E70000090BDF8361010230022404605F094FF14 +:107E8000B0BBBDF86000042801D006284AD1BDF877 +:107E90002410219881423AD10F2093E73AE001283B +:107EA00035D1BDF83800B0F5205F03D042F60101AE +:107EB00088422CD1BAF80600BDF83610884201D1AC +:107EC000012700E0002705B19EB1219881421ED113 +:107ED00018A809AA01940294CDE903200720009074 +:107EE0000D4610230022404605F05EFF00B902E077 +:107EF0002DE04E460BE0BDF86000022801D01028AE +:107F000010D1C0B217AA09A90AF0D4FA50B9BDF825 +:107F1000369086E7052055E705A917A8221D0AF027 +:107F2000E8FA08B103204DE79DF814000023001D76 +:107F3000C2B28DF8142022980092CDE901401BA80E +:107F4000069905F0C1FD10B902228AF80420FEF757 +:107F50005AFE37E710B50B46401E88B084B205AA1A +:107F600000211846FEF7EEFE00200DF1080C06AACF +:107F700005A901908CE8070007200090012300224A +:107F800021464FF6FF7005F0E5FC0446BDF81800E9 +:107F9000012800D0FFDF2046FEF735FE08B010BDF7 +:107FA000F0B5FF4F044687B038790E46032804D059 +:107FB000042802D0082007B0F0BD04AA03A9204677 +:107FC000FEF799FE0500F6D160688078C0F34100A5 +:107FD00002280AD19DF80D0010F0380F05D0206955 +:107FE0000CF0E0F908B11020E5E7208905AA216925 +:107FF0008DE807006389BDF810202068039905F01B +:1080000063FD10B1FEF7FFFDD5E716B1BDF8140012 +:108010003080042038712846CDE7F8B50C000646BC +:108020000BD001464FF6FF7500236A46284605F03F +:108030003DFF20B1FEF7E7FDF8BD1020F8BD694611 +:108040002046FEF710FE0028F8D1A078314600F057 +:1080500001032846009A05F055FFEBE730B587B0DD +:10806000144600220DF1080C05AD01928CE82C009D +:10807000072200920A46014623884FF6FF7005F05A +:1080800069FCBDF814102180FEF7BDFD07B030BDBE +:1080900070B50D46042108F08BFC040000D1FFDF11 +:1080A000294604F11400BDE8704004F079BC70B5B5 +:1080B0000D46042108F07CFC040000D1FFDF2946B6 +:1080C00004F11400BDE8704004F08DBC70B50D469D +:1080D000042108F06DFC040000D1FFDF294604F103 +:1080E0001400BDE8704004F0A5BC70B5054604213D +:1080F00008F05EFC040000D1FFDF2146284623681B +:10810000BDE870400122FEF74BBF70B50646042162 +:1081100008F04EFC040000D1FFDF04F1140004F06D +:108120002FFC401D20F0030511E0011D00880022F6 +:10813000431821463046FEF733FF00280BD0607C01 +:10814000ABB2684382B2A068011D08F0EEFAA068E5 +:1081500041880029E9D170BD70B50546042108F0B9 +:1081600027FC040000D1FFDF214628466368BDE8F4 +:1081700070400222FEF714BF70B50E46054601F0AE +:1081800049F9040000D1FFDF01202072667265808A +:10819000207820F00F00001D20F0F000403020700B +:1081A000BDE8704001F039B910B50446012900D08E +:1081B000FFDF2046BDE810400121FAF713B92DE991 +:1081C000F04F97B04FF0000A0C008346ADF814A0B2 +:1081D000D04619D0E06830B1A068A8B10188ADF8E8 +:1081E0001410A0F800A05846FBF735F9070043F239 +:1081F000020961D0387822285CD30421584608F05F +:10820000D7FB050005D103E0102017B0BDE8F08FC3 +:10821000FFDF05F1140004F0B3FB401D20F003065E +:10822000A078012803D0022801D00720EDE721889B +:1082300007AA584605F005FD30BB07A805F00DFD5F +:1082400010BB07A805F009FD48B99DF826000128D4 +:1082500005D1BDF82400A0F52451023902D04FF415 +:108260005050D2E7E068B0B1CDE902A007200090FD +:1082700005AACDF804A00492A2882188BDF8143084 +:10828000584605F067FB10B1FEF7BDFCBDE7A168DD +:10829000BDF8140008809DF81F00C00602D543F207 +:1082A0000140B2E70B9838B1A1780078012905D0D8 +:1082B00080071AD40820A8E74846A6E7C007F9D0E7 +:1082C00002208DF83C00A8684FF00009A0B1697C3D +:1082D0004288714391420FD98AB2B3B2011D08F0AE +:1082E000DAF98046A0F800A006E003208DF83C00F3 +:1082F000D5F800804FF001099DF8200010F0380FEC +:1083000000D1FFDF9DF820002649C0F3C2000844D9 +:1083100097F8231010F8010C884201D90F2074E758 +:108320002088ADF8400014A90095CDE9019143469D +:1083300007220FA95846FEF75DFE002891D19DF84F +:10834000500050B9A078012807D1687CB3B27043BF +:1083500082B2A868011D08F0B2F9002055E770B597 +:10836000064615460C460846FEF70CFC002805D1CB +:108370002A4621463046BDE8704075E470BD13E5DD +:1083800070B51E4614460D000ED06CB1616859B12F +:1083900060B10349C988814208D0072070BD000040 +:1083A0007C020020FA2F00001020F7E72068FEF77B +:1083B000E9FB0028F2D1324621462846BDE870404C +:1083C000FFF747BA70B515460C0006D038B1FE4924 +:1083D0000989814203D00720E0E71020DEE720680A +:1083E000FEF7D0FB0028D9D129462046BDE87040D1 +:1083F000D6E570B5064686B00D46144610460BF01D +:10840000B3FFD0BB60680BF0D6FFB0BBA6F57F40D2 +:10841000FF3803D03046FBF71EF880B12846694686 +:10842000FEF7E3FC00280CD19DF810100F2008295E +:108430003CD2DFE801F008060606060A0A0843F205 +:10844000020006B0AAE70320FBE79DF8021001290D +:1084500008D1BDF80010B1F5C05FF2D06FF4C05282 +:10846000D142EED09DF8061001290DD1BDF80410BF +:10847000A1F52851062907D200E028E0DFE801F045 +:10848000030304030303DCE79DF80A1001290ED15E +:10849000BDF80810B1F5245FD3D0A1F524510239FD +:1084A000CFD00129CDD0022901D1CAE7FFDF606812 +:1084B00078B9002305AA2946304605F0F7FC10B12B +:1084C000FEF7A1FBBDE79DF81400800601D4102043 +:1084D000B7E76188224628466368FFF7BFFDB0E72B +:1084E0002DE9F043814687B08846144610460BF0CC +:1084F0003BFF18B1102007B0BDE8F083002306AAA7 +:108500004146484605F0D2FC18B100BFFEF77BFBA0 +:10851000F1E79DF81800C00602D543F20140EAE7F2 +:108520000025072705A8019500970295CDE903507E +:1085300062884FF6FF734146484605F035FC060059 +:1085400013D160680BF010FF60B960680195CDE948 +:10855000025000970495238862884146484605F0FA +:1085600023FC0646BDF8140020803046CEE739B122 +:10857000954B0A889B899A4202D843F203007047C0 +:108580001DE610B586B0904C0423ADF81430638915 +:1085900043B1A4898C4201D2914205D943F2030030 +:1085A00006B010BD0620FBE7ADF8101000210091C9 +:1085B0000191ADF8003002218DF8021005A9029159 +:1085C00004A90391ADF812206946FFF7F8FDE7E72B +:1085D0002DE9FC4781460E4608460BF09FFE88BBFE +:1085E0004846FAF738FF5FEA00080AD098F800001A +:1085F000222829D30421484608F0DAF9070005D1DA +:1086000003E043F20200BDE8FC87FFDF07F114003E +:1086100004F0CDF905463078012803D0022804D0B3 +:108620000720F0E7A8070FD502E015F01C0F0BD0CC +:10863000B079341DC00709D0E08838B1A0680BF0CC +:108640006DFE18B11020DEE70820DCE732782088C4 +:10865000002628B3A0F201130721112B18D20CD247 +:10866000DFE803F00B090D0B1D0B121D100B0B1D8A +:108670001D1D1D0B1D00022A11D10846C3E7012A4A +:10868000FBD00CE02A0700E0EA06002AF5DA06E053 +:10869000A0F5C0721F2A02D97D3A022AEDD8C6B2CF +:1086A00000F0B8FE50B198F82300CDE90006FA8931 +:1086B000234639464846FEF7EAFCA4E71120A2E724 +:1086C0002DE9F04F8BB01F4615460C468346002619 +:1086D000FAF7C1FE28B10078222805D208200BB095 +:1086E00094E543F20200FAE7B80801D00720F6E764 +:1086F000032F00D100274FF6FF79CCB1022D73D3A1 +:1087000020460BF058FE30B904EB0508A8F1010033 +:108710000BF051FE08B11020E1E7AD1EAAB22146D0 +:10872000484605F06DFC38F8021C88425CD1ADB2B9 +:108730002549B80702D58889401C00E001201FFAAE +:1087400080F8F80701D08F8900E04F4605AA41461E +:10875000584605F076FA4FF0070A4FF00009ACB31F +:10876000204608E0408810283ED8361D304486B2A6 +:10877000AE4239D2A01902884245F3D354E000BF7B +:108780009DF8170002074FD584B304EB0608361D89 +:10879000B8F80230B6B2102B26D89A19AA4223D8BC +:1087A000B8F8002091421FD1C00620D5CDE900A91C +:1087B0000DF1080C0AAAA11948468CE80700B8F880 +:1087C00000100022584603E07C0200202CE00BE061 +:1087D00005F0C0F810B1FEF716FA80E7B8F802000D +:1087E000BDF82810884202D00B2078E704E0B8F8E2 +:1087F0000200304486B206E0C00604D55846FEF7B3 +:1088000078FC002888D19DF81700BDF81A1020F0D8 +:1088100010008DF81700BDF81700ADF80000FF2319 +:108820005846009A05F06EFB05A805F016FA18B92F +:10883000BDF81A10B942A3D90421584608F0B8F877 +:10884000040000D1FFDFA2895AB1CDE900A94D464D +:10885000002321465846FEF71AFC0028BDD1A58109 +:108860003DE700203BE72DE9FF4F8BB01E46170088 +:108870000D464FF0000412D0B00802D007200FB010 +:10888000C4E4032E00D100265DB108460BF08AFD3A +:1088900028B93888691E08440BF084FD08B11020FF +:1088A000EDE7C74AB00701D5D18900E00121F00703 +:1088B0004FF6FF7802D0D089401E00E0404686B2D5 +:1088C00006AA0B9805F0BDF94FF000094FF0070B11 +:1088D0000DF1140A39E000BF9DF81B00000734D5E4 +:1088E000CDF80490CDF800B0CDF80890CDE9039A0A +:1088F000434600220B9805F057FA60BB05B3BDF85C +:1089000014103A8821442819091D8A4230D3BDF831 +:108910001E2020F8022BBDF8142020F8022BCDE9F0 +:1089200000B9CDE90290CDF810A0BDF81E10BDF839 +:10893000143000220B9805F037FA08B103209EE7A7 +:10894000BDF814002044001D84B206A805F085F986 +:1089500020B10A2806D0FEF756F990E7BDF81E10A0 +:10896000B142B9D934B17DB13888A11C884203D253 +:108970000C2084E7052082E722462946404605F080 +:108980003FFB014628190180A41C3C80002076E7AB +:1089900010B504460BF0E8FC08B1102010BD884863 +:1089A000C0892080002010BDF0B58BB00D46064672 +:1089B000142103A81BF09DFC01208DF80C008DF8FC +:1089C000100000208DF81100ADF814503046FAF771 +:1089D00042FD48B10078222812D30421304607F026 +:1089E000E7FF040005D103E043F202000BB0F0BD45 +:1089F000FFDF04F11400074603F0D9FF800601D41D +:108A00000820F3E7207C022140F00100207409A82F +:108A10000094CDE90110072203A930466368FEF7F0 +:108A2000E9FA20B1217C21F001012174DEE7294619 +:108A30003046F9F7C8FC08A9384603F0A7FF00B193 +:108A4000FFDFBDF82040172C01D2172000E02046A0 +:108A5000A84201D92C4602E0172C00D21724214647 +:108A60003046FFF724FB21463046F9F7D2F90020C3 +:108A7000BCE7F8B51C4615460E46069F08F0CAF836 +:108A80002346FF1DBCB231462A46009407F0B5FCD0 +:108A9000F8BD70B50C4605460E2120461BF007FCBC +:108AA000002020802DB1012D01D0FFDF76E40620CB +:108AB00000E00520A07171E410B5488008781346E5 +:108AC00020F00F00001D20F0F00080300C460870F0 +:108AD0001422194604F108001BF0AFFB00F09DFCC6 +:108AE0003748046010BD2DE9F047DFF8D890491DE4 +:108AF000064621F0030117460C46D9F8000007F09E +:108B000092FD050000D1FFDF4FF000083560A5F8A9 +:108B100000802146D9F8000007F085FD050000D14E +:108B2000FFDF7560A5F800807FB104FB07F1091D28 +:108B30000BD0D9F8000007F076FD040000D1FFDF6C +:108B4000B460C4F80080BDE8F087C6F80880FAE792 +:108B50002DE9F0411746491D21F00302194D064643 +:108B600001681446286807F089FD22467168286864 +:108B700007F084FD3FB104FB07F2121D03D0B1687A +:108B8000286807F07BFD042007F0BAFE04460420A5 +:108B900007F0BEFE201A012804D12868BDE8F04184 +:108BA00007F036BDBDE8F08110B50C4605F015F8AC +:108BB00000B1FFDF2046BDE81040FEF724B80000FA +:108BC0007C0200201400002038B50C468288817B8E +:108BD00019B14189914200D90A462280C188121DEB +:108BE00090B26A4606F092FFBDF80000032800D359 +:108BF0000320C1B2208800F0A3FF38BD38B50C4671 +:108C00008288817B19B10189914200D90A4622806C +:108C1000C188121D90B26A4606F078FFBDF80000C8 +:108C2000022800D30220C1B2208800F089FF401C36 +:108C3000C0B238BD2DE9FE4F0C46FD4981464022A9 +:108C4000D1E90201CDE9010109F1030020F003019E +:108C5000C91C21F0030100916846114607F0C5FCCC +:108C6000F44E002C02D1F44A00999160009901441D +:108C70000091357F05F1010504D1E8B209F0C0FB90 +:108C800000B1FFDF009800EB0510C01C20F00301CD +:108C900000915CB9707AB27A1044C2B200200870B8 +:108CA000308C80B204F021FE00B1FFDF0098316A01 +:108CB000084400902146684600F00DFF0098C01C53 +:108CC00020F003000090B37AF27A717A04B10020A8 +:108CD00007F081FD0099084400902146684600F0A5 +:108CE0003AFF00273D46B24696F801800CE0284640 +:108CF00000F0D4FE064681788088F9F721F9717872 +:108D00006D1C00FB0177EDB24545F0D10098C01C09 +:108D100020F00300009004B100203946F9F71BF958 +:108D200000990027084400903D469AF801800CE025 +:108D3000284600F0B3FE0646C1788088FEF763FC43 +:108D400071786D1C00FB0177EDB24545F0D10098BC +:108D5000C01C20F00300009004B100203946FEF74B +:108D60005BFC00994FF000080844009045469AF8D3 +:108D700001700EE0284600F091FE0646807B30B17F +:108D800006F1080001F0DDFE727800FB02886D1C20 +:108D9000EDB2BD42EED10098C01C20F0030000905F +:108DA00004B10020414601F0D0FE00990844009033 +:108DB0002146684600F049FE0098C01D20F00702D9 +:108DC00000922CBB9D490020FAF747F8FBF715FBF2 +:108DD000984801AA00211030F8F7CEFA00B1FFDF61 +:108DE0009AF81D00FEF77FFF00B1FFDF91484FF4B6 +:108DF000F67144301BF07DFA8E480421443080F82F +:108E0000E91180F8EA11062180F8EB1103210171C4 +:108E10000099A1EB0900BDE8FE8F70B5854C0646B0 +:108E20004434207804EB4015E078083590B9A01957 +:108E300090F8E80100280ED0A0780F2800D3FFDFBB +:108E4000202128461BF055FA687866F30200687006 +:108E50000120E070284670BD2DE9F04105460C4622 +:108E600000270078052190463E46B1EB101F00D048 +:108E7000FFDF287A50B101280ED0FFDFA8F800608C +:108E80000CB1278066800020BDE8F081012709260B +:108E900074B16888A08008E00227142644B168886D +:108EA000A0802869E060A88A2082287B2072E5E7FC +:108EB000A8F80060E7E710B55F4C6068C11D21F0BD +:108EC0000701814200D0FFDF5A48012100220170D2 +:108ED00042700172417203238372C1720273027481 +:108EE000052202831F224283417455A242610A2255 +:108EF000027741774FF4B06101626168416010BD53 +:108F000030B54D4C1568636810339D4202D2042081 +:108F1000136030BD474B5D785A6802EB0512107044 +:108F200051700320D080172090800120D070907065 +:108F3000002090735878401C587060681030606052 +:108F4000002030BD70B506463A480024457807E059 +:108F5000204600F0A3FD0178B14204D0641CE4B2C5 +:108F6000AC42F5D1002070BDF7B5074608780C4635 +:108F700010B3FFF7E7FF0546A7F12006202F06D024 +:108F8000052E19D2DFE806F00F2B2B151A0000F082 +:108F900090FD0DB1697800E00021401AA17880B2FF +:108FA0000844FF2808D8A07830B1A088022824D22D +:108FB00002E06088172820D20720FEBD207AE0B1A9 +:108FC00061881729F8D3A1881729F5D3A179002939 +:108FD000F2D0E1790029EFD0402804D9ECE7242F22 +:108FE0000BD1207A48B161884FF6FB70814202D8DC +:108FF000A188814201D90420FEBD65B9207802AA6A +:109000000121FFF77DFF0028F6D12078FFF79AFFB6 +:10901000050000D1FFDF052E25D2DFE806F003189A +:109020001B151E00A0786870A088E8801CE0000076 +:10903000B0460200980300201C0000200000002021 +:109040006E524635780000006088A8800CE0A07859 +:10905000A87009E0A078E87006E054F8020FA86054 +:109060006068E86000E0FFDF0020FEBD1A2835D010 +:109070000DDC132832D2DFE800F01B31203131271C +:109080002723252D313129313131312F0F0030285F +:1090900002D003DC1E2821D1072070473A38092866 +:1090A0001CD2DFE800F0151B0F1B1B1B1B1B07004E +:1090B0000020704743F20400704743F202007047FB +:1090C000042070470D2070470F207047082070471C +:1090D0001120704713207047062070470320704707 +:1090E00010B5007800F0010006F001FDBDE8104069 +:1090F000BCE70EB5017801F001018DF80010417850 +:1091000001F001018DF801100178C1F340018DF8E3 +:1091100002104178C1F340018DF8031001788908ED +:109120008DF80410417889088DF8051081788DF844 +:109130000610C1788DF8071000798DF80800684690 +:1091400005F0ACFAFFF792FF0EBD2DE9F84FDFF8FE +:10915000F883FE4C00261FE0012000F03FFD0120B7 +:10916000FFF75BFE054640214746D8F8080007F0A8 +:109170005AFA686000B9FFDF686805F03EF8A8B1E8 +:109180002846FAF75AFC284600F02EFD20B9402266 +:109190006968B86807F072FA94F9E9010428DBDA23 +:1091A000022007F0ADFB07460025A6E040226968D3 +:1091B000D8F8080007F062FAF2E7B8F80210404663 +:1091C000491C89B2A8F80210B94201D3002141809C +:1091D0000221B8F8020007F0EBFB002865D0B8F8D0 +:1091E0000200694606F0F1FBFFF740FF00B1FFDF28 +:1091F0009DF8000078B1B8F8020007F01DFD5FEAA5 +:10920000000900D1FFDF484606F08BFF18B1B8F81F +:10921000020002F03DF9B8F8020007F0FBFC5FEA3B +:10922000000900D1FFDF484606F073FFE8BB0321C9 +:10923000B8F8020007F0BCFB5FEA000B48D1FFDF83 +:1092400046E000BFDBF8100010B10078FF2849D0DD +:10925000022000F0C3FC0220FFF7DFFD82464846F3 +:1092600007F063F8CAF8040000B9FFDFDAF8040079 +:1092700007F02BF9002100900170B8F80210504659 +:10928000AAF8021001F00AFE484607F020F900B9DA +:10929000FFDF504600F0A8FC18B99AF8010000075B +:1092A00004D50099CBF8101012E024E0DBF8100090 +:1092B00038B10178491C11F0FF01017008D1FFDFBE +:1092C00006E000221146484600F0BDFB00B9FFDF72 +:1092D00094F9EA01022805DBB8F8020001F0A3FDC9 +:1092E0000028AFD194F9E901042804DB484607F0CF +:1092F00052F900B101266D1CEDB2BD4204D294F9C1 +:10930000EA010228BFF659AF002E7FF423AFBDE873 +:10931000F84F032000F062BC10B58B4CE060086889 +:109320002061AFF2D91002F012FD607010BD8748C5 +:1093300000214438017084480170854941607047BC +:1093400070B505464FF080500C46D0F8A410491C6B +:1093500005D1D0F8A810C9430904090C0BD050F866 +:10936000A01F01F001012970416821608068A08080 +:10937000287830B970BD062120460AF0AAFC0120E9 +:109380002870607940F0C000607170BD70B54FF01A +:1093900080540D46D4F88010491C0BD1D4F88410A9 +:1093A000491C07D1D4F88810491C03D1D4F88C107B +:1093B000491C0CD0D4F880100160D4F884104160AE +:1093C000D4F888108160D4F88C10C16002E01021BC +:1093D0000AF07FFCD4F89000401C0BD1D4F8940024 +:1093E000401C07D1D4F89800401C03D1D4F89C004D +:1093F000401C09D054F8900F286060686860A0682D +:10940000A860E068E86070BD2846BDE870401021A3 +:109410000AF05FBC4D480079FFE470B54B4CE07832 +:1094200030B3207804EB4010407A00F0070020446D +:1094300090F9E801002800DCFFDF2078002504EB2C +:109440004010407A00F00700011991F8E801401E31 +:1094500081F8E8012078401CC0B220700F2800D1AC +:109460002570A078401CA0700AF096FBE57070BDD6 +:10947000FFDF70BD3EB50546032107F099FA0446AB +:10948000284607F0C7FB054604B9FFDF206918B17D +:109490000078FF2800D1FFDF01AA6946284600F0C6 +:1094A000D2FA60B9FFDF0AE0002202A9284600F0E4 +:1094B000CAFA00B9FFDF9DF8080000B1FFDF9DF890 +:1094C0000000411E8DF80010EED2206901998842FB +:1094D00001D1002020613EBD70B50546A0F57F405A +:1094E0000C46FF3800D1FFDF012C01D0FFDF70BD3B +:1094F000FFF790FF040000D1FFDF207820F00F007D +:10950000401D20F0F0005030207065800020207257 +:1095100001202073BDE870407FE72DE9F041164639 +:109520000D460746FFF776FF040000D1FFDF2078E5 +:1095300020F00F00401D20F0F000503020706780B8 +:1095400001202072286805E01C000020DC030020B8 +:10955000C81400202061A888A0822673BDE8F041CD +:109560005BE77FB5FFF7EEFC040000D1FFDF02A947 +:109570002046FFF729FB054603A92046FFF73EFBDF +:109580008DF800508DF80100BDF80800001DADF801 +:109590000200BDF80C00001DADF80400E088ADF835 +:1095A0000600684606F08CFA002800D0FFDF7FBD79 +:1095B0002DE9F047DFF8FC930546002799F80000F5 +:1095C00010B10820BDE8F08728460AF0CDFE08B1AA +:1095D0001020F7E7F84C207808B9FFF76CFCA07A68 +:1095E000617A0844C6B200F064FAB04207D2301A79 +:1095F000C1B22A460020FFF783FC0700E2D1D9F868 +:1096000004004E46C01C20F00300C9F8040000F01E +:1096100040FB716800EB010801214046FFF70AFB9F +:10962000064629684044884202D8B6F5803F15D3E3 +:1096300028600020FFF786FC05000DD005F113001F +:10964000D9F8041020F003004E46884200D0FFDF16 +:109650006078401E607075600420B3E700214046CA +:10966000FFF7E8FA0446A64200D0FFDF04EB08014A +:10967000C9F8041029604FF6FF71A9F80210012102 +:1096800089F8001038469DE72DE9F0410446C948A5 +:1096900017460E46007810B10820BDE8F081084654 +:1096A0000AF03CFE08B11020F7E7C34D287808B94E +:1096B000FFF701FC601E1E2807D8012C22D130784C +:1096C000FE281FD828770020E7E7A4F120001F28F4 +:1096D00005D8E0B23A463146BDE8F04144E4A4F191 +:1096E00040001F2805D831462046BDE8F04100F073 +:1096F000A3BAA4F1A0001F2804D80020A02C03D0F6 +:10970000A12C06D00720C8E7317801F00101697764 +:10971000C3E731680922F82901D38B0701D010462D +:10972000BBE76B7C03F00303012B04D16B8BD733B6 +:109730009CB28C42F3D82962AFE72DE9F04781460D +:109740000E4608460AF010FE48B948460AF02AFEBE +:1097500028B909F1030020F00301494501D0102088 +:1097600030E795484FF0000A4430817869B141787C +:10977000804600EB411408343788324600212046E9 +:1097800000F040FA050004D027E0A6F800A005206C +:1097900018E7B9F1000F24D03088B84201D90C2560 +:1097A0001FE0607800F00705284600F017FA08EB84 +:1097B0000507324697F8E8014946401C87F8E8015A +:1097C000204607F5F47700F01DFA05463878401E6C +:1097D0003870032000F002FA2DB10C2D01D0A6F84C +:1097E00000A02846EEE66078724E00F007010129DD +:1097F00023D002290CD0032933D0FFDF98F80110C1 +:109800004046491CC9B288F801100F2934D035E010 +:10981000616821B1000702D46088FFF72BFE98F839 +:10982000EA014746012802D1707802F0AFFA97F9B1 +:10983000EA010428E2DBFFDFE0E7616819B14022BA +:10984000B06806F01BFF98F8E9014746032802D1EB +:10985000707802F09BFA97F9E9010428CEDBFFDF6C +:10986000CCE7C00602D56088FFF704FE98F9EB014B +:109870000628C3DBFFDFC1E780F801A08178491E1D +:109880008170617801F0070101EB080090F8E811A0 +:10989000491C80F8E811A4E770B50D4604460AF0AB +:1098A0003DFD18B928460AF05FFD08B1102070BDD3 +:1098B00029462046BDE8704008F0D9BD70B5044681 +:1098C00015460E4608460AF029FD18B928460AF042 +:1098D0004BFD08B1102070BD022C03D0102C01D01C +:1098E000092070BD2A463146204608F0E3FD0028D5 +:1098F000F7D0052070BD70B514460D4606460AF037 +:109900000DFD38B928460AF02FFD18B920460AF097 +:1099100049FD08B1102070BD22462946304608F0A6 +:10992000E8FD0028F7D0072070BD3EB504460AF0D8 +:109930001BFD08B110203EBD684604F00FFEFFF786 +:1099400095FB0028F7D19DF806002070BDF80800AF +:109950006080BDF80A00A08000203EBD70B50546BD +:109960000C4608460AF01EFD20B93CB120680AF0FA +:10997000FBFC08B1102070BDA08828B12146284604 +:10998000BDE87040FDF7BEBE092070BD70B504464D +:109990000D4608460AF0C2FC30B9601E1E2818D8D1 +:1099A00028460AF0BBFC08B1102070BD022C05D976 +:1099B000072070BD1C0000209803002004B9FFDFC1 +:1099C000F94800EB840050F8041C2846BDE87040BC +:1099D0000847A4F120001F2805D829462046BDE8E5 +:1099E0007040FAF792BCF02CE2D1A8680AF096FC1D +:1099F0000028D9D1284606F0CBF8BDE87040FFF723 +:109A000035BB70B504460D4608460AF0ADFC30B9CA +:109A1000601E1E280DD828460AF080FC08B11020D0 +:109A2000C7E7012C01D0022C01D10620C1E7072095 +:109A3000BFE7A4F120001F28F9D829462046BDE839 +:109A40007040FAF7BABC06F033BB38B50446D748C5 +:109A5000007B00F00105D9B9F9F78BFA0DB1226846 +:109A600000E00022D2484178C06804F06EFBD04884 +:109A70001030C0788DF8000010B1012802D004E049 +:109A8000012000E000208DF80000684604F0DFFDB2 +:109A9000002D02D020682830206038BD30B5C34D7D +:109AA00004466878A04200D8FFDF686800EB041025 +:109AB00030BD70B5BD4800252C46467807E02046ED +:109AC000FFF7ECFF4078641C2844C5B2E4B2B4420E +:109AD000F5D128466DE72DE9F0410C46064600F029 +:109AE00006F907463068C01C20F00302326014BB40 +:109AF000AE483B46082124300AF0EAFA002409E087 +:109B0000082C10D2DFE804F0060408080A04040652 +:109B1000A84804E0A84802E0A84800E0A8480AF0E5 +:109B2000F7FA054600E0FFDFA54200D0FFDF641C26 +:109B3000E4B2082CE4D3306800EB07103060ACE5E9 +:109B4000021D5143452900D245210844C01CB0FBE9 +:109B5000F2F0C0B270472DE9FC5F064693484FF023 +:109B600000088B464746444690F8019022E0204684 +:109B7000FFF794FF050000D1FFDF6878694638449D +:109B8000C7B22846FFF720F8824601A92846FFF70A +:109B900035F80346BDF804005246001D81B2BDF8F9 +:109BA0000000001D80B206F081FF6A78641C00FB93 +:109BB0000288E4B24C45DAD13068C01C20F00300C2 +:109BC0003060BBF1000F00D000204246394606F05D +:109BD0007BFF316808443060BDE8FC9F7349443125 +:109BE00008710020C870704770494431CA782AB1A2 +:109BF0000A7801EB42110831814201D001207047FF +:109C0000002070472DE9F04106460078154600F027 +:109C10000F0400201080601E0F46052800D3FFDFD0 +:109C200061482A46103000EB8400394650F8043C65 +:109C30003046BDE8F041184770B50C46402802D0C8 +:109C4000412806D120E0A07861780D18E1788142A2 +:109C500001D90720ADE62078012801D91320A8E614 +:109C6000FF2D08D808F0B0FD064609F04CFF301A69 +:109C7000801EA84201DA12209BE64C4821688160D0 +:109C800021790173002094E6BDE87040084600F099 +:109C90005EB82DE9F0470027DFF810A13E463D46AB +:109CA000B9463C469AF801800AE02046FFF7F6FEE6 +:109CB0004178807B0E4410FB0155641CE4B27F1C8C +:109CC0004445F2D109EB8700C6EBC60100EB8100E9 +:109CD0009AF8092000EB850101EBC2019AF80A20ED +:109CE0009AF80B0001EBC20101EB80006AE42DE958 +:109CF000F047DFF8B8900026344699F8090099F843 +:109D00000A2099F801700244D5B299F80B2010444A +:109D100000F0FF0808E02046FFF7C0FE817B407896 +:109D200011FB0066641CE4B2BC42F4D199F809004E +:109D300099F80A10284428444044401C01B10121EC +:109D400008448419FF2C00D9FFDFE0B23AE438B5AB +:109D50000446407800F00300012803D002280BD00D +:109D6000072038BD606858B10AF025FBD0B960689B +:109D70000AF018FB20B915E060680AF0CFFA88B93C +:109D800069462046FCF71EF90028EAD1607800F009 +:109D90000300022816D19DF8000098B160680AF00F +:109DA00001FB78B1102038BDB046020098030020B6 +:109DB0001C000020B941000017AC00005D2F00001E +:109DC000F32101006189F8290DD8208988420AD839 +:109DD000607800F003020A48012A06D1D731026AEE +:109DE00089B28A4201D20920DDE794E80E0000F131 +:109DF000100585E80E000AB9002101830020D2E792 +:109E0000980300202DE9F04107461446884608468D +:109E100001F01CFD064608EB88001C22796802EB65 +:109E2000C0000D18688C58B14146384601F016FD47 +:109E3000014678680078C200082305F120000CE094 +:109E4000E88CA8B14146384601F00FFD014678681C +:109E500008234078C20005F1240006F066FC38B102 +:109E6000062121726681D0E90010C4E9031009E0DF +:109E7000287809280BD00520207266816868E06088 +:109E8000002028702046BDE8F04101F0D5BC072035 +:109E900020726681F4E72DE9F04116460D4607462B +:109EA000406801EB85011C2202EBC10144182046E9 +:109EB00001F0FDFC40B10021708865F30F2160F3D3 +:109EC0001F4107200AF0DEF909202070324629469A +:109ED0003846BDE8F04195E72DE9F0410E460746CA +:109EE00000241C21F07816E004EB8403726801EB77 +:109EF000C303D25C6AB1FFF78DFA050000D1FFDF22 +:109F00006F802A4621463046FFF7C5FF0120BDE895 +:109F1000F081641CE4B2A042E6D80020F7E770B5F7 +:109F2000064600241C21C0780AE000BF04EB84032D +:109F3000726801EBC303D5182A782AB1641CE4B215 +:109F4000A042F3D8402070BD282128461AF0AFF96E +:109F5000706880892881204670BD70B50346002056 +:109F60001C25DC780DE000BF00EB80065A6805EB8D +:109F7000C6063244167816B1128A8A4204D0401CB2 +:109F8000C0B28442F0D8402070BDF0B50446002035 +:109F90001C26E5780EE000BF00EB8007636806EB47 +:109FA000C7073B441F788F4202D15B78934204D0AD +:109FB000401CC0B28542EFD84020F0BD0078032895 +:109FC00001D000207047012070470078022801D09E +:109FD00000207047012070470078072801D000203A +:109FE0007047012070472DE9F041064688461078F9 +:109FF000F1781546884200D3FFDF2C781C27641CBB +:10A00000F078E4B2A04201D8201AC4B204EB840173 +:10A01000706807EBC1010844017821B141468847C7 +:10A0200008B12C7073E72878A042E8D1402028704E +:10A030006DE770B514460B880122A240134207D188 +:10A0400013430B8001230A22011D06F038FB047024 +:10A0500070BD2DE9FF4F81B00878DDE90E7B9A468F +:10A0600091460E4640072CD4019806F0E5FD040009 +:10A0700000D1FFDF07F1040820461FFA88F105F040 +:10A0800024FF050000D1FFDF204629466A4606F07E +:10A090006EF90098A0F80370A0F805A0284606F015 +:10A0A00014FA017869F306016BF3C71101702046B9 +:10A0B0001FFA88F105F04CFF00B9FFDF019803F0AB +:10A0C000B9FF06EB0900017F491C017705B0BDE827 +:10A0D000F08F2DE9F84F0E469A4691460746032128 +:10A0E00006F066FC0446008DDFF8B485002518B143 +:10A0F00098F80000B0421ED1384606F09DFD0700DA +:10A1000000D1FFDF09F10401384689B205F0DDFE18 +:10A11000050010D0384629466A4606F028F900980E +:10A1200000210A460180817004F054F80098C01D97 +:10A13000CAF8000021E098F80000B04216D104F1FE +:10A14000260734F8341F012000FA06F911EA090F36 +:10A1500000D0FFDF2088012340EA090020800A2286 +:10A16000391D384606F0C6FA067006E0324604F19C +:10A17000340104F12600FFF75CFF0A2188F8001083 +:10A180002846BDE8F88FFEB514460D46064602ABDC +:10A190000C220621FFF79DFF002826D0029968783F +:10A1A00012220A70801C487008224A80A8702088F9 +:10A1B00088806088C880A0880881E0884881002461 +:10A1C0000C20CDE900040523062229463046FFF77E +:10A1D00040FF2146002266F31F41F023104609F09C +:10A1E000A7FF6878801C68700120FEBDFEB514468C +:10A1F0000D460622064602AB1146FFF76AFF00280D +:10A2000012D0029B132000211870A87858700220E9 +:10A2100058809C800620CDE900010246052329468E +:10A220003046FFF716FF0120FEBD2DE9FE430C4628 +:10A23000804644E002AB0E2207214046FFF749FF6B +:10A24000002841D060681C2267788678BF1C06EB26 +:10A25000860102EBC1014518029814210170477074 +:10A260000A214180698A0181E98A4181A988818026 +:10A27000A9898181304601F0E9FA02990523072274 +:10A28000C8806F700420287000250E20CDE90005DD +:10A2900021464046FFF7DDFE294666F30F2168F3AD +:10A2A0001F41F0230022072009F042FF6078FD499A +:10A2B000801C607062682046921CFFF794FE606804 +:10A2C00080784028B6D10120BDE8FE83FEB50D465A +:10A2D000064638E002AB0E2207213046FFF7F9FEB2 +:10A2E000002835D068681C23C17801EB810203EB9C +:10A2F000C2028418029815220270627842700A2203 +:10A300004280A2894281A2888281084601F09EFA99 +:10A31000014602988180618AC180E18A0181A0881A +:10A32000B8B10020207000210E20CDE900010523E6 +:10A33000072229463046FFF78CFE6A68DA4928462C +:10A34000D21CFFF750FE6868C0784028C2D10120B7 +:10A35000FEBD0620E6E72DE9FE430C46814644E0BB +:10A36000204601F08EFAD0B302AB082207214846FE +:10A37000FFF7AFFE0028A7D060681C226578067939 +:10A38000AD1C06EB860102EBC10147180298B7F835 +:10A39000108006210170457004214180304601F093 +:10A3A00055FA0146029805230722C180A0F80480CF +:10A3B0007D70082038700025CDE90005214648460B +:10A3C000FFF747FE294666F30F2169F31F41F0238B +:10A3D0000022072009F0ACFE6078801C6070626883 +:10A3E000B2492046121DFFF7FEFD60680179402941 +:10A3F000B6D1012068E72DE9F34F83B00E4680E027 +:10A40000304601F03EFA002875D071681C2091F8A2 +:10A41000068008EB880200EBC2000C18414630466B +:10A4200001F023FA0146A078C30070684078C200AA +:10A4300004F1240006F095F907468088E18B401A64 +:10A4400080B2002581B3AA46218B814200D80846FC +:10A450008146024602AB07210398FFF73AFE01004E +:10A4600028D0BAF1000F03D0029AB88802251080D4 +:10A470008B46E28B3968A9EB05001FFA80FA0A4483 +:10A480000398009206F0D8FBED1D009A59465346FA +:10A49000009505F0E6FFE08B504480B2E083B98878 +:10A4A000884209D1012508E0FFE7801C4FF0010A2E +:10A4B00080B2C9E7002009E60025CDE90095238A8E +:10A4C000072231460398FFF7C4FDE089401EE08172 +:10A4D0008DB1A078401CA0707068F178427811FBB3 +:10A4E00002F1CAB2816901230E3006F0E8F880F863 +:10A4F00000800020E08372686D493046921DFFF7AE +:10A5000072FD7068817940297FF47AAF0120DDE522 +:10A5100070B5064648680D4614468179402910D129 +:10A5200004EB84011C2202EBC101084401F0E0F9B4 +:10A53000002806D06868294684713046BDE870401E +:10A5400059E770BDFEB50C460746002645E020469B +:10A5500001F097F9D8B360681C22417901EB8101C1 +:10A5600002EBC1014518688900B9FFDF02AB082280 +:10A5700007213846FFF7ADFD002833D002996078F7 +:10A5800016220A70801C4870042048806068407958 +:10A5900001F05CF901460298052307228180698950 +:10A5A000C1800820CDE9000621463846FFF751FD5D +:10A5B0006078801C6070A88969890844B0F5803F84 +:10A5C00000D3FFDFA88969890844A8816E81626889 +:10A5D00038492046521DFFF706FD60684179402941 +:10A5E000B5D10120FEBD30B5438C458BC3F3C70404 +:10A5F000002345B1838B641EED1AC38A6D1E1D4472 +:10A6000095FBF3F3E4B22CB1008918B1A04200D855 +:10A61000204603444FF6FF70834200D30346138065 +:10A620000C7030BD2DE9FC41074616460D464868C2 +:10A6300002EB86011C2202EBC10144186A4601A903 +:10A640002046FFF7D0FFA089618901448AB2BDF896 +:10A650000010914212D0081A00D50020608168686D +:10A66000407940280AD1204601F038F9002805D069 +:10A670006868294646713846FFF764FFBDE8FC81EB +:10A680002DE9FE4F8946804615465088032106F085 +:10A690008FF98346B8F8020040280DD240200CE024 +:10A6A00030000020BD9F0000CB9F0000D99F00001C +:10A6B000F1B80000DDB80000403880B282460146A3 +:10A6C000584601F0DEF800287ED00AEB8A001C22F2 +:10A6D000DBF8041002EBC0000C18204601F0E7F88C +:10A6E000002877D1B8F80000E18A88423CD8A189D7 +:10A6F000D1B348456ED100265146584601F0AEF818 +:10A70000218C0F18608B48B9B9F1020F62D3B8F8E9 +:10A7100004006083618A884226D80226A9EB0600DD +:10A720001FFA80F9B888A28B801A002814DD4946E8 +:10A73000814500DA084683B2688869680291396801 +:10A740000A44CDE9003206F065FADDE90121F61D83 +:10A75000009B009605F051FEA18B01EB090080B231 +:10A76000A083618B884207D9688803B05246594656 +:10A77000BDE8F04F01F0D9B81FD14FF009002872A1 +:10A78000B8F802006881D7E90001C5E90401608BCF +:10A79000A881284601F050F85146584601F05EF86D +:10A7A0000146DBF8040008230078C20004F1200011 +:10A7B00005F0BBFF0020A0836083A0890AF0FF02A0 +:10A7C000401EA081688800E004E003B05946BDE85F +:10A7D000F04F27E7BDE8FE8F2DE9F041064615460C +:10A7E0000F461C46184609F099FD18B9206809F073 +:10A7F000BBFD08B1102015E47168688C0978B0EBD6 +:10A80000C10F01D313200DE43946304601F026F87C +:10A810000146706808230078C20005F1200005F0A9 +:10A820004EFFD4E90012C0E900120020E3E710B5A2 +:10A830000446032106F0BCF80146007800F003004E +:10A84000022805D02046BDE8104001F114029AE428 +:10A850008A8A2046BDE81040C8E470B5044603214A +:10A8600006F0A6F8054601462046FFF774FD0028CD +:10A8700016D029462046FFF765FE002810D029464D +:10A880002046FFF723FD00280AD029462046FFF77F +:10A89000CCFC002804D029462046BDE87040AAE53B +:10A8A00070BD2DE9F0410C4680461EE0E17842780B +:10A8B00011FB02F1CAB2816901230E3005F035FFA8 +:10A8C000077860681C22C179491EC17107EB8701B6 +:10A8D000606802EBC10146183946204600F0D1FFFE +:10A8E00018B1304600F0DCFF20B16068C179002962 +:10A8F000DCD180E7FEF78EFD050000D1FFDF0A20E6 +:10A900002872384600F0A2FF68813946204600F0E0 +:10A91000ACFF0146606808234078C20006F12400BD +:10A9200005F003FFD0E90010C5E90310A5F8028087 +:10A93000284600F081FFB07800B9FFDFB078401EF4 +:10A94000B07058E770B50C460546032106F030F8A4 +:10A9500001464068C2792244C2712846BDE8704071 +:10A960009FE72DE9FE4F8246507814460F464FF080 +:10A97000000800284FD0012807D0022822D0FFDF8E +:10A980002068B8606068F86024E702AB0E220821F6 +:10A990005046FFF79EFB0028F2D0029815210523B0 +:10A9A0000170217841700A214180C0F80480C0F80C +:10A9B0000880A0F80C80628882810E20CDE9000812 +:10A9C000082221E0A678304600F040FF054606EB5D +:10A9D00086012C22786802EBC1010822465A02AB9C +:10A9E00011465046FFF775FB0028C9D00298072191 +:10A9F0000170217841700421418008218580C68042 +:10AA0000CDE9001805230A4639465046FFF721FBD9 +:10AA100087F80880DEE6A678022516B1022E13D04C +:10AA2000FFDF2A1D914602AB08215046FFF751FB7C +:10AA30000028A5D002980121022E017021784170D2 +:10AA40004580868002D005E00625EAE7A188C1801E +:10AA5000E1880181CDE90098052308223946504656 +:10AA6000D4E710B50446032105F0A2FF014600F12A +:10AA700008022046BDE8104073E72DE9F05F0C4660 +:10AA800001281DD0957992F80480567905EB85014F +:10AA90001F2202EBC10121F0030B08EB060111FBA1 +:10AAA00005F14FF6FF7202EAC10909F1030115FB36 +:10AAB0000611F94F21F0031A40B101283DD124E0DD +:10AAC0006168E57891F800804E78DFE7594678684C +:10AAD00005F0A9FD606000B9FFDF5946606819F014 +:10AAE00008FCE5705146786805F09DFD6168486195 +:10AAF00000B9FFDF6068426902EB090181616068AB +:10AB000080F800806068467017E0606852464169CE +:10AB1000786805F0B3FD5A466168786805F0AEFDC7 +:10AB2000032005F0EDFE0446032005F0F1FE201A97 +:10AB3000012802D1786805F06BFD0BEB0A00BDE837 +:10AB4000F09F02460021022097E773B5D24D0A20FC +:10AB50002870009848B100244FEA0D0005F045FD2B +:10AB6000002C01D1009969607CBD01240020F5E72B +:10AB700070B50C4615463821204619F0BAFB01265F +:10AB800066700A2104F11C0019F0B3FB05B9FFDF60 +:10AB9000297A207861F301002070A879002817D065 +:10ABA0002A4621460020FFF768FF61684020887030 +:10ABB0006168C8706168087161684871616888710E +:10ABC0006168288808816168688848816068868132 +:10ABD00070BDC878002802D0002201204DE77047E0 +:10ABE00070B50546002165F31F41002009F04AFBBE +:10ABF0000321284605F0DCFE040000D1FFDF2146DA +:10AC00002846FFF769F9002804D0207840F01000AA +:10AC10002070012070BD2DE9FF4180460E460F0CCB +:10AC2000FEF7F8FB050007D06F800321384605F0DA +:10AC3000BFFE040008D106E004B03846BDE8F0418C +:10AC40001321F9F7FBBEFFDF5FEA080005D0B8F17A +:10AC5000070F18D0FFDFBDE8FF8120782A4620F0DB +:10AC6000080020700020ADF8020002208DF80000DE +:10AC70004FF6FF70ADF80400ADF80600694638469F +:10AC8000F9F7EFFAE7E7C6F3072101EB81021C238E +:10AC9000606803EBC202805C042803D008280AD055 +:10ACA000FFDFD8E7012000904FF440432A462046BA +:10ACB00000F004FECFE704B02A462046BDE8F0418C +:10ACC000FFF7E9B82DE9F05F0027B0F80A90904649 +:10ACD0000C4605463E46B9F1400F01D2402001E046 +:10ACE000A9F140001FFA80FA287AC01E08286BD20A +:10ACF000DFE800F00D04192058363C477227102673 +:10AD0000002C6CD0D5E90301C4E902015CE0702796 +:10AD10001226002C63D00A2205F10C0104F1080070 +:10AD200019F08BFA50E071270C26002C57D0E868F8 +:10AD3000A06049E0742710269CB3D5E90301C4E95B +:10AD400002016888032105F033FE8346FEF762FBAB +:10AD500002466888508051465846FFF753F833E062 +:10AD600075270A26ECB1A88920812DE076271426C4 +:10AD7000BCB105F10C0004F1080307C883E8070023 +:10AD800022E07727102664B1D5E90301C4E9020166 +:10AD90006888032105F00CFE01466888FFF781FDF5 +:10ADA00012E01CE073270826CCB16888032105F067 +:10ADB000FFFD01460078C00606D56888FFF78CF8CD +:10ADC00010B96888F8F71DFEA8F800602CB127803C +:10ADD000A4F8069066806888A0800020AFE6A8F8F6 +:10ADE0000060FAE72DE9FC410C461E4617468046F6 +:10ADF000032105F0DDFD05460A2C0AD2DFE804F048 +:10AE000005050505050509090907042303E00623CF +:10AE100001E0FFDF0023CDE90076224629464046C7 +:10AE2000FFF717F92AE438B50546A0F57F40FF384B +:10AE300030D0284605F0EEFE040000D1FFDF2046AA +:10AE400005F073FA002815D001466A46204605F041 +:10AE50008EFA00980321B0F80540284605F0A8FDB9 +:10AE60000546052C03D0402C05D2402404E0007A8E +:10AE700080B1002038BD403CA4B2214600F001FD65 +:10AE800040B1686804EB84013E2202EBC101405AE4 +:10AE90000028EFD0012038BD300000202DE9F04F10 +:10AEA000044689B0408805F0B5FE050000D1FFDFFB +:10AEB00006AA2846616800F0BDFC069D001F81B20D +:10AEC00035F8032F6B888A4205D1042B0AD0052B55 +:10AED0001DD0062B15D022462846FFF7D1FB09B01E +:10AEE000BDE8F08F16462D1D224629463046F7F75D +:10AEF00054FA0828F3D1224629463046FCF749FC8B +:10AF0000EDE76088291D6368FAF7C8FCE7E7174694 +:10AF10006088032105F04CFD4FF000088DF8048097 +:10AF20000646ADF80680042FD9D36A79002AD6D018 +:10AF300028794FF6FF794FF01C0A13282CD008DC33 +:10AF4000012878D0062847D0072875D0122874D158 +:10AF500006E0142872D0152871D016286DD1ACE106 +:10AF60000C2F6AD1307800F00301022965D140F03E +:10AF7000080030706879B07001208DF804002889CD +:10AF8000ADF808006889ADF80A00A889ADF80C0092 +:10AF9000E889ADF80E0019E0B07890429FD1307882 +:10AFA00001079CD5062F9AD120F0080030706088E8 +:10AFB000414660F31F41002009F064F902208DF83A +:10AFC0000400ADF808902889ADF80A006088224690 +:10AFD00001A9F9F746F982E7082F80D12F89B5F842 +:10AFE0000A90402F01D2402001E0A7F1400080B23A +:10AFF00080460146304600F044FC08B3716808EB17 +:10B0000088002C2202EBC000095A4945E3D1FE48D2 +:10B0100007AAD0E90210CDE9071068798DF81C0065 +:10B0200008F0FF058DF81E5060883146FFF799FC47 +:10B030002246294639E0B6E014E03CE039E0E6E09B +:10B04000F148D0E90010CDE907106879ADF820701B +:10B050008DF81C00ADF82290608807AA3146FFF7F2 +:10B0600080FC3CE7082FB6D16889B5F808804028F5 +:10B0700001D2402000E0403887B23946304600F027 +:10B0800000FC0028A7D007EB870271680AEBC2001A +:10B090000844028A42459ED1017808299BD1407814 +:10B0A0006979884297D1F9B222463046FEF7F3FE1D +:10B0B00015E70E2F07D0CDF81C80CDF820806879D9 +:10B0C0008DF81C00C8E76989EF898B46B5F80C90AC +:10B0D0003046FEF742FFABF14001402901D3092081 +:10B0E0004AE0B9F1170F01D3172F01D20B2043E02B +:10B0F00040280ED000EB800271680AEBC2000844C1 +:10B100000178012903D1407869798842A9D00A20C1 +:10B1100032E03046FEF703FF014640282BD001EB1A +:10B12000810372680AEBC30002EB0008012288F871 +:10B1300000206A7988F8012070682A894089B8421D +:10B1400000D938462D8A03232372A282E781208208 +:10B15000A4F80C906582084600F078FB6081A8F89E +:10B160001490A8F81870A8F80E50A8F810B020464F +:10B1700000F062FBB3E6042005212172A4F80A80E6 +:10B18000E08101212173A049D1E90421CDE9072102 +:10B1900069798DF81C10ADF81E00608807AA314649 +:10B1A000FFF7DFFBE3E7062FE4D3B078904215D139 +:10B1B0003078010712D520F00800307060884146D1 +:10B1C00060F31F41002009F05DF802208DF80400B3 +:10B1D0002889ADF80800ADF80A90F7E6042130465A +:10B1E000FEF7D3FE05464028C4D00220830300901A +:10B1F00022462946304600F061FB4146608865F3EF +:10B200000F2160F31F41072009F03CF867E60E2F7D +:10B21000B0D104213046FEF7B8FE81464028A9D0BF +:10B220004146608869F30F2160F31F41072009F050 +:10B2300029F8288A0790E88900907068AF894089CA +:10B24000B84200D938468346B5F80A802889059067 +:10B25000484600F0FBFA6081079840B10220079B46 +:10B26000009022464946304600F028FB37E6B8F108 +:10B27000170F1ED3172F1CD3042020720098608252 +:10B28000E781A4F810B0A4F80C8009EB890271687A +:10B290000AEBC2000D1800990598A5F81480A5F8CE +:10B2A00018B0E9812882204600F0C6FA06202870EE +:10B2B00015E601200B230090D3E7082FA6D129899A +:10B2C0003046FEF74AFE074640289FD007EB87022C +:10B2D00071680AEBC2000844804600F0E8FA0028D2 +:10B2E00094D16D89B8F80E002844B0F5803F05D39D +:10B2F00060883A46314600F018FBF0E5002D85D015 +:10B30000A8F80E0060883A463146FFF701F9082098 +:10B310002072384600F09AFA6081A58127E770B55F +:10B320000D460646032105F043FB040004D02078B7 +:10B33000000704D5112070BD43F2020070BD2A46FB +:10B3400021463046FEF71FFF18B92868606168681B +:10B35000A061207840F008002070002070BD70B51A +:10B360000D460646032105F023FB040004D0207897 +:10B37000000704D4082070BD43F2020070BD2A46C5 +:10B3800021463046FEF732FF00B9A582207820F032 +:10B3900008002070002070BD2DE9F04F0E4691B0DE +:10B3A0008046032105F004FB0446404605F044FCBA +:10B3B00007460020079008900990ADF830000A90E9 +:10B3C00002900390049004B9FFDF0DF1080917BB48 +:10B3D000FFDF20E038460BA9002204F069FE9DF84B +:10B3E0002C0000F07F050A2D00D3FFDF6019017FDC +:10B3F000491E01779DF82C0000060CD52A460CA9A1 +:10B4000007A8FEF716FE01E0D846020019F805105D +:10B41000491C09F80510761EF6B2DBD204F134009F +:10B42000FA4D04F1260BDFF8E8A304F12A07069091 +:10B4300010E05846069900F06AFA064628700A2875 +:10B4400000D3FFDF5AF8261040468847E08CC05DE5 +:10B45000B04202D0208D0028EBD10A202870EC4D9C +:10B460004E4628350EE00CA907A800F050FA044615 +:10B47000375D55F8240000B9FFDF55F82420394620 +:10B4800040469047BDF81E000028ECD111B027E5DA +:10B4900010B5032105F08CFA040000D1FFDF0A216A +:10B4A00004F11C0018F025FF207840F00400207003 +:10B4B00010BD10B50C46032105F07AFA2044007F38 +:10B4C000002800D0012010BD2DE9F84F894615460F +:10B4D0008246032105F06CFA070004D0284608F0E4 +:10B4E0001DFF40B903E043F20200BDE8F88F484673 +:10B4F00008F03AFF08B11020F7E7786828B16988AA +:10B500000089814201D90920EFE7B9F800001C2425 +:10B5100018B1402809D2402008E03846FEF7FFFC69 +:10B520008046402819D11320DFE7403880B280469A +:10B530000146384600F0A5F948B108EB8800796863 +:10B5400004EBC000085C012803D00820CDE70520EB +:10B55000CBE7FDF75FFF06000BD008EB88007968AA +:10B5600004EBC0000C18B9F8000020B1E88910B154 +:10B5700013E01120B9E72888172802D36888172814 +:10B5800001D20720B1E7686838B12B1D2246414639 +:10B590003846FFF721F90028A7D104F10C026946CB +:10B5A0002046FFF720F8288860826888E082B9F892 +:10B5B000000030B102202070E889A080E889A0B1A5 +:10B5C0002BE003202070A889A0807868817840292A +:10B5D00005D180F8028039465046FEF726FE4046E7 +:10B5E00000F034F9A9F8000021E07868218B408947 +:10B5F000884200D908462083A6F802A004203072B1 +:10B60000B9F800007081E0897082F181208B30826E +:10B61000A08AB081304600F00FF97868C1784029DF +:10B6200005D180F8038039465046FEF74FFE0020D2 +:10B630005BE770B50D460646032105F0B9F9040035 +:10B6400003D0402D04D2402503E043F2020070BD38 +:10B65000403DADB2294600F014F958B105EB850123 +:10B660001C22606802EBC101084400F020F918B107 +:10B67000082070BD052070BD2A462146304600F0E6 +:10B6800054F9002070BD2DE9F0410D461646804664 +:10B69000032105F08DF90446402D01D2402500E03C +:10B6A000403DADB28CB1294600F0EBF880B105EB1E +:10B6B00085011C22606802EBC1014718384600F082 +:10B6C000F6F838B10820BDE8F08143F20200FAE74D +:10B6D0000520F8E733463A4629462046FFF77CF82E +:10B6E0000028F0D1EAB221464046FEF79BFF002039 +:10B6F000E9E72DE9F0410D4616468046032105F0A5 +:10B7000057F90446402D01D2402500E0403DAFB23C +:10B7100024B1304608F002FE38B902E043F20200DC +:10B72000D1E7306808F0FAFD08B11020CBE73946C0 +:10B73000204600F0A6F860B107EB87011C22606884 +:10B7400002EBC1014518284600F0B1F818B10820F5 +:10B75000B9E70520B7E7B088A98A884201D90C204B +:10B76000B1E76168E88C4978B0EBC10F01D31320D1 +:10B77000A9E73946204600F078F8014660680823BA +:10B780004078C20005F1240004F099FFD6E90012C8 +:10B79000C0E90012FAB221464046FEF7B9FE002089 +:10B7A00091E72DE9F0470D461F469046814603215B +:10B7B00005F0FEF80446402D01D2402001E0A5F13D +:10B7C000400086B23CB14DB1384608F0EBFD50B1B7 +:10B7D0001020BDE8F08743F20200FAE76068C8B1C4 +:10B7E000A0F80C8024E03146204600F04AF888B1E9 +:10B7F00006EB86011C22606802EBC1014518284651 +:10B8000000F055F840B10820E3E7000030000020C8 +:10B81000F04602000520DCE7A5F80880F2B22146D8 +:10B820004846FEF7FFFE1FB1A889698908443880A1 +:10B830000020CEE704F09BBD017821F00F01491CE8 +:10B8400021F0F00110310170FDF7E7BD10B504469D +:10B85000402800D9FFDF4034A0B210BD40684269E3 +:10B860000078484302EBC0007047C2784068037814 +:10B8700012FB03F24378406901FB032100EBC10096 +:10B880007047C2788A4209D9406801EB81011C22C5 +:10B8900002EBC101405C08B10120704700207047F5 +:10B8A0000078062801D901207047002070470078F1 +:10B8B000062801D00120704700207047F0B401EB4A +:10B8C00081061C27446807EBC6063444049D052600 +:10B8D0002670E3802571F0BCFEF794BA10B541895B +:10B8E00011B1FFF7DDFF08B1002010BD012010BD30 +:10B8F00010B5C18C8278B1EBC20F04D9C18911B1E6 +:10B90000FFF7CEFF08B1002010BD012010BD10B51B +:10B910000C4601230A22011D04F007FF007821884C +:10B92000012282409143218010BDF0B402EB8205D8 +:10B930001C264C6806EBC505072363554B681C792C +:10B94000402C03D11A71F0BCFEF705BDF0BC704766 +:10B9500010B5EFF3108000F0010472B6EE484178A4 +:10B96000491C41704078012801D1F7F70DFB002CEC +:10B9700000D162B610BD70B5E74CE07848B901253A +:10B98000E570FFF7E5FFF7F707FB20B1002008F0AF +:10B990000AF9002070BD4FF080406571C0F8045373 +:10B9A000F7E770B5EFF3108000F0010572B6DA4CDE +:10B9B000607800B9FFDF6078401E6070607808B979 +:10B9C000F7F7E6FA002D00D162B670BDD24810B587 +:10B9D000C17821B100214171C170FFF7E2FF002061 +:10B9E00010BD10B50446F7F7D7FACB49C97808401F +:10B9F00000D001202060002010BD2DE9F05FDFF8AD +:10BA000018934278817889F80620002589F8071074 +:10BA1000064689F8085000782F4620B101280FD03B +:10BA200002280FD0FFDFF7F7C4FA98B1F7F7C8FA8A +:10BA3000A8420FD12846F7F7C7FA0028FAD047E006 +:10BA40000125F0E7FFF784FFF7F7A6FA0028FBD0FF +:10BA50000225E8E701208407E060C4F80471AF49DB +:10BA60000D600107D1F84412AC4AC1F342312432CF +:10BA70001160AA49343108604FF0020BC4F804B3D6 +:10BA8000A060DFF89CA2DAF80010C94341F300116E +:10BA900001F10108DAF8001041F01001CAF80010B5 +:10BAA00000E020BFD4F804010028FAD02846F7F7B8 +:10BAB0008BFA0028FAD0B8F1000F05D1DAF800109F +:10BAC00021F01001CAF80010C4F808B3C4F80471DA +:10BAD00099F807004C4670B1307860B9F7F75CFA16 +:10BAE000064608F0BDF96FF0004116B1C4E9031035 +:10BAF00001E0C4E9030115B12771BDE8F09F012001 +:10BB00002071BDE8F05F00F0ABB870B5050000D162 +:10BB1000FFDF4FF080424FF0FF30C2F808030021F2 +:10BB2000C2F80011C2F80411C2F80C11C2F81011C9 +:10BB3000794C6170F7F736FA10B10120E07060704F +:10BB40002846BDE8704058E72DE9F05F7548D0F809 +:10BB500000B0744A7449083211608406D4F80801B0 +:10BB600008B1012600E00026D4F8000110B14FF022 +:10BB7000010801E04FF00008D4F8040108B10127E2 +:10BB800000E00027D4F80C0100B101208246D4F86F +:10BB9000100108B1012100E00021894646EA0801B0 +:10BBA00027EA010020EA0A0030EA090000D0FFDF9E +:10BBB000002526B1C4F80851012007F0F4FF564EC5 +:10BBC000B8F1000F10D0C4F80051707918B1757138 +:10BBD000002007F0E8FF307830B10120534935707C +:10BBE000B07002220A6020610FB1C4F80451BAF1AA +:10BBF000000F0BD0C4F80C51B07800B9FFDF4B48F0 +:10BC00000560B57001206061FFF7CBFEB9F1000F50 +:10BC100005D0C4F81051307908B100F045F8414919 +:10BC2000091DC1F800B068E770B53B4DE87808B968 +:10BC3000F7F7AEF901208407A061A87858B100BFDA +:10BC4000D4F80C0120B90020F7F7BEF90028F7D18D +:10BC50000020C4F80C014FF0FF30C4F8080370BD99 +:10BC60002DE9F0411926B407C4F808630125A56140 +:10BC70000020C4F80001C4F80C01C4F81001F7F763 +:10BC80008BF9254F28B12949BD7002200860256134 +:10BC900000E03D70FFF75CFE2049B8792031086074 +:10BCA000C4F80463BDE8F0812DE9F0411A4C4FF06F +:10BCB00080470125E079F0B1012803D0217A401EA8 +:10BCC000814218DAF7F768F9064608F0C9F8E17911 +:10BCD000012902D9217A491C21720EB1216900E0A3 +:10BCE000E168411A022902DA11F1020F0EDC0EB1ED +:10BCF000206100E0E060FFF72BFEF7F74DF938B167 +:10BD00000A49022008603D61A57002E07D61C9E733 +:10BD1000257000202072C5E73C0000201805004077 +:10BD200010ED00E01005024001000001340C00405D +:10BD30004FF0E0214FF00070C1F88001C1F880029F +:10BD4000384B802283F80024C1F80001704700B509 +:10BD500002460420344903E001EBC0031B792BB1F8 +:10BD6000401EC0B2F8D2FFDFFF2000BD41F83020F6 +:10BD700001EBC00100224A718A7101220A7100BDE3 +:10BD8000294A002102EBC0000171704710B504463A +:10BD9000042800D3FFDF244800EBC40420790128E5 +:10BDA00000D0FFDF6079A179401CC0B2814200D091 +:10BDB00060714FF0E0214FF00070C1F8000210BD3B +:10BDC0002DE9F041194805681849194808310860FB +:10BDD0001448042690F80004134F4009154C042819 +:10BDE00018D0FFDF16E0217807EBC1000279012AA5 +:10BDF00008D1427983799A4204D04279827157F806 +:10BE0000310080472078401CC0B22070042801D344 +:10BE100000202070761EF6B2E5D20448001D0560B1 +:10BE2000BDE8F08119E000E0C805002010050240DF +:10BE30000100000150000020F8B51D46DDE906476D +:10BE40000E000AD004F0F8FE2346FF1DBCB23146B6 +:10BE50002A46009404F005FBF8BDD0192246194685 +:10BE600018F0A6F92046F8BD70B50D46044610211D +:10BE700018F01DFA258117206081A07B40F00A0090 +:10BE8000A07370BD4FF6FF720A800146022008F0D1 +:10BE9000F9B9704700897047827BD30701D19207B7 +:10BEA00003D4808908800020704705207047827B7A +:10BEB000920700D58181704701460020098841F62C +:10BEC000FE52114200D00120704700B50346807B2E +:10BED000C00701D0052000BD59811846FFF7ECFFCF +:10BEE000C00703D0987B40F004009873987B40F023 +:10BEF00001009873002000BD827B520700D509B174 +:10BF00004089704717207047827B61F3C3028273B8 +:10BF100070472DE9FC5F0E460446017896460120E5 +:10BF200000FA01F14DF6FF5201EA020962684FF68C +:10BF3000FF7B1188594502D10920BDE8FC9FB9F16A +:10BF4000000F05D041F6FE55294201D00120F4E74B +:10BF500041EA090111801D0014D04FF0000C85F852 +:10BF600000C023780521032267464FF0020A0E2BFA +:10BF700074D2DFE803F0F809252F4762697447900F +:10BF800092B3D0D70420D8E7616820898B7B9B07C8 +:10BF90007DD5172848D30B89834245D38989172932 +:10BFA00001D3814240D185F800A0A5F8010032807C +:10BFB000616888816068817B21F002018173C5E03E +:10BFC000042028702089A5F801006089A5F80300E5 +:10BFD0003180BBE0208A3188C01D1FFA80F84145BE +:10BFE00022D3062028702089A5F801006089A5F8D1 +:10BFF0000300A089A5F805000721208ACDE90001EA +:10C0000063693EE0082B10D0082028702089A5F82D +:10C0100001006089A5F8030031806A1D694604F1BA +:10C020000C0006F066FA10B15FE01020EDE73088F2 +:10C030009DF800100844308088E00A20287020898C +:10C04000A5F80100328045E00C2028702089A5F871 +:10C0500001006089A5F8030031803BE083E021897D +:10C06000338800EB41021FFA82F843453DD3B8F113 +:10C07000050F3AD30E222A700BEA4101CDE90010D8 +:10C08000E36860882A467146FFF7D6FE00E04DE07F +:10C09000A6F800805AE04020287060893188C01CD2 +:10C0A0001FFA80F8414520D32878714620F03F00E0 +:10C0B000123028702089A5F801006089CDE90002BE +:10C0C00060882A46E368FFF7B7FEA6F80080287864 +:10C0D00040063BD461682089888037E0A089328897 +:10C0E000401D1FFA80F8424501D204273EE0162089 +:10C0F00028702089A5F801006089A5F80300A089AF +:10C10000CDE9000160882A4671462369FFF794FE55 +:10C11000A6F80080DEE718202870207A6870A6F85C +:10C1200000A013E061680A88920401D405271DE08D +:10C13000C9882289914201D0062717E01E21297063 +:10C1400030806068018821F400510180B9F1000F4E +:10C150000CD0618878230022022007F0E9FF616893 +:10C160002078887007E0A6F800C00327606801887F +:10C1700021EA090101803846DFE62DE9FF4F85B04D +:10C180001746129C0D001E461CD03078C10703D004 +:10C1900000F03F00192801D9012100E000212046CC +:10C1A000FFF7AAFEA8420DD32088A0F57F41FF39F2 +:10C1B00008D03078410601D4000605D5082009B022 +:10C1C000BDE8F08F0720FAE700208DF800008DF819 +:10C1D000010030786B1E00F03F0C0121A81E4FF0CB +:10C1E000050A4FF002094FF0030B9AB2BCF1200F81 +:10C1F00075D2DFE80CF08B10745E7468748C749CDC +:10C2000074B674BB74C974D574E2747474F274F047 +:10C2100074EF74EE748B052D78D18DF80090A078B2 +:10C220008DF804007088ADF8060030798DF80100B3 +:10C23000707800F03F000C2829D00ADCA0F1020041 +:10C24000092863D2DFE800F0126215621A621D62EB +:10C250002000122824D004DC0E281BD01028DBD1AB +:10C260001BE016281FD01828D6D11FE020788007A1 +:10C2700001E020784007002848DAEFE02078000746 +:10C28000F9E72078C006F6E720788006F3E7207803 +:10C290004006F0E720780006EDE72088C005EAE7D1 +:10C2A00020884005E7E720880005E4E72088C004EF +:10C2B000E1E72078800729D5032D27D18DF800B03C +:10C2C000B6F8010082E0217849071FD5062D1DD35D +:10C2D00081B27078012803D0022817D102E0CAE0A9 +:10C2E000022000E0102004228DF8002072788DF8E2 +:10C2F0000420801CB1FBF0F2ADF8062092B242435C +:10C300008A4203D10397ADF80890A7E07AE020783D +:10C31000000777D598B282088DF800A0ADF8042008 +:10C32000B0EB820F6ED10297ADF8061096E021783F +:10C33000C90667D5022D65D381B206208DF80000AD +:10C34000707802285ED300BFB1FBF0F28DF80400D4 +:10C35000ADF8062092B242438A4253D1ADF808901C +:10C360007BE0207880064DD5072003E0207840064A +:10C370007FD508208DF80000A088ADF80400ADF846 +:10C380000620ADF8081068E02078000671D5092075 +:10C39000ADF804208DF80000ADF8061002975DE0BE +:10C3A0002188C90565D5022D63D381B20A208DF895 +:10C3B0000000707804285CD3C6E72088400558D573 +:10C3C000012D56D10B208DF80000A088ADF8040097 +:10C3D00044E021E026E016E0FFE72088000548D58C +:10C3E000052D46D30C208DF80000A088ADF8040080 +:10C3F000B6F803006D1FADF80850ADF80600ADF8B3 +:10C400000AA02AE035E02088C00432D5012D30D1C1 +:10C410000D208DF8000021E02088800429D4B6F892 +:10C420000100E080A07B000723D5032D21D33078C5 +:10C4300000F03F001B2818D00F208DF80000208846 +:10C4400040F40050A4F80000B6F80100ADF8040074 +:10C45000ED1EADF80650ADF808B003976946059893 +:10C46000F5F7E6FC050008D016E00E208DF8000078 +:10C47000EAE7072510E008250EE0307800F03F00DD +:10C480001B2809D01D2807D00220059907F0FAFEC5 +:10C49000208800F400502080A07B400708D520466B +:10C4A000FFF70AFDC00703D1A07B20F00400A073B2 +:10C4B000284684E61FB5022806D101208DF8000029 +:10C4C00088B26946F5F7B4FC1FBD0000F8B51D46FB +:10C4D000DDE906470E000AD004F0AEFB2346FF1D3F +:10C4E000BCB231462A46009403F0BBFFF8BDD01918 +:10C4F0002246194617F05CFE2046F8BD2DE9FF4F95 +:10C500008DB09B46DDE91B57DDF87CA00C46082B5F +:10C5100005D0E06901F002F950B11020D2E028887E +:10C52000092140F0100028808AF80010022617E048 +:10C53000E16901208871E2694FF420519180E1693D +:10C540008872E06942F601010181E069002181738E +:10C550002888112140F0200028808AF80010042645 +:10C5600038780A900A2038704FF0020904F1180058 +:10C570004D460C9001F095FBB04681E0BBF1100FE9 +:10C580000ED1022D0CD0A9EB0800801C80B2022134 +:10C59000CDE9001005AB52461E990D98FFF796FFA6 +:10C5A000BDF816101A98814203D9F74800790F9008 +:10C5B00004E003D10A9808B138702FE04FF002016F +:10C5C000CDE900190DF1160352461E990D98FFF79B +:10C5D0007DFF1D980088401B801B83B2C6F1FF00C1 +:10C5E000984200D203461E990BA8D9B15FF0000211 +:10C5F000DDF878C0CDE9032009EB060189B2CDE969 +:10C6000001C10F980090BDF8161000220D9801F09E +:10C61000CBFB387070B1C0B2832807D0BDF81600CC +:10C6200020833AE00AEB09018A19E1E7022011B000 +:10C63000BDE8F08FBDF82C00811901F0FF08022D34 +:10C640000DD09AF80120424506D1BDF82010814254 +:10C6500007D0B8F1FF0F04D09AF801801FE08AF8E4 +:10C660000180C94800680178052902D1BDF816107B +:10C67000818009EB08001FFA80F905EB080085B2FC +:10C68000DDE90C1005AB0F9A01F00EFB28B91D98DF +:10C690000088411B4145BFF671AF022D13D0BBF19D +:10C6A000100F0CD1A9EB0800801C81B20220CDE94B +:10C6B000000105AB52461E990D98FFF707FF1D9824 +:10C6C0000580002038700020B1E72DE9F8439C4632 +:10C6D000089E13460027B26B9AB3491F8CB2F18FA4 +:10C6E000A1F57F45FF3D05D05518AD882944891D2A +:10C6F0008DB200E000252919B6F83C80083141458B +:10C7000020D82A44BCF8011022F8021BBCF8031000 +:10C7100022F8021B984622F8024B914604F07AFA5E +:10C720004FF00C0C41464A462346CDF800C003F0BA +:10C7300064FEF587B16B00202944A41D21440880C4 +:10C7400003E001E0092700E083273846BDE8F883CD +:10C7500010B50B88848F9C420CD9846BE018048838 +:10C7600044B1848824F40044A41D23440B80106049 +:10C77000002010BD0A2010BD2DE9F0478AB0002529 +:10C78000904689468246ADF8185007274BE0059839 +:10C7900006888088000446D4A8F8006007A80195A0 +:10C7A00000970295CDE903504FF400730022314603 +:10C7B000504601F0F9FA04003CD1BDF81800ADF87C +:10C7C0002000059804888188B44216D10A0414D444 +:10C7D00001950295039521F400410097049541F4D9 +:10C7E000804342882146504601F0B4F804000BD142 +:10C7F0000598818841F40041818005AA08A948462E +:10C80000FFF7A6FF0400DCD000970598029501957C +:10C81000039504950188BDF81C300022504601F0B4 +:10C8200099F80A2C06D105AA06A94846FFF790FFF9 +:10C830000400ACD0ADF8185004E00598818821F4CC +:10C840000041818005AA06A94846FFF781FF00281C +:10C85000F3D00A2C03D020460AB0BDE8F0870020B0 +:10C86000FAE710B50C46896B86B051B10C218DF8F2 +:10C870000010A18FADF80810A16B01916946FAF77D +:10C8800064FC00204FF6FF71A063E187A08706B02B +:10C8900010BD2DE9F0410D460746896B0020069E2C +:10C8A0001446002911D0012B0FD1324629463846B3 +:10C8B000FFF762FF002808D1002C06D03246294637 +:10C8C0003846BDE8F04100F038BFBDE8F0812DE901 +:10C8D000FC411446DDE9087C0E46DDE90A15521DCF +:10C8E000BCF800E092B2964502D20720BDE8FC8178 +:10C8F000ACF8002017222A70A5F80160A5F80330D3 +:10C900000522CDE900423B462A46FFF7DFFD002025 +:10C91000ECE770B50C4615464821204617F0E9FCB7 +:10C9200004F1080044F81C0F00204FF6FF71E0618D +:10C9300061842084A5841720E08494F82A0040F0C4 +:10C940000A0084F82A0070BD4FF6FF720A80014683 +:10C95000032007F097BC30B585B00C460546FFF7BD +:10C9600080FFA18E284629B101218DF8001069466B +:10C97000FAF7EBFB0020E0622063606305B030BD96 +:10C98000B0F84000704700005400002090F84620A6 +:10C99000920703D4408808800020F3E70620F1E7DF +:10C9A00090F846209207EDD5A0F84410EAE701463A +:10C9B000002009880A0700D5012011F0F00F01D0EE +:10C9C00040F00200CA0501D540F004008A0501D5F7 +:10C9D00040F008004A0501D540F010000905D1D506 +:10C9E00040F02000CEE700B5034690F84600C007AF +:10C9F00001D0062000BDA3F842101846FFF7D7FF6C +:10CA000010F03E0F05D093F8460040F0040083F884 +:10CA1000460013F8460F40F001001870002000BDDA +:10CA200090F84620520700D511B1B0F84200A9E7AE +:10CA30001720A7E710F8462F61F3C3020270A1E7A1 +:10CA40002DE9FF4F9BB00E00DDE92B34DDE929789D +:10CA5000289D24D02878C10703D000F03F00192872 +:10CA600001D9012100E000212046FFF7D9FFB042A3 +:10CA700015D32878410600F03F010CD41E290CD0B4 +:10CA8000218811F47F6F0AD13A8842B1A1F57F4223 +:10CA9000FF3A04D001E0122901D1000602D504209A +:10CAA0001FB0C5E5F9491D984FF0000A08718DF8CF +:10CAB00018A08DF83CA00FAA0A60ADF81CA0ADF834 +:10CAC00050A02978994601F03F02701F5B1C04F1C9 +:10CAD000180C4FF0060E4FF0040BCDF858C01F2A6B +:10CAE0007ED2DFE802F07D7D107D267DAC7DF47D79 +:10CAF000F37DF27DF17DF47DF07D7D7DEF7DEE7D3A +:10CB00007D7D7D7DED0094F84610B5F80100890724 +:10CB100001D5032E02D08DF818B022E34FF4006146 +:10CB2000ADF85010608003218DF83C10ADF8400046 +:10CB3000D8E2052EEFD1B5F801002083ADF81C0036 +:10CB4000B5F80310618308B1884201D901207FE163 +:10CB50000020A07220814FF6FF702084169801F00B +:10CB6000A0F8052089F800000220029083460AAB55 +:10CB70001D9A16991B9801F097F890BB9DF82E000E +:10CB8000012804D0022089F80100102003E00120D0 +:10CB900089F8010002200590002203A90BA805F0E6 +:10CBA000A8FCE8BB9DF80C00059981423DD13A886C +:10CBB000801CA2EB0B01814237DB02990220CDE9F8 +:10CBC00000010DF12A034A4641461B98FFF77EFCFF +:10CBD00002980BF1020B801C80B217AA03A901E096 +:10CBE000A0E228E002900BA805F083FC02999DF8D2 +:10CBF0000C00CDE9000117AB4A4641461B98FFF7F0 +:10CC000065FC9DF80C100AAB0BEB01001FFA80FBD2 +:10CC100002981D9A084480B2029016991B9800E071 +:10CC200003E001F041F80028B6D0BBF1020F02D0BA +:10CC3000A7F800B053E20A208DF818004FE2002157 +:10CC40000391072EFFF467AFB5F801002083ADF81C +:10CC50001C00B5F80320628300283FF477AF9042B0 +:10CC60003FF674AF0120A072B5F8050020810020C6 +:10CC7000A073E06900F052FD78B9E1690120887184 +:10CC8000E2694FF420519180E1698872E06942F6CF +:10CC900001010181E06900218173F01F20841E9849 +:10CCA000606207206084169800F0FBFF072089F877 +:10CCB00000000120049002900020ADF82A0028E036 +:10CCC0001DE2A3E13AE1EAE016E2AEE086E049E0E7 +:10CCD0000298012814D0E0698079012803D1BDF8B9 +:10CCE0002800ADF80E00049803ABCDE900B04A4629 +:10CCF00041461B98FFF7EAFB0498001D80B20490A0 +:10CD0000BDF82A00ADF80C00ADF80E00059880B211 +:10CD100002900AAB1D9A16991B9800F0C5FF28B91E +:10CD200002983988001D05908142D1D202980128CD +:10CD300081D0E0698079012805D0BDF82810A1F5DF +:10CD40007F40FF3803D1BDF82800ADF80E000498ED +:10CD500003ABCDE900B04A4641461B98FFF7B6FB4E +:10CD60000298BBE1072E02D0152E7FF4D4AEB5F8A1 +:10CD700001102183ADF81C10B5F80320628300294F +:10CD80003FF4E4AE91423FF6E1AE0121A1724FF0D3 +:10CD9000000BA4F808B084F80EB0052E07D0C0B27E +:10CDA000691DE26905F086FB00287FF444AF4FF669 +:10CDB000FF70208401A906AA14A8CDF800B081E86C +:10CDC00085032878214600F03F031D9A1B98FFF742 +:10CDD00095FB8246208BADF81C0080E10120032EDC +:10CDE000C3D14021ADF85010B5F801102183ADF842 +:10CDF0001C100AAAB8F1000F00D00023CDE90203ED +:10CE000004921D98CDF80480009038880022401EBE +:10CE100083B21B9800F0C8FF8DF8180090BB0B2060 +:10CE200089F80000BDF8280037E04FF0010C052E0E +:10CE30009BD18020ADF85000B5F801102183B5F8E2 +:10CE400003002084ADF81C10B0F5007F03D9072043 +:10CE50008DF8180085E140F47C4222840CA8B8F1DA +:10CE6000000F00D00023CDE90330CDE9018C1D98DF +:10CE700000903888401E83B21B9800F095FF8DF813 +:10CE8000180028B18328A8D10220BDE0540000205A +:10CE90000D2189F80010BDF83000401C1EE1032E62 +:10CEA00004D248067FF537AE002017E1B5F801102F +:10CEB000ADF81C102878400602D58DF83CE002E061 +:10CEC00007208DF83C004FF000080320CDE9020850 +:10CED0001E9BCDF810801D980193A6F1030B0090C6 +:10CEE0001FFA8BF342461B9800F034FD8DF81800B2 +:10CEF0008DF83C80297849060DD52088C00506D5D7 +:10CF0000208BBDF81C10884201D1C4F82480404613 +:10CF10008DF81880E2E0832801D14FF0020A4FF427 +:10CF20008070ADF85000BDF81C002083A4F820B03C +:10CF30001E986062032060841321CCE0052EFFF46C +:10CF4000EAADB5F80110ADF81C10A28F62B3A2F5DE +:10CF50007F43FE3B28D008228DF83C204FF0000B89 +:10CF60000523CDE9023BDDF878C0CDF810B01D9A5D +:10CF700080B2CDF804C040F400430092B5F803201D +:10CF80001B9800F0E7FC8DF83CB04FF400718DF871 +:10CF90001800ADF85010832810D0F8B1A18FA1F57A +:10CFA0007F40FE3807D0DCE00B228DF83C204FF6A6 +:10CFB000FE72A287D2E7A4F83CB0D2E000942B46E0 +:10CFC00031461E9A1B98FFF780FB8DF8180008B1B8 +:10CFD00083284BD1BDF81C00208355E700942B46D5 +:10CFE00031461E9A1B98FFF770FB8DF81800E8BBBE +:10CFF000E18FA06B0844811D8DE8820343888288FD +:10D0000001881B98FFF763FC824668E095F8018071 +:10D01000022E70D15FEA080002D0B8F1010F6AD188 +:10D0200009208DF83C0007A800908DF84080434609 +:10D03000002221461B98FFF72CFC8DF842004FF090 +:10D04000000B8DF843B050B9B8F1010F12D0B8F110 +:10D05000000F04D1A18FA1F57F40FF380AD0A08F27 +:10D0600040B18DF83CB04FF4806000E037E0ADF89F +:10D0700050000DE00FA91B98FAF767F882468DF86B +:10D080003CB04FF48060ADF85000BAF1020F06D00A +:10D09000FC480068C07928B18DF8180027E0A4F892 +:10D0A000188044E0BAF1000F03D081208DF81800F9 +:10D0B0003DE007A800904346012221461B98FFF758 +:10D0C000E8FB8DF8180021461B98FFF7CAFB9DF876 +:10D0D000180020B9192189F80010012038809DF826 +:10D0E0003C0020B10FA91B98FAF72FF88246BAF13D +:10D0F000000F33D01BE018E08DF818E031E0207805 +:10D10000000712D5012E10D10A208DF83C00E088CE +:10D11000ADF8400003201B9907F0B4F80820ADF8E3 +:10D120005000C1E648067FF5F6AC4FF0040A2088AF +:10D13000BDF8501008432080BDF8500080050BD585 +:10D14000A18FA1F57F40FE3806D11E98E062289895 +:10D150002063A6864FF0030A5046A1E49DF818000C +:10D1600078B1012089F80000297889F80110BDF80C +:10D170001C10A9F802109DF8181089F80410052059 +:10D1800038802088BDF8501088432080E4E72DE9DE +:10D19000FF4F8846087895B0012181404FF2090081 +:10D1A000249C0140ADF820102088DDF88890A0F57F +:10D1B0007F424FF0000AFF3A06D039B1000705D58B +:10D1C000012019B0BDE8F08F0820FAE7239E4FF048 +:10D1D000000B0EA886F800B018995D460988ADF8D6 +:10D1E0003410A8498DF81CB0179A0A718DF838B020 +:10D1F000086098F8000001283BD0022809D00328D5 +:10D200006FD1307820F03F001D303070B8F8040046 +:10D21000E08098F800100320022904D1317821F031 +:10D220003F011B31317094F84610090759D505AB01 +:10D23000B9F1000F13D0002102AA82E80B000720E9 +:10D24000CDE90009BDF83400B8F80410C01E83B25F +:10D250000022159800F0A8FD0028D1D101E0F11CB2 +:10D26000EAE7B8F80400A6F80100BDF81400C01CF5 +:10D2700004E198F805108DF81C1098F804000128B6 +:10D2800006D04FF4007A02282CD00328B8D16CE1E4 +:10D290002188B8F8080011F40061ADF8201020D002 +:10D2A00017281CD3B4F84010814218D3B4F84410A6 +:10D2B000172901D3814212D1317821F03F01C91CD5 +:10D2C0003170A6F801000321ADF83410A4F8440031 +:10D2D00094F8460020F0020084F8460065E1052538 +:10D2E0007EE177E1208808F1080700F4FE60ADF8E0 +:10D2F000200010F0F00F1BD010F0C00F03D03888C2 +:10D30000228B9042EBD199B9B878C00710D0B96898 +:10D310000720CDE902B1CDF804B00090CDF810B0EF +:10D32000FB88BA883988159800F014FB0028D6D1FC +:10D330002398BDF82010401C80294ED006DC10290F +:10D340000DD020290BD0402987D124E0B1F5807F72 +:10D350006ED051457ED0B1F5806F97D1DEE0C80622 +:10D3600001D5082000E0102082460DA907AA05205B +:10D37000CDE902218DF83800ADF83CB0CDE9049636 +:10D3800008A93888CDE9000153460722214615989F +:10D39000FFF7B4F8A8E09DF81C2001214FF00A0A1D +:10D3A000002A9BD105ABB9F1000F00D00020CDE9D8 +:10D3B00002100720CDE90009BDF834000493401E97 +:10D3C00083B2218B0022159800F0EEFC8DF81C0032 +:10D3D0000B203070BDF8140020E09DF81C200121C6 +:10D3E0004FF00C0A002A22D113ABB9F1000F00D084 +:10D3F0000020CDE902100720CDE900090493BDF813 +:10D400003400228C401E83B2218B159800F0CCFC96 +:10D410008DF81C000D203070BDF84C00401CADF89C +:10D42000340005208DF83800208BADF83C00BCE0BE +:10D430003888218B88427FF452AF9DF81C004FF052 +:10D44000120A00281CD1606AA8B1B878C0073FF45E +:10D4500046AF00E018E0BA680720CDE902B2CDF887 +:10D4600004B00090CDF810B0FB88BA88159800F091 +:10D4700071FA8DF81C00132030700120ADF83400D3 +:10D4800093E00000540000203988208B8142D2D1E3 +:10D490009DF81C004FF0160A0028A06B08D0E0B3DE +:10D4A0004FF6FF7000215F46ADF808B0019027E00D +:10D4B00068B1B978C907BED1E18F0DAB0844821DB0 +:10D4C00003968DE80C0243888288018809E0B878C9 +:10D4D000C007BCD0BA680DAB03968DE80C02BB88C0 +:10D4E000FA881598FFF7F3F905005ED0072D72D082 +:10D4F00076E0019005AA02A92046FFF729F9014626 +:10D50000E28FBDF80800824201D00029F1D0E08FFF +:10D51000A16B084407800198E08746E09DF81C0055 +:10D520004FF0180A40B1208BC8B1388820832146BB +:10D530001598FFF796F938E004F118000090237E63 +:10D54000012221461598FFF7A4F98DF81C00002848 +:10D55000EDD1192030700120ADF83400E7E7052542 +:10D5600021461598FFF77DF93AE0208800F4007015 +:10D57000ADF8200050452DD1A08FA0F57F41FE3998 +:10D5800001D006252CE0D8F808004FF0160A48B163 +:10D59000A063B8F80C10A1874FF6FF71E187A0F8DF +:10D5A00000B002E04FF6FF70A087BDF8200030F415 +:10D5B0007F611AD0782300220320159906F0B8FD68 +:10D5C00098F8000020712088BDF8201008432080C2 +:10D5D0000EE000E007252088BDF820108843208059 +:10D5E000208810F47F6F1CD03AE02188814321808D +:10D5F0009DF8380020B10EA91598F9F7A6FD05464B +:10D600009DF81C000028EBD086F801A001203070A6 +:10D61000208B70809DF81C0030710520ADF834001F +:10D62000DEE7A18EE1B118980DAB0088ADF83400AB +:10D630002398CDE90304CDE90139206B0090E36A1A +:10D64000179A1598FFF7FCF9054601208DF8380068 +:10D650000EA91598F9F779FD00B10546A4F834B084 +:10D6600094F8460040070AD52046FFF7A0F910F0CD +:10D670003E0F04D114F8460F20F0040020701898D3 +:10D68000BDF83410018028469BE500B585B003281D +:10D6900006D102208DF8000088B26946F9F755FDE1 +:10D6A00005B000BD10B5384C0B782268012B02D0B4 +:10D6B000022B2AD111E013780BB1052B01D10423E1 +:10D6C000137023688A889A802268CB88D380226866 +:10D6D0000B891381498951810DE08B8893802268E1 +:10D6E000CB88D38022680B8913814B8953818B8926 +:10D6F0009381096911612168F9F727FD22680021EA +:10D700000228117003D0002800D0812010BD832092 +:10D7100010BD806B002800D001207047817801295E +:10D7200009D10088B0F5205F03D042F6010188429C +:10D7300001D10020704707207047F0B587B0002462 +:10D7400015460E460746ADF8144010E006980188CD +:10D750002980811DCDE902410721019404940091A3 +:10D76000838842880188384600F0F4F830B906AA68 +:10D7700005A93046FEF7ECFF0028E7D00A2800D1C3 +:10D78000002007B0F0BD00005400002010B58B78D9 +:10D7900083B102789A4205D10B885BB102E08B79A4 +:10D7A000091D4BB18B789A42F9D1B0F801300C8841 +:10D7B000A342F4D1002010BD812010BD072826D03F +:10D7C00012B1012A27D103E0497801F0070102E0F4 +:10D7D0004978C1F3C20105291DD2DFE801F0031821 +:10D7E000080C12000AB10320704702207047042879 +:10D7F0000DD250B10DE0052809D2801E022808D3B1 +:10D8000003E0062803D0032803D00520704700203A +:10D8100070470F20704781207047C0B282060BD43A +:10D82000000607D5FE48807A4143C01D01EBD000B9 +:10D8300080B27047084670470020704770B5138863 +:10D840000B800B781C0625D5F54CA47A844204D8AD +:10D8500043F010000870002070BD956800F00706C6 +:10D8600005EBD0052D78F54065F304130B701378A4 +:10D87000D17803F0030341EA032140F20123B1FB15 +:10D88000F3F503FB15119268E41D00FB012000EB8A +:10D89000D40070BD906870BD37B51446BDF8041053 +:10D8A00011809DF804100A061ED5C1F30013DC494F +:10D8B000A568897A814208D8FE2811D1C91DC908F6 +:10D8C0005A42284616F0EBFC0AE005EBD00100F0C6 +:10D8D0000702012508789540A84393401843087033 +:10D8E000207820F0100020703EBD2DE9F041074661 +:10D8F000C81C0E4620F00300B04202D08620BDE8CE +:10D90000F081C74D002034462E60AF802881AA7276 +:10D91000E8801AE0E988491CE980810614D4E1789E +:10D9200000F0030041EA002040F20121B0FBF1F2D7 +:10D9300001FB12012068FFF770FF2989084480B2BB +:10D940002881381A3044A0600C3420784107E1D493 +:10D950000020D4E72DE9FF4F89B01646DDE9168A8D +:10D960000F46994623F44045084600F00DFB04009D +:10D970000FD0099802F0E2FF0290207800060AD545 +:10D98000A748817A0298814205D887200DB0BDE86A +:10D99000F08F0120FAE7224601A90298FFF74EFF17 +:10D9A000834600208DF80C004046B8F1070F1AD0CE +:10D9B00001222146FFF702FF0028E7D12078400628 +:10D9C00011D502208DF80C00ADF81070BDF80400E0 +:10D9D000ADF81200ADF814601898ADF81650CDF8F7 +:10D9E0001CA0ADF818005FEA094004D500252E46BA +:10D9F000A84601270CE02178E07801F0030140EA15 +:10DA0000012040F20121B0FBF1F2804601FB1287B8 +:10DA10005FEA494009D5B84507D1A178207901F0DE +:10DA2000030140EA0120B04201D3BE4201D90720E0 +:10DA3000ACE7A8191FFA80F9B94501D90D20A5E76F +:10DA40009DF80C0028B103A90998F9F77CFB002880 +:10DA50009CD1B84507D1A0784FEA192161F30100A4 +:10DA6000A07084F804901A9800B10580199850EAC3 +:10DA70000A0027D0199830B10BEB06002A461999F5 +:10DA800016F096FB0EE00BEB06085746189E099819 +:10DA900003F0C0F82B46F61DB5B239464246009554 +:10DAA00002F0ABFC224601A90298FFF7C7FE9DF8E1 +:10DAB0000400224620F010008DF80400DDE901107A +:10DAC000FFF7EAFE002061E72DE9FF4FDFF85091F4 +:10DAD00082461746B9F80610D9F8000001EB41015B +:10DAE00000EB810440F20120B2FBF0F185B000FBB5 +:10DAF00011764D46DDF84C8031460698FFF78DFED5 +:10DB000029682A898B46611A0C3101441144AB887B +:10DB100089B28B4202D8842009B038E70699CDB289 +:10DB2000290603D5A90601D50620F5E7B9F806C0F0 +:10DB30000CF1010C1FFA8CFCA9F806C0149909B16C +:10DB4000A1F800C0A90602D5C4F8088007E0104477 +:10DB500080B2A9F80800191A01EB0B00A060224658 +:10DB6000FE200699FFF798FEE77026712078390AA3 +:10DB700061F30100320AA17840F0040062F3010170 +:10DB8000A17020709AF802006071BAF80000E0807D +:10DB900000262673280602D599F80A7000E00127AE +:10DBA000A80601D54FF000084D4600244FF00709A4 +:10DBB0000FE0CDE902680196CDF800900496E9885F +:10DBC0002046129B089AFFF7C5FE0028A4D1641CCA +:10DBD000E4B2BC42EDD300209EE72DE9F047804639 +:10DBE00000F0D2F9070005D0002644460C4D40F263 +:10DBF000012919E00120BDE8F087204600F0C4F9B2 +:10DC00000278C17802F0030241EA0222B2FBF9F382 +:10DC100009FB13210068FFF700FE304486B201E0E3 +:10DC2000E8050020641CA4B2E988601E8142E4DC9F +:10DC3000A8F10100E8802889801B28810020387025 +:10DC4000D9E710B5144631B1491E218002F076FEA5 +:10DC5000A070002010BD012010BD10B5D2490446AF +:10DC60000088CA88904201D30A2010BD096800EBE1 +:10DC7000400001EB80025079A072D0882081917819 +:10DC8000107901F0030140EA0120A081A078E11C95 +:10DC9000FFF7D4FD20612088401C2080E080002018 +:10DCA00010BD0121018270472DE9FF4F85B04FF66D +:10DCB000FF788246A3F8008048681F460D468078AA +:10DCC0008DF8060048680088ADF8040000208DF843 +:10DCD0000A00088A0C88A04200D304462C8241E046 +:10DCE000288A401C2882701D6968FFF74FFDB8BB69 +:10DCF0003988414501D1601E38806888A04236D3FA +:10DD0000B178307901F0030140EA012901A9701DC1 +:10DD1000FFF73CFD20BB298941452CD0002231462C +:10DD20000798FFF74BFDD8B92989494518D1E9680B +:10DD30000391B5F80AC0D6F808B05046CDF800C037 +:10DD400002F068FFDDF800C05A460CF1070C1FFA1C +:10DD50008CFC4B460399CDF800C002F018FB50B183 +:10DD6000641CA4B2204600F00FF90600B8D1641E6E +:10DD70002C820A20D0E67C807079B871F088B88057 +:10DD80003178F07801F0030140EA01207881A7F8AA +:10DD90000C90504602F0D2FD324607F10801FFF721 +:10DDA0004DFD38610020B7E62DE9FF4F87B0814671 +:10DDB0001C469246DDF860B0DDF85480089800F00B +:10DDC000E3F805000CD0484602F0B8FD29780906B2 +:10DDD00008D57549897A814204D887200BB0D6E5E9 +:10DDE0000120FBE7CAF309062A4601A9FFF726FD31 +:10DDF0000746149807281CD000222946FFF7DEFCAE +:10DE00000028EBD12878400613D501208DF80800B2 +:10DE10000898ADF80C00BDF80400ADF80E00ADF8A0 +:10DE20001060ADF8124002A94846F9F78CF90028B5 +:10DE3000D4D12978E87801F0030140EA0121AA78D9 +:10DE4000287902F0030240EA0220564507D0B1F5D6 +:10DE5000007F04D9611E814201DD0B20BEE78642AE +:10DE600001D90720BAE7801B85B2A54200D9254613 +:10DE7000BBF1000F01D0ABF80050179818B1B919D9 +:10DE80002A4616F095F9B8F1000F0DD03E444846E9 +:10DE90004446169F02F0D0FE2146FF1DBCB232461A +:10DEA0002B46009402F0DDFA002097E72DE9F041BF +:10DEB00007461D461646084600F066F804000BD0DB +:10DEC000384602F03BFD2178090607D53649897AA4 +:10DED000814203D8872012E5012010E52246314611 +:10DEE000FFF7ACFC65B12178E07801F0030140EA6E +:10DEF0000120B0F5007F01D8012000E0002028704B +:10DF00000020FCE42DE9F04107461D461646084670 +:10DF100000F03AF804000BD0384602F00FFD2178EB +:10DF2000090607D52049897A814203D88720E6E48B +:10DF30000120E4E422463146FFF7AEFCFF2D14D069 +:10DF40002178E07801F0030240EA022040F2012249 +:10DF5000B0FBF2F302FB130015B900F2012080B20E +:10DF6000E070000A60F3010121700020C7E410B5E1 +:10DF70000C4600F009F828B1C18821804079A070D2 +:10DF8000002010BD012010BD0749CA88824209D374 +:10DF900040B1096800EB40006FF00B0202EB80001B +:10DFA0000844704700207047E805002070B503461C +:10DFB000002002466FF02F050EE09C5CA4F13006B5 +:10DFC0000A2E02D34FF0FF3070BD00EB800005EB4E +:10DFD0004000521C2044D2B28A42EED370BD30B50C +:10DFE0000A240AE0B0FBF4F304FB13008D18303070 +:10DFF00005F8010C521E1846D2B2002AF2D130BDEB +:10E0000030B500234FF6FF7510E0040A44EA002003 +:10E0100084B2C85C6040C0F30314604005EA003479 +:10E020004440E0B25B1C84EA40109BB29342ECD3C4 +:10E0300030BD000010B582B0694601F0D1FD002866 +:10E0400018BFFFDF9DF80000002448B1019890F848 +:10E05000DD0028B1019880F8DD4001980AF0AFF9A1 +:10E06000F8488068A0F8D24002B010BD2DE9F04712 +:10E0700004460D46062002F043FC0646072002F047 +:10E080003FFC304400F0FF08002718EB050618BFDE +:10E090004FF000091DD02088401C80B22080B04283 +:10E0A00028BFA4F800902588454501D3B54209D37F +:10E0B0000621284602F07CFC20B90721284602F000 +:10E0C00077FC10B10020BDE8F087781CC7B2BE42D3 +:10E0D000E1D84FF6FF7020801220BDE8F08770B5C0 +:10E0E00082B007F073FB0DF0AFF9D74C4FF6FF7617 +:10E0F00000256683A683D5A12570D1E90001CDE96D +:10E10000000165706946A01C16F008FAA11C601C8D +:10E1100014F04CF825721B2060814FF4A471A1818A +:10E12000E08121820321A1740422E274A082E082B2 +:10E13000A4F13E00218305704680C6480570A4F115 +:10E1400010000570468002B070BDF8B5BD4D174691 +:10E150000E466860297007F0B3FA4FF6FF70ADF80D +:10E16000000000216846FFF781FFA0B90621BDF835 +:10E17000000002F02FFC04460721BDF8000002F069 +:10E1800029FC002C1CBF0028FFDF00216846FFF798 +:10E190006DFF0028EAD0FFF7A2FF287812F07CF884 +:10E1A0000FF0A0FC2978686813F013FF28780CF0B2 +:10E1B000ABFB30460AF00FF807F020FC29786868BE +:10E1C0000BF048FA3946287814F0ADFDBDE8F84068 +:10E1D0000DF03AB910B50124002A1CBF002010BD73 +:10E1E000002908BF022105D0012918BF002401D051 +:10E1F000204610BD0EF088FEFAE72DE9F04F8BB0F7 +:10E20000040008BFFFDF02218F4E06F11C00FFF75C +:10E210002DFF002818BFFFDFB6F81CA0062002F073 +:10E220006FFB0546072002F06BFB284400F0FF0857 +:10E2300008F1010000F0FF094FF0000BB78B4745D4 +:10E2400025D120460FF022F8002840F0CE8030780B +:10E25000002800F0CE8084F801B014202070C4F8AB +:10E2600004B0C4F808B0C4F80CB0C4F810B0C4F8D6 +:10E2700014B0C4F818B0C4F81CB00220C4F820B020 +:10E28000207186F800B00BB00120BDE8F08F4F453B +:10E2900020D1204607F04CFB00287DD007F02AFF54 +:10E2A000002859D02078172856D12079002853D03B +:10E2B000E088072102F07CFB050008BFFFDF28880B +:10E2C00007F017FAE088072102F084FB002818BF46 +:10E2D000FFDF8AE004A9384601F082FC00285BD108 +:10E2E0009DF8100048B107F07EFBB84254D021469B +:10E2F00038460BF0B8F880B377E00FF05AF8B84220 +:10E3000077D02146384613F085FD00286DD1059859 +:10E3100000F1580590F8D00018B9E87E08B1012046 +:10E3200000E00020079095F8370000281CBF95F802 +:10E33000380010F0020F1CD084F801B001202070CA +:10E3400084F804B0E78095F839002072688F608106 +:10E35000A88FA08185F837B047E0FFE7059800F166 +:10E36000580590F80C010028DBD1E87E0028D8D0B1 +:10E37000D5E7384602F060FC0290002808BFFFDFB6 +:10E38000029801F06FFE50B184F801B00F212170A6 +:10E39000E7802081012000E02BE0207125E0384655 +:10E3A00002F038FC0290002808BFFFDF079800B396 +:10E3B000029801F0AEFEE0B19DF8100038B9059862 +:10E3C000D0F8F8004188B94208BF80F800B038465C +:10E3D00007F08FF984F801B00C20207084F804B0A5 +:10E3E000E780287F207285F81BB00BB00120BDE8C4 +:10E3F000F08F022106F11C00FFF738FE18B9B08B30 +:10E4000050457FF41BAF0BB02046BDE8F04F14F031 +:10E41000D0BC10B512F08AFC042803D012F086FCA0 +:10E42000052802D10FF078FD28B90AF0A9F920B12A +:10E4300007F08AFC08B10C2010BD0DF051F8002047 +:10E4400010BD00005C00002032060020FFFFFFFF2F +:10E450001F0000006800002010B504460078002866 +:10E460001EBF0128122010BD12F060FC042806D047 +:10E4700012F05CFC052802D00AF082F928B10DF0F8 +:10E480007EF900281CBF0C2010BD2078002816BF84 +:10E4900002280020012004F11703E21D611CBDE8E1 +:10E4A00010400DF075B810B50446007800281EBF66 +:10E4B0000128122010BD12F039FC042803D012F0FC +:10E4C00035FC052802D10FF027FD28B90AF058F9CC +:10E4D00020B107F039FC08B10C2010BD20780028CD +:10E4E00016BF022800200120611C0CF0BFFF00288D +:10E4F00014BF0020072010BD10B50DF043F900280F +:10E5000014BF0020302010BD10B5044612F00EFCE0 +:10E51000042806D012F00AFC052802D00AF030F9CF +:10E5200008B10C2010BD20460DF026F9002010BDCA +:10E5300010B512F0FBFB042806D012F0F7FB0528FB +:10E5400002D00AF01DF928B10DF019F900281CBFFE +:10E550000C2010BD0DF075F8002010BDFF2181705A +:10E560004FF6FF718180FE4949680A7882718A8876 +:10E57000028149884181012141700020704710B516 +:10E58000002482B012F1080F16D00CDC12F1280F13 +:10E5900018BF12F1140F0FD012F1100F18BF12F1A3 +:10E5A0000C0F09D00EE012F1040F18BF002A03D09F +:10E5B000032A18BF042A05D1012807D0022809D050 +:10E5C00003280BD0122402B0204610BD104607F0DD +:10E5D0008CFDF8E710460FF03AFAF4E708461446C7 +:10E5E000694601F0FDFA002818BF0224EBD19DF81E +:10E5F0000000019880F857400024E4E710B5134666 +:10E6000001220DF0A6FF002010BD10B5044612F047 +:10E610008DFB052804BF0C2010BD204611F02AFEFA +:10E62000002010BD10B5044612F080FB042806D06F +:10E6300012F07CFB052802D00AF0A2F808B10C20E9 +:10E6400010BD2146002007F0C2F8002010BD10B513 +:10E65000044611F0B9FE50B10AF085F838B12078BF +:10E6600009F0DDFD20780FF090FC002010BD0C209B +:10E6700010BD10B5044612F059FB042806D012F064 +:10E6800055FB052802D00AF07BF808B10C2010BD1C +:10E690002146012007F09BF8002010BD38B5044644 +:10E6A0004FF6FF70ADF80000A079E179884213D0F1 +:10E6B00021791F299CBF61791F290DD8002211469D +:10E6C00014F030FF40B90022E079114614F02AFF1F +:10E6D00010B9207A072801D9122038BD0AF050F865 +:10E6E00060B912F023FB48B900216846FFF7BEFC71 +:10E6F00020B1204606F031F8002038BD0C2038BD8E +:10E7000070B504468078002582B01A2825D00EDC2A +:10E71000162844D2DFE800F04343434343214343F8 +:10E7200043434343434343434343432121212A2853 +:10E7300035D00BDCA0F11E000C2830D2DFE800F051 +:10E740002F2F2F2F2F2F2F2F2F2F2F0D3A38042819 +:10E7500025D2DFE800F0240224022088B0F5706F93 +:10E760001DD20126694601F03BFA00281EBF022097 +:10E7700002B070BD9DF80000002801980BBF00F1A9 +:10E78000F40100F5B87100F1F50300F271130246CF +:10E7900012D192F8D00092F8732052B903E002B07F +:10E7A0004FF0120070BD002818BF042801D008786F +:10E7B00068B102B00C2070BD92F80C0192F8732081 +:10E7C000002AF6D1002818BF0428F0D1F1E70E7016 +:10E7D000A07818709DF8000048B1019890F8DD000D +:10E7E00028B1019880F8DD50019809F0E8FD02B0E9 +:10E7F000002070BDF0B583B00C46694601F0F0F919 +:10E8000028B1204615F074FE03B00220F0BD019837 +:10E81000002700F1580500F1080600BF85F8407098 +:10E820003146204615F07AFE95F840000028F5D1D3 +:10E8300003B0F0BD2DE9F0410D4604460189808802 +:10E8400000230DF0BCFF696A814228BFBDE8F0815A +:10E85000401A401C4108A0884FF0000C401A80B2BA +:10E86000A08022896FF00E07511A8AB2228195F892 +:10E870005460618816F00C0F6FF00D0328D0B0F5CE +:10E88000747F38BF604606D35038C61700EB9660D9 +:10E8900003EBA01080B2814238BF0846608095F833 +:10E8A0005510E08811F00C0F1BD0B2F5747F09D31E +:10E8B000A2F15001CA1701EB926103EBA11100BF55 +:10E8C0001FFA81FC604528BF6046E080BDE8F0810A +:10E8D000022E1ABF03EBD00080B207EB9000DAD112 +:10E8E000D8E702291ABF03EBD2011FFA81FC07EB1C +:10E8F0009201E7D1E4E7F0B587B00C46054604A9DC +:10E9000001F06EF900281CBF07B0F0BD9DF81000A3 +:10E91000002814BF002201220599B1F84A30FB2BD0 +:10E9200028BFFB23B1F84CC0BCF1FB0F28BF4FF050 +:10E93000FB0C0C4FD7E90006BF68009001960297C8 +:10E94000ADF80230ADF806C06846FFF773FF65808A +:10E95000BDF80400E080BDF80800608104E000001C +:10E960005C00002040470200BDF80200A080BDF816 +:10E970000600208107B00020F0BD2DE9F04F89B0DE +:10E9800004460088694601F02BF95FEA00081CBFC5 +:10E9900009B0BDE8F08FB4F806C02289ACF11B01C4 +:10E9A0001220E12924BF09B0BDE8F08FB2F5A47FA1 +:10E9B0003CBF09B0BDE8F08F44F29025AA4284BF65 +:10E9C00009B0BDE8F08F00276388A188A3F11B067A +:10E9D000E12E24BF09B0BDE8F08FB1F5A47F2EBFB2 +:10E9E0008D4209B0BDE8F08F1120BCF1FB0F99BF3B +:10E9F00040F64806B24209B0BDE8F08FFB2B92BF4B +:10EA0000B14209B0BDE8F08F208806A901F0E8F80E +:10EA1000002818BFFFDF35D19DF8180000280CBF73 +:10EA2000012200220799B1F84A00FB2828BFFB20E9 +:10EA3000B1F84C30FB2B28BFFB23DFF858B7DBF8CD +:10EA400000C0DBF804A0DBF808B0CDF808C0CDF8B2 +:10EA50000CA0CDF810B0ADF80A00ADF80E3002A849 +:10EA6000FFF7E8FEBDF80C0060F31F45BDF810008D +:10EA700060F31F49BDF80A0060F30F05BDF80E00F2 +:10EA800060F30F0962881FFA89F1092091423CBFA7 +:10EA900009B0BDE8F08FA9B2E28891423CBF09B04D +:10EAA000BDE8F08F4FEA1941A288238901EB154197 +:10EAB0001A4491423CBF09B0BDE8F08F9DF80000B8 +:10EAC0004FF001090028019808D000F5CD7580F8B5 +:10EAD0009B91019890F8DE0148B307E000F582753C +:10EAE00080F80591019890F8280110B14FF03A088C +:10EAF00018E0E08868806088E8802089A880A08885 +:10EB00002881012228460199FFF794FEA888B04287 +:10EB100028BF40F64800A8802889B0421DD228812D +:10EB200085F800906F7009B04046BDE8F08FE0882E +:10EB300068806088E8802089A880A08828810022D9 +:10EB400028460199FFF776FEA888B04228BF40F614 +:10EB50004800A8802889B042E1D340F64800DEE7AB +:10EB60000BE710B5044612F0E1F8042806D012F0C5 +:10EB7000DDF8052802D009F003FE28B10CF0FFFDF6 +:10EB800000281CBF0C2010BD2078002816BF0228CA +:10EB900000200120E279611C0CF075FF002814BFF1 +:10EBA0000020022010BD817831F0070207BFC27833 +:10EBB00032F007031220704711F0040F0EBF12F05D +:10EBC000040F1120704701F023B810B504460178F6 +:10EBD000122084B0012918BF002904D002291EBFC9 +:10EBE000032904B010BD6178002918BF012904D0A1 +:10EBF00002291EBF032904B010BDE17B21B9A17811 +:10EC000001291CBF04B010BDA17831F005021CBF62 +:10EC100004B010BD11F0050F04BF04B010BD11F019 +:10EC2000040F1EBF112004B010BDE178E388628993 +:10EC300000291EBF012904B010BD042B2EBF042AD9 +:10EC400004B010BDA17B002904BF04B010BD07298A +:10EC500084BF04B010BD12F069F8042837D012F058 +:10EC600065F8052833D0A0788DF80800A0788DF8D5 +:10EC7000000060788DF8040020788DF80300A07BF8 +:10EC80008DF80500E07B002818BF01208DF80600F4 +:10EC9000A07810F0010F10D0E078012808BF022002 +:10ECA00003D000280CBF012000208DF80100E0886F +:10ECB000ADF80A006089ADF80C0002A811F091FBD4 +:10ECC000002804BF68460FF065F904B010BD04B019 +:10ECD0000C2010BD10B5044602781220012A0FD076 +:10ECE000002A18BF10BD012A26D012F01FF80528EF +:10ECF00004D011F0F6F9002808BF10BD0C2010BD9B +:10ED00006178002918BF012906D0022918BF10BD5B +:10ED1000A188002908BF10BD6388002B1CBFA188F3 +:10ED20000029E0D003EB83035B0001EB8101B3EB2F +:10ED3000012F28BF10BDD6E70FF01DF8002804BF33 +:10ED4000122010BD0FF02CF800200FF0D3F800288F +:10ED500018BF10BD60780FF0B1F8002818BF10BDC3 +:10ED6000A1886088BDE8104011F064BB002100F06C +:10ED7000B1BF017811F0010F02D0406813F0ECBF71 +:10ED800013F0B9BF2DE9F04F8FB00D460246AFF634 +:10ED90004411D1E90001CDE90B011146284600F0EC +:10EDA00099FF00281CBF0FB0BDE8F08F11F0BEFF27 +:10EDB00004280CD011F0BAFF052808D0F64F387897 +:10EDC00028B90EF0F6FAA0F57F41FF3903D00FB055 +:10EDD0000C20BDE8F08FF1480890F1480990F14807 +:10EDE0000A9008AA06210DA801F0B0FD040002BF98 +:10EDF00009200FB0BDE8F08F03210DF052F9B98A58 +:10EE0000A4F84A10FA8AA4F84C20F87C0090BB7C45 +:10EE1000208801F088FE002818BFFFDF208806F058 +:10EE200067FC268804F10E094FF0000B4FF00A0A28 +:10EE30000421484604F04DFF48460DF001FB062032 +:10EE400001F05EFD80461CE005A9062001F039FDB9 +:10EE500005A801F014FD5FEA000B10D1BDF8180001 +:10EE6000B04206D00798042249460E3015F074F9D6 +:10EE700070B105A801F003FD5FEA000BEED0A8F128 +:10EE80000108B8F1000F07DDBBF1000FDCD007E08F +:10EE900048460DF0DEFAF2E7BBF1000F08BFFFDFD6 +:10EEA000D9F800000CF07AFFBAF1010A01D000286D +:10EEB000BED0BDA004F1120600680190032101A894 +:10EEC00004F0DEFE002001A90A5C3254401CC0B2EE +:10EED0000328F9D3A88B6080688CA080288DE080FF +:10EEE000687A10F0010F18BF01217CD0388B0A46D8 +:10EEF00011F009FB0146A062204611F030FB4FF0F3 +:10EF0000000884F85E8084F85F80A878002816BF27 +:10EF10000228002001206076D5F80300C4F81A000A +:10EF2000B5F80700E0830BA904F1080015F0F6FA24 +:10EF30004FF0010984F80091B4F84C0004F5827692 +:10EF40004A46FB2828BFFB207989814238BF084602 +:10EF500094F855104FF4747A11F00C0F1CBF0AEBA3 +:10EF600080111FFA81FC72D0B989614538BF8C4687 +:10EF7000B4F84A10FB2928BFFB21FB898B4238BF1C +:10EF8000194694F854B01BF00C0F1CBF0AEB811308 +:10EF90009BB265D03F8A9F4238BF3B461B2918BFB2 +:10EFA000B3F5A47F65D0F080A6F808C07180B38067 +:10EFB00021463046FFF73EFCB08840F648018842C3 +:10EFC00028BF40F64800B0803089884228BF40F60C +:10EFD0004800308186F800908DF800800121684655 +:10EFE00004F04EFE00E02BE09DF8000000F0070169 +:10EFF000C0F3C1021144C0F3401008448DF8000072 +:10F00000401D207609283CBF08302076002120468C +:10F010000DF047F868780EF0B9FEA9782878EA1C58 +:10F020000EF087FE002808BF122650D00EF0B8FE62 +:10F03000A9782878EA1C0EF01BFF06001FD046E0D6 +:10F0400010F0020F14BF022100214FE7FFE7022951 +:10F0500007BF81003C31C10070311FFA81FC83E79A +:10F06000BBF1020F07BF8B003C33CB0070339BB268 +:10F0700090E71B2818BFBCF5A47F94D1ACE7012012 +:10F080000EF04CFE060022D1214603200EF028FF90 +:10F0900006001CD1687A8DF8000010F0010F05D031 +:10F0A0006889ADF80200288AADF80400684611F0BE +:10F0B00098F9064695F83A00002818BF01200EF08E +:10F0C00033FE26B9204611F026F9060009D0208823 +:10F0D00006F00FFB2088062101F07CFC002818BFF9 +:10F0E000FFDF30460FB0BDE8F08F0146002049E653 +:10F0F00038B5294C207870B911F018FE052805D0D4 +:10F100000EF057F9A0F57F41FF3904D0684611F0A1 +:10F11000CCF910B113E00C2038BD0098008806F03F +:10F12000E8FA00980621008801F054FC002818BF76 +:10F13000FFDF012020701D480078FCF727FE00202B +:10F1400038BD70B4B0F802C08188C3880289448990 +:10F150008089ACF1060640F67B45AE423CBF8E1F6F +:10F16000AE4214D28C4598BFB3F5FA7F3EBFA2F1F0 +:10F170000A0C0F4D15EB0C0509D25B1C5943B1EB82 +:10F18000820F04DA84429EBF002070BC704730209A +:10F1900070BC70474047020032060020F405002092 +:10F1A0006800002022060020112233005C000020AD +:10F1B00089F3FFFF2DE9F047B0F802C004468188CB +:10F1C000C388028947898689ACF1060940F67B48E5 +:10F1D00030200025C1453ABFA1F10609C145BDE86F +:10F1E000F0878C4598BFB3F5FA7F3DBFA2F10A0CBA +:10F1F000DFF8B48418EB0C08BDE8F0875B1C5943BA +:10F20000B1EB820FA8BFBDE8F087B74288BFBDE869 +:10F21000F0872088062101F0CBFB68B190F8D01070 +:10F2200090F8732042B9002918BF042904D0D0F8FF +:10F23000F8100A781AB106E00220BDE8F087D0F88D +:10F240004421127812B13A20BDE8F08705228A7174 +:10F25000D0F8F8100D81D0F8F820A1885181D0F8AD +:10F26000F820E1889181D0F8F8202189D181D0F867 +:10F27000F8100A894B899A429EBF8A79082A9A42D5 +:10F2800024BF1220BDE8F08722884A80D0F8F80019 +:10F29000022101700020BDE8F087F0B583B005467B +:10F2A0000DF0F2F8002802BF122003B0F0BD0026D6 +:10F2B000FE4F012429467C70B81C15F02FF97E7092 +:10F2C0006946062001F0FDFA002818BFFFDF6846F6 +:10F2D00001F0D5FA002808BFBDF804500AD1029801 +:10F2E00080F80041684601F0CAFA18B9BDF8040078 +:10F2F000A842F4D103B00020F0BD10B50446008848 +:10F30000062101F055FB68B190F8D01090F87320F9 +:10F3100042B9002918BF042904D0D0F8F8100A789F +:10F3200012B105E0022010BDD0F8442112780AB1D4 +:10F330003A2010BD90F8962012F0010F04BF0C2067 +:10F3400010BDD4F80220D4F806304A608B60D0F8A3 +:10F35000F81062898A81D0F8F810E268C1F80E20AE +:10F360002269C1F812206269C1F81620A269C1F8A9 +:10F370001A20D0F8F82003211170D0F8F800218865 +:10F380004180002010BDF8B515460E46044609F030 +:10F39000F7F900281CBF0C20F8BD20781223EF28B5 +:10F3A00073D86088ADF8000010F0100F4FF0000126 +:10F3B0000CD010F0010F00F002021BD0B2B110F01F +:10F3C000080F08BF10F0040F1ED01AE010F0080F4D +:10F3D0007ED110F0200F18BF10F0030F78D110F07D +:10F3E000010F18BF10F0020F72D10DE010F0040FE2 +:10F3F0000AD106E02AB110F0080F08BF10F0040F80 +:10F4000002D010F00F0F63D1608810F0080F09D1FF +:10F41000D4E901C2624528BFBCF1200F58D3B2F134 +:10F42000807F55D2227B002A52D0072A50D894F8E8 +:10F430000DC0BCF1000F18BFBCF1010F05D0BCF12D +:10F44000020F18BFBCF1030F42D110F0040F05D119 +:10F45000BCF1020F18BFBCF1030F07D1A27B002A39 +:10F4600018BF012A34D110F0040F08D1627D002AA0 +:10F4700018BF012A03D0022A18BF032A28D1E27D2F +:10F4800010F0100F02D0012A10D021E0012A18BF7D +:10F49000032A1DD110F0100F08D1627E012A1CBF73 +:10F4A000022A032A14D1A27E0F2A11D8E27E002A52 +:10F4B00018BF012A0CD1E27D1123032A08D010F0D5 +:10F4C000100F04BF627E032A02D010F0400F01D05B +:10F4D0001846F8BD3170A17555B9FF208DF80000B0 +:10F4E0006946002006F0EDFD6946002006F0D4FDD7 +:10F4F0002046BDE8F84006F004BD002243E72DE9B0 +:10F50000F0470446C0780F46122510B106F063FD9F +:10F5100050B1607804280AD094F8038094F80090E1 +:10F520006678B8F1FB0F12D92846BDE8F08709F0DC +:10F5300027F90028F8D006F0A6FD0028F4D106F03F +:10F540009AFA002804BFE0780028EDD1E4E71FB163 +:10F55000B8F11F0F23D9E7E706F08DFA28B1B8F10B +:10F560001F0F98BF032E07D0DEE7032E18BF042E0F +:10F5700002D0B8F1000FD7D009F002F9002818BF67 +:10F58000032E04D0042E1CBF0C20BDE8F087484693 +:10F5900006F069FA002804BF4220BDE8F087E07851 +:10F5A00061781F2898BF03291CBF1120BDE8F08790 +:10F5B000211D06F086FD0020BDE8F08700219EE7B2 +:10F5C0002DE9F0470446C0788846122710B106F0AE +:10F5D00098FD38B16578042D04D0E67894F8009051 +:10F5E000FB2E02D93846BDE8F087B8F1000F02D0F3 +:10F5F0001F2E21D9F6E706F03EFA20B11F2E98BF44 +:10F60000032D06D0EEE7032D18BF042D01D0002EE8 +:10F61000E8D009F0B5F8002818BF032D04D0042D58 +:10F620001CBF0C20BDE8F087484606F01CFA0028F5 +:10F6300004BF4220BDE8F087E07861781F2898BFBA +:10F6400003291CBF1120BDE8F087211D06F024FD11 +:10F650000020BDE8F0870021B2E72DE9F041044623 +:10F660004078422582B0012808D8A07806F0FBF93E +:10F6700020B120781225012804D0A0B102B028467C +:10F68000BDE8F08106F04BFD20B1A0880028F5D040 +:10F690008028F3D806F050FD90B160780028EDD0B6 +:10F6A0002078012810D003E089F3FFFF3206002004 +:10F6B00007F0EAFE044608F0DBFC002800F0EA80D0 +:10F6C00002B00C20BDE8F08106F046FB38B906F028 +:10F6D0001FFD002802BF122002B0BDE8F08109F032 +:10F6E0004FF80028ECD106F07EF9A0F57F41FF39F4 +:10F6F000E6D106F050FBA08842F2107100FB01F643 +:10F70000A079314606F078FC06F0F4FC18B300222C +:10F71000072101A801F01AF9040002BF092002B074 +:10F72000BDE8F081F6480321846020460CF072FBAE +:10F73000204607F0EBF8F34DA88AA4F84A00E88ABF +:10F74000A4F84C0006F097F968B1288B012108F065 +:10F7500013FEA0620FE03146002008F063FD002890 +:10F7600018BFFFDFA1E006F0E9FC2A8B0146104636 +:10F7700008F002FEA06201460022204607F087FE44 +:10F7800006F079F9002808BF06F0D8FCE87C009064 +:10F79000AB7CEA8AA98A208801F0C5F9002818BF45 +:10F7A000FFDF208805F0A4FF3146204608F03AFD2F +:10F7B000002818BFFFDF2146B4F84C00002204F5F2 +:10F7C000CD76FB2828BFFB206B89834238BF1846C3 +:10F7D00091F855304FF4747413F00C0F1CBF04EB08 +:10F7E00080131FFA83FC38D0AF89674528BF67466E +:10F7F000B1F84A30FB2B28BFFB23B5F80EC09C455F +:10F8000038BF634691F854C01CF00C0F1CBF04EBCA +:10F81000831C1FFA8CF829D02C8A444528BF444603 +:10F820001B2B18BFB4F5A47F2ED0F08037817380D6 +:10F83000B4803046FEF7FEFFB08840F648018842AB +:10F8400028BF40F64800B0803089884228BF40F683 +:10F85000480030810120307027E0022B07BF830071 +:10F860003C33C30070331FFA83FCBDE7BCF1020FC9 +:10F8700007BF4FEA830C0CF13C0C4FEAC30C0CF1B0 +:10F88000700C1FFA8CF8C7E71B2818BFB7F5A47FC8 +:10F89000CBD10AE04CB1208805F02BFF208807214E +:10F8A00001F098F8002818BFFFDF002002B0BDE883 +:10F8B000F0810021D1E610B50C46072101F078F85F +:10F8C000002804BF022010BD90F8731109B10C206C +:10F8D00010BD90F86510142912BF152990F8C011B9 +:10F8E0000029F4D12168C0F874116168C0F878115A +:10F8F000A168C0F87C11E168C0F88011012180F88E +:10F900007311002010BD10B5072101F051F8002837 +:10F9100004BF022010BD90F8731109B10C2010BD76 +:10F9200090F86510142918BF1529F7D1022180F825 +:10F930007311002010BDF0B50E464BF68032122137 +:10F9400083B0964217D8B6B1694600F049F900284D +:10F950001CBF03B0F0BD019800F15807841C258836 +:10F960003246294638460CF00FFA2088A842F6D1D4 +:10F9700003B00020F0BD03B00846F0BD10B582B062 +:10F9800004460088694600F02BF900281CBF02B02D +:10F9900010BD0198A37800F1580190F82C209A42EC +:10F9A00002BF0C2002B010BD7F220A728A720022B0 +:10F9B000CA72E17880F82D10217980F82E10A17894 +:10F9C00080F82C1002B0104610BD10B582B00C4665 +:10F9D000694600F005F900281CBF02B010BD01986F +:10F9E00090F87300002818BF0120207002B000209A +:10F9F00010BD30B583B00D461446694600F0F0F8EE +:10FA000000281CBF03B030BD019890F82C000128DD +:10FA10001EBF0C2003B030BD019890F86010297013 +:10FA200090F86100207003B0002030BD70B50D4625 +:10FA30001646072100F0BCFF002804BF022070BD5D +:10FA400083884FF0010CC28841880CEB430C65455C +:10FA50001AD342F2107C02FB0CF240F6C41C01FBEC +:10FA60000CF1B2FBF1F1491E8CB2B4F5FA7F88BFFC +:10FA70004FF4FA74A54238BF2C46621C591CB2FBE5 +:10FA8000F1F25143491E8BB290F8AC11002908BF26 +:10FA900003843380002070BD10B50C46072100F0B0 +:10FAA00087FF002804BF022010BD80F8DF40002C33 +:10FAB0001EBF90F8DD10002908F081FC002010BD69 +:10FAC000017800291CBF417800290ED041881B29EC +:10FAD00021BF81881B29C188022906D30A490268EF +:10FAE00040680A654865002070471220704710B5CD +:10FAF000044610F005FD204608F009FC002010BD6A +:10FB00005C00002032060020F40500202DE9F041C1 +:10FB100016460F46044601221146384610F0F3FC03 +:10FB200005460121384608F027FC854228BF2846B3 +:10FB30000123E100503189B2E631884206D901F152 +:10FB40009602401AB0FBF2F0401C83B233800020D2 +:10FB5000BDE8F08110B5044611F0E8F8042806D09D +:10FB600011F0E4F8052802D008F00AFE08B10C20D4 +:10FB700010BD601C0BF05DFF207800F0010006F066 +:10FB800005F9207800F001000EF005F9002010BD05 +:10FB900010B50446072000F0A5FE00281CBF0C206D +:10FBA00010BD207810F0010F11D0002260781146AE +:10FBB00013F0B8FC00281CBF122010BDA0680AF08A +:10FBC00048FA607861680AF04DFA002010BD002004 +:10FBD0000AF03FFA002108460AF044FA002010BD5E +:10FBE00070B50C460546062100F0E2FE606010B1DB +:10FBF0000020207070BD0721284600F0D9FE60600B +:10FC0000002804BF022070BD01202070002070BDBC +:10FC100010B582B0044600886946FFF7E1FF020094 +:10FC20001CBF02B010BDA088002818BF012804D056 +:10FC300002281EBF122002B010BDA178002908BF03 +:10FC40000321E078002808BF03204FF0000C9DF846 +:10FC500000400123002C019C06D084F8A531019CB2 +:10FC600094F8F241ECB124E084F80F31019C94F84F +:10FC700034413CB9019C94F80E411CB9019C94F8A4 +:10FC80007D400CB13A2208E0019C84F80E31019BC2 +:10FC900083F81011019981F81101019880F80FC1C2 +:10FCA00015E0019C94F8A4411CB9019C94F87D4096 +:10FCB0000CB13A2208E0019C84F8A431019B83F83E +:10FCC000A611019981F8A701019880F8A5C102B099 +:10FCD000104610BD427A12F0070F10D032F0070321 +:10FCE0000DD112F0040F01D011207047012A18BF66 +:10FCF000022AF9D190F83A301BB9012A01D012201A +:10FD000070472DE9F0074FF0000C12F0010F40F69C +:10FD1000774740F67B4337D069B14489B0F810C0CB +:10FD2000261F43F6FD75AE423CBFACF10406AE4261 +:10FD300026D2644524D3C68AB0F81CC0448C058DF5 +:10FD4000B0F82E90B0F83480A6F1060A9A453CBF70 +:10FD5000ACF1060A9A4513D2664598BFB4F5FA7F0E +:10FD60003CBFA5F10A06BE420AD2641C04FB0CFC8F +:10FD7000BCEB850F04DAC14598BF4FF0010C03D9E5 +:10FD8000BDE8F0073020704712F0020F22D000EBE0 +:10FD90004C02D68AB2F81CC0558C148DB2F82E8055 +:10FDA000928EA6F106094B4584BFACF106094B457E +:10FDB000E6D9664598BFB5F5FA7F3CBFA4F10A03C2 +:10FDC000BB42DDD26B1C03FB0CF3B3EB840FD7DA21 +:10FDD0009045D5D802782AB1012A13D0BDE8F007A2 +:10FDE000122070470029817808D0002918BF012906 +:10FDF00008D0022918BF032904D0EFE7002918BF53 +:10FE00000129EBD14078002818BF012803D002282F +:10FE100018BF0328E2D1BDE8F007002070470000BA +:10FE200030B5058825F4004421448CB24FF40041DC +:10FE300094420AD2121B92B21B339A4201D2A943B6 +:10FE400007E005F40041214303E0A21A92B2A9435E +:10FE50001143018030BD0844083050434A31084402 +:10FE600080B2704770B51D4616460B4604462946BB +:10FE70003046049AFFF7EFFF0646B34200D2FFDF99 +:10FE80002821204614F035FA4FF6FF70A082283E54 +:10FE9000B0B265776080B0F5004F00D9FFDF6188B0 +:10FEA00005F13C00814200D2FFDF60880835401B2D +:10FEB000343880B220801B2800D21B2020800020F4 +:10FEC000A07770BD8161886170472DE9F05F0D46B4 +:10FED000C188044600F12809008921F4004620F475 +:10FEE000004800F062FB10B10020BDE8F09F4FF029 +:10FEF000000A4FF0010BB0450CD9617FA8EB06005A +:10FF0000401A0838854219DC09EB060000210580FB +:10FF100041801AE06088617F801B471A083F0DD43A +:10FF20001B2F00DAFFDFBD4201DC294600E0B9B239 +:10FF3000681A0204120C04D0424502DD84F817A0AE +:10FF4000D2E709EB06000180428084F817B0CCE7C5 +:10FF500070B5044600F12802C088E37D20F400401B +:10FF60002BB110440288438813448B4201D20020F5 +:10FF700070BD00258A4202D30180458008E0891ABD +:10FF80000904090C418003D0A01D00F01EFB08E00D +:10FF9000637F00880833184481B26288A01DFFF790 +:10FFA0003FFFE575012070BD70B5034600F12804E0 +:10FFB000C588808820F400462644A84202D100204B +:10FFC000188270BD98893588A84206D3401B758871 +:10FFD0002D1A2044ADB2C01E05E02C1AA5B25C7FDC +:10FFE00020443044401D0C88AC4200D90D809C89CF +:10FFF00024B1002414700988198270BD0124F9E726 +:020000040001F9 +:1000000070B5044600F12801808820F400404518AE +:10001000208A002825D0A189084480B2A08129889F +:100020006A881144814200D2FFDF2888698800264F +:100030000844A189884212D1A069807F287169880B +:1000400019B1201D00F0C1FA08E0637F2888083349 +:10005000184481B26288201DFFF7E2FEA681268245 +:10006000012070BD2DE9F0414189878800260446B2 +:1000700000F12805B94218D004F10A0821F4004023 +:100080002844418819B1404600F09FFA08E0637F98 +:1000900000880833184481B262884046FFF7C0FEEA +:1000A000761C6189B6B2B942E8D13046BDE8F0812C +:1000B0002DE9F04104460B4627892830A68827F40D +:1000C0000041B4F80A8001440D46B74201D1002036 +:1000D000ECE70AB1481D106023B1627F691D184624 +:1000E00014F066F82E88698804F1080021B18A1995 +:1000F00096B200F06AFA06E0637F628808339919C5 +:1001000089B2FFF78DFE474501D1208960813046D5 +:10011000CCE78188C088814201D10120704700204E +:10012000704701898088814201D1012070470020F9 +:10013000704770B58588C38800F1280425F4004213 +:1001400023F4004114449D421AD08389058A5E1924 +:1001500025886388EC18A64214D313B18B4211D3BF +:100160000EE0437F08325C192244408892B2801A24 +:1001700080B22333984201D211B103E08A4201D107 +:10018000002070BD012070BD2DE9F0478846C18870 +:100190000446008921F4004604F1280720F40045B4 +:1001A00007EB060900F001FA002178BBB54204D93B +:1001B000627FA81B801A002503E06088627F801B95 +:1001C000801A083823D4E28962B1B9F80020B9F85E +:1001D00002303BB1E81A2177404518DBE08938440A +:1001E000801A09E0801A217740450ADB607FE189A7 +:1001F0000830304439440844C01EA4F81280BDE8D9 +:10020000F087454503DB01202077E7E7FFE76182C0 +:100210000020F4E72DE9F74F044600F12805C088D7 +:10022000884620F4004A608A05EB0A0608B140457A +:1002300002D20020BDE8FE8FE08978B13788B6F899 +:10024000029007EB0901884200D0FFDF207F4FF0CA +:10025000000B50EA090106D088B33BE00027A07FDD +:10026000B9463071F2E7E18959B1607F294408301D +:1002700050440844B4F81F1020F8031D94F82110CE +:100280008170E28907EB080002EB0801E181308010 +:10029000A6F802B002985F4650B1637F30880833F9 +:1002A000184481B26288A01DFFF7BAFDE78121E002 +:1002B000607FE18908305044294408442DE0FFE77D +:1002C000E089B4F81F102844C01B20F8031D94F8DF +:1002D0002110817009EB0800E28981B202EB08006D +:1002E000E081378071800298A0B1A01D00F06DF907 +:1002F000A4F80EB0A07F401CA077A07D08B1E088D4 +:10030000A08284F816B000BFA4F812B084F817B029 +:1003100001208FE7E0892844C01B30F8031DA4F8B2 +:100320001F10807884F82100EEE710B5818800F175 +:10033000280321F400442344848AC288A14212D0B5 +:10034000914210D0818971B9826972B11046FFF76C +:10035000E8FE50B91089283220F400401044197981 +:100360000079884201D1002010BD184610BD00F16F +:100370002803407F08300844C01E1060088808B970 +:10038000DB1E136008884988084480B270472DE955 +:10039000F04100F12806407F1C4608309046431883 +:1003A00008884D88069ADB1EA0B1C01C80B290421E +:1003B00014D9801AA04200DB204687B298183A462A +:1003C000414613F0C9FE002816D1E01B84B2B844A0 +:1003D000002005E0ED1CADB2F61EE8E7101A80B271 +:1003E0000119A94206D8304422464146BDE8F041F1 +:1003F00013F0B2BE4FF0FF3058E62DE9F04100F1A6 +:100400002804407F1E46083090464318002508887F +:100410004F88069ADB1E90B1C01C80B2904212D960 +:10042000801AB04200DB304685B299182A46404611 +:1004300013F0BEFE701B86B2A844002005E0FF1C2E +:10044000BFB2E41EEAE7101A80B28119B94206D899 +:1004500021183246404613F0ABFEA81985B2284653 +:1004600024E62DE9F04100F12804407F1E460830C3 +:1004700090464318002508884F88069ADB1E90B1E5 +:10048000C01C80B2904212D9801AB04200DB3046C4 +:1004900085B298182A46414613F08AFE701B86B230 +:1004A000A844002005E0FF1CBFB2E41EEAE7101AD2 +:1004B00080B28119B94206D820443246414613F031 +:1004C00077FEA81985B22846F0E5401D704710B5A3 +:1004D000044600F12801C288808820F400431944B2 +:1004E000904206D0A28922B9228A12B9A28A9042E9 +:1004F00001D1002010BD0888498831B1201D00F0CD +:1005000064F800202082012010BD637F62880833D8 +:10051000184481B2201DFFF783FCF2E70021C1815E +:1005200001774182C1758175704703881380C28944 +:1005300042B1C28822F4004300F128021A440A6042 +:10054000C08970470020704710B50446808AA0F526 +:100550007F41FF3900D0FFDFE088A082E08900B151 +:100560000120A07510BD4FF6FF71818200218175B9 +:10057000704710B50446808AA0F57F41FF3900D14D +:10058000FFDFA07D28B9A088A18A884201D1002080 +:1005900010BD012010BD8188828A914201D1807DE9 +:1005A00008B1002070470120704720F4004221F478 +:1005B00000439A4207D100F4004001F40041884210 +:1005C00001D0012070470020704730B504460088F4 +:1005D0000D4620F40040A84200D2FFDF21884FF4EE +:1005E000004088432843208030BD70B50C0005468C +:1005F00009D0082C00D2FFDF1DB1A1B2286800F09D +:1006000044F8201D70BD0DB100202860002070BD91 +:100610000021026803E093881268194489B2002A15 +:10062000F9D100F032B870B500260D46044608290D +:1006300000D2FFDF206808B91EE0044620688188E8 +:10064000A94202D001680029F7D181880646A94253 +:1006500001D100680DE005F1080293B20022994231 +:1006600009D32844491B0260818021680968216000 +:100670000160206000E00026304670BD00230B6062 +:100680008A8002680A600160704700234360021D8F +:10069000018102607047F0B50F4601884088154619 +:1006A0000C181E46AC4200D3641B3044A84200D94B +:1006B000FFDFA019A84200D9FFDF3819F0BD2DE9EE +:1006C000F041884606460188408815460C181F46AA +:1006D000AC4200D3641B3844A84200D9FFDFE019C4 +:1006E000A84200D9FFDF70883844708008EB04000E +:1006F000BDE8F0812DE9F041054600881E46174609 +:10070000841B8846BC4200D33C442C80688830441B +:10071000B84200D9FFDFA019B84200D9FFDF6888CE +:100720003044688008EB0400E2E72DE9F0410688D8 +:100730001D460446701980B2174688462080B8428C +:1007400001D3C01B20806088A84200D2FFDF70194F +:10075000B84200D9FFDF6088401B608008EB0600CC +:10076000C6E730B50D460188CC18944200D3A41AD0 +:100770004088984200D8FFDF281930BD2DE9F041AC +:10078000C84D04469046A8780E46A04200D8FFDF28 +:1007900005EB8607B86A50F8240000B1FFDFB8689F +:1007A000002816D0304600F044F90146B868FFF73B +:1007B0003AFF05000CD0B86A082E40F8245000D348 +:1007C000FFDFB9484246294650F826302046984770 +:1007D0002846BDE8F0812DE9F8431E468C19914664 +:1007E0000F460546FF2C00D9FFDFB14500D9FFDFDA +:1007F000E4B200954DB300208046E81C20F00300D1 +:10080000A84200D0FFDF4946DFF89892684689F891 +:10081000001089F8017089F8024089F8034089F8CE +:10082000044089F8054089F8066089F80770414658 +:1008300000F008F9002142460F464B460098C01CC4 +:1008400020F00300009012B10EE00120D4E703EB8A +:100850008106B062002005E0D6F828C04CF8207070 +:10086000401CC0B2A042F7D30098491C00EB8400A2 +:10087000C9B200900829E1D3401BBDE8F88310B548 +:10088000044603F071FD08B1102010BD2078854AA0 +:10089000618802EB800092780EE0836A53F8213081 +:1008A00043B14A1C6280A180806A50F82100A06098 +:1008B000002010BD491C89B28A42EED86180052013 +:1008C00010BD70B505460C46084603F04DFD08B155 +:1008D000102070BD082D01D3072070BD25700020A9 +:1008E000608070BD0EB56946FFF7EBFF00B1FFDF1A +:1008F0006846FFF7C4FF08B100200EBD01200EBD01 +:1009000010B50446082800D3FFDF6648005D10BD1F +:100910003EB5054600246946FFF7D3FF18B1FFDF57 +:1009200001E0641CE4B26846FFF7A9FF0028F8D094 +:100930002846FFF7E5FF001BC0B23EBD5949897844 +:10094000814201D9C0B27047FF2070472DE9F041C4 +:10095000544B062903D007291CD19D7900E00025BE +:1009600000244FF6FF7603EB810713F801C00AE07D +:100970006319D7F828E09BB25EF823E0BEF1000FC0 +:1009800004D0641CA4B2A445F2D8334603801846B0 +:10099000B34201D100201CE7BDE8F041EEE6A0F52E +:1009A0007F43FF3B01D0082901D300207047E5E6D3 +:1009B000A0F57F42FF3A0BD0082909D2394A937833 +:1009C000834205D902EB8101896A51F82000704702 +:1009D000002070472DE9F04104460D46A4F57F4103 +:1009E00043F20200FF3902D0082D01D30720F0E6C0 +:1009F0002C494FF000088A78A242F8D901EB85060D +:100A0000B26A52F82470002FF1D0274839462030BE +:100A100050F8252020469047B16A284641F82480A6 +:100A200000F007F802463946B068FFF727FE0020BD +:100A3000CFE61D49403131F810004FF6FC71C01C63 +:100A4000084070472DE9F843164E884605460024B5 +:100A50002868C01C20F0030028602046FFF7E9FF4B +:100A6000315D4843B8F1000F01D0002200E02A6850 +:100A70000146009232B100274FEA0D00FFF7B5FDA5 +:100A80001FB106E001270020F8E706EB8401009A79 +:100A90008A602968641C0844E4B22860082CD7D313 +:100AA000EBE60000500600204C47020070B50E46F1 +:100AB0001D46114600F0D4F804462946304600F0A1 +:100AC000D8F82044001D70BD2DE9F04190460D4638 +:100AD00004004FF0000610D00027E01C20F00300B7 +:100AE000A04200D0FFDFDDB141460020FFF77DFDD1 +:100AF0000C3000EB850617B112E00127EDE7614FDE +:100B000004F10C00A9003C602572606000EB8500D8 +:100B10002060606813F0EDFB41463868FFF765FD23 +:100B20003046BDE8F0812DE9FF4F564C804681B03C +:100B300020689A46934600B9FFDF2068027A424552 +:100B400003D9416851F8280020B143F2020005B0F2 +:100B5000BDE8F08F5146029800F082F886B2584600 +:100B60000E9900F086F885B27019001D87B22068D2 +:100B7000A14639460068FFF756FD04001FD0678084 +:100B800025802946201D0E9D07465A4601230095C3 +:100B9000FFF768F92088314638440123029ACDF8DE +:100BA00000A0FFF75FF92088C1193846FFF78AF9DE +:100BB000D9F800004168002041F82840C7E7042028 +:100BC000C5E770B52F4C0546206800B9FFDF2068E7 +:100BD000017AA9420ED9426852F8251051B100237A +:100BE00042F825304A880068FFF748FD2168002058 +:100BF0000A7A08E043F2020070BD4B6853F82030D7 +:100C000033B9401CC0B28242F7D80868FFF700FD34 +:100C1000002070BD70B51B4E05460024306800B939 +:100C2000FFDF3068017AA94204D9406850F82500F6 +:100C300000B1041D204670BD70B5124E054600245B +:100C4000306800B9FFDF3068017AA94206D94068F0 +:100C500050F8251011B131F8040B4418204670BD2E +:100C600010B50A460121FFF7F6F8C01C20F003007A +:100C700010BD10B50A460121FFF7EDF8C01C20F0A9 +:100C8000030010BD7000002070B50446C2F11005CD +:100C9000281913F08DFA15F0FF0108D0491EC9B2CA +:100CA000802060542046BDE8704013F000BB70BD4A +:100CB00030B505E05B1EDBB2CC5CD55C6C40C45447 +:100CC000002BF7D130BD10B5002409E00B78521E7F +:100CD00044EA430300F8013B11F8013BD2B2DC09BE +:100CE000002AF3D110BD2DE9F04389B01E46DDE99D +:100CF000107990460D00044622D002460846F94974 +:100D0000FDF77CFC102221463846FFF7DCFFE07B34 +:100D1000000606D5F34A3946102310320846FFF77D +:100D2000C7FF102239464846FFF7CDFFF87B000683 +:100D300006D5EC4A4946102310320846FFF7B8FFA3 +:100D40001021204613F0B3FA0DE0103EB6B208EBC6 +:100D50000601102322466846FFF7AAFF22462846CE +:100D60006946FDF74BFC102EEFD818D0F2B2414681 +:100D70006846FFF789FF10234A46694604A8FFF733 +:100D800097FF1023224604A96846FFF791FF2246E9 +:100D900028466946FDF732FC09B0BDE8F083102310 +:100DA0003A464146EAE770B59CB01E4605461346F2 +:100DB00020980C468DF80800202219460DF10900F4 +:100DC00013F0F6F9202221460DF1290013F0F0F975 +:100DD00017A913A8CDE90001412302AA31462846EC +:100DE000FFF781FF1CB070BD2DE9FF4F9FB014AE1F +:100DF000DDE92D5410AFBB49CDE900762023203129 +:100E00001AA8FFF770FF4FF000088DF808804FF028 +:100E100001098DF8099054F8010FCDF80A00A08857 +:100E2000ADF80E0014F8010C1022C0F340008DF84C +:100E3000100055F8010FCDF81100A888ADF8150085 +:100E400015F8010C2C99C0F340008DF8170006A886 +:100E5000824613F0ADF90AA883461022229913F0B6 +:100E6000A7F9A0483523083802AA40688DF83C80CD +:100E7000CDE900760E901AA91F98FFF734FF8DF880 +:100E800008808DF809902068CDF80A00A088ADF898 +:100E90000E0014F8010C1022C0F340008DF8100071 +:100EA0002868CDF81100A888ADF8150015F8010CD8 +:100EB0002C99C0F340008DF81700504613F078F9D4 +:100EC00058461022229913F073F9864835230838C2 +:100ED00002AA40688DF83C90CDE900760E901AA9E0 +:100EE0002098FFF700FF23B0BDE8F08FF0B59BB06E +:100EF0000C460546DDE922101E461746DDE9203284 +:100F0000D0F801C0CDF808C0B0F805C0ADF80CC0ED +:100F10000078C0F340008DF80E00D1F80100CDF844 +:100F20000F00B1F80500ADF8130008781946C0F3BA +:100F300040008DF815001088ADF8160090788DF8F7 +:100F400018000DF11900102213F032F90DF12900EB +:100F50001022314613F02CF90DF1390010223946D8 +:100F600013F026F917A913A8CDE90001412302AA1D +:100F700021462846FFF7B7FE1BB0F0BDF0B5A3B081 +:100F800017460D4604461E46102202A8289913F063 +:100F90000FF906A82022394613F00AF90EA82022DC +:100FA000294613F005F91EA91AA8CDE9000150231E +:100FB00002AA314616A8FFF796FE1698206023B0C5 +:100FC000F0BDF0B589B00446DDE90E070D4639786D +:100FD000109EC1F340018DF8001031789446C1F3A2 +:100FE00040018DF801101968CDF802109988ADF80C +:100FF000061099798DF808100168CDF809108188DC +:10100000ADF80D1080798DF80F0010236A46614607 +:1010100004A8FFF74DFE2246284604A9FDF7EEFA84 +:10102000D6F801000090B6F80500ADF80400D7F836 +:101030000100CDF80600B7F80500ADF80A00002061 +:10104000039010236A46214604A8FFF731FE22468A +:10105000284604A9FDF7D2FA09B0F0BD1FB51C68F7 +:1010600000945B68019313680293526803920246EE +:1010700008466946FDF7C2FA1FBD10B588B00446A0 +:10108000106804905068059000200690079008466C +:101090006A4604A9FDF7B2FABDF80000208008B046 +:1010A00010BD1FB51288ADF800201A88ADF80220D7 +:1010B0000022019202920392024608466946FDF719 +:1010C0009DFA1FBD7FB5074B14460546083B9A1C89 +:1010D0006846FFF7E6FF224669462846FFF7CDFF40 +:1010E0007FBD0000A447020070B5044600780E469C +:1010F000012813D0052802D0092813D10EE0A068DA +:1011000061690578042003F0BDF8052D0AD0782325 +:1011100000220420616903F00BF803E004206169F8 +:1011200003F0B0F831462046BDE8704001F086B8C3 +:1011300010B500F12D02C3799478411D64F00304C9 +:101140002340C371DB070DD04B79547923404B7199 +:101150000B79127913400B718278C9788A4200D9D1 +:10116000817010BD00224A710A71F5E741780129AA +:1011700000D00C21017070472DE9F04F93B04FF073 +:10118000000B0C690D468DF820B0097801260C2063 +:1011900017464FF00D084FF0110A4FF008091B29B0 +:1011A00075D2DFE811F01B00C30206031E035D03C6 +:1011B0007003A203B703F803190461049304A004A5 +:1011C000EC042A05340552055D05EE0531063406AA +:1011D00063067F06F9061D07E606EB0614B12078C4 +:1011E0001D282AD0D5F808805FEA08004FD00120DA +:1011F0008DF82000686A02220D908DF824200A20C4 +:101200008DF82500A8690A90A8880028EED098F8E3 +:10121000001091B10F2910D27ED2DFE801F07D13CA +:1012200049DEFEFDFCFBFAF938089CF8F7000228BD +:101230002DD124B120780C2801D00026EFE38DF8C1 +:101240002020CBE10420696A03F01CF8A888072855 +:10125000EED1204600F0EDFF022809D0204600F034 +:10126000E8FF032807D9204600F0E3FF072802D251 +:101270000120207004E0002CB8D020780128D7D1BC +:1012800098F80400C11F0A2902D30A2061E0C4E1D2 +:10129000A070D8F80010E162B8F80410218698F820 +:1012A000060084F83200012028700320207044E0FA +:1012B0000728BDD1002C99D020780D28B8D198F8F6 +:1012C000031094F82F20C1F3C000C2F3C0021042F3 +:1012D00001D0062000E00720890707D198F8051003 +:1012E0000142D2D198F806100142CED194F83120B3 +:1012F00098F8051020EA02021142C6D194F8322073 +:1013000098F8061090430142BFD198F80400C11F1D +:101310000A29BAD2617D00E006E281427ED8D8F87F +:1013200000106160B8F80410218198F80600A072DE +:10133000012028700E20207003208DF82000686A9C +:101340000D9004F12D000990601D0A900F300B9054 +:1013500022E12875FDE3412891D1204600F069FF84 +:10136000042802D1E078C00704D1204600F061FFD4 +:101370000F2884D1A88CD5F80C8080B24FF0400B98 +:10138000E669FFF747FC324641465B464E46CDF8DC +:101390000090FFF732F80B208DF82000686A0D905E +:1013A000E0690990002108A8FFF79EFE2078042834 +:1013B00006D0A07D58B1012809D003280AD049E3FE +:1013C00005202070032028708DF82060CDE184F87E +:1013D00000A032E712202070E9E11128BCD120469C +:1013E00000F027FF042802D1E078C00719D020467A +:1013F00000F01FFF062805D1E078C00711D1A07DBD +:1014000002280ED0204600F014FF08E0CAE081E078 +:101410006FE14EE121E101E1E7E017E0ADE11128E4 +:101420009AD1102208F1010104F13C0012F0C0FE33 +:10143000607801287ED012202070E078C00760D04C +:10144000A07D0028C8D00128C6D05AE0112890D12C +:10145000204600F0EEFE082804D0204600F0E9FE09 +:10146000132886D104F16C00102208F10101064610 +:1014700012F09EFE207808280DD014202070E1780C +:10148000C8070DD0A07D02280AD06278022A04D0B5 +:101490000328A1D035E00920F0E708B1012837D1B1 +:1014A000C80713D0A07D02281DD000200090D4E9E9 +:1014B000062133460EA8FFF776FC10220EA904F190 +:1014C0003C0012F049FEC8B1042042E7D4E90912F9 +:1014D000201D8DE8070004F12C0332460EA8616B35 +:1014E000FFF76FFDE9E7606BC1F34401491E006837 +:1014F000C84000F0010040F08000D7E720780928BC +:1015000006D185F800908DF8209033E32870ECE345 +:101510000920FBE711289AD1204600F08AFE0A280C +:1015200002D1E078C00704D1204600F082FE1528E1 +:101530008DD100E08DE104F13C00102208F10101A1 +:10154000064612F035FE20780A2816D016202070A4 +:10155000D4E90932606B611D8DE80F0004F15C0372 +:1015600004F16C0247310EA8FFF7C0FC10220EA94F +:10157000304612F0F1FD18B1F5E20B20207071E257 +:101580002046FFF7D5FDA078216A0A18C0F11001A6 +:10159000104612F08CFE23E3394608A8FFF7A4FD9D +:1015A00006463BE20228B6D1204600F042FE04285F +:1015B00004D3204600F03DFE082809D3204600F061 +:1015C00038FE0E2829D3204600F033FE122824D2FC +:1015D000A07D02289FD10E208DF82000686A0D9012 +:1015E00098F801008DF82400F0E3022893D12046FA +:1015F00000F01FFE002810D0204600F01AFE01283F +:10160000F9D0204600F015FE0C28F4D004208DF807 +:10161000240098F801008DF825005EE21128FCD125 +:10162000002CFAD020781728F7D16178606A022957 +:1016300011D0002101EB4101182606EBC101102257 +:10164000405808F1010112F0B3FD0420696A00F06E +:10165000E3FD2670F1E50121ECE70B28DDD1002C3C +:10166000DBD020781828D8D16078616A02281CD095 +:101670005FF0000000EB4002102000EBC2000958B0 +:10168000B8F8010008806078616A02280FD0002055 +:1016900000EB4002142000EBC2000958404650F80D +:1016A000032F0A604068486039E00120E2E701202A +:1016B000EEE71128B1D1002CAFD020781928ACD199 +:1016C0006178606A022912D05FF0000101EB4101EC +:1016D0001C2202EBC1011022405808F1010112F056 +:1016E00067FD0420696A00F097FD1A20B6E0012129 +:1016F000ECE7082891D1002C8FD020781A288CD1C3 +:10170000606A98F80120017862F347010170616A0C +:10171000D8F8022041F8012FB8F80600888004208C +:10172000696A00F079FD8EE2072012E63878012818 +:1017300094D1182204F11400796812F07EFDE0794A +:10174000C10894F82F0001EAD001E07861F30000AD +:10175000E070217D002974D12178032909D0C007C8 +:1017600025D0032028708DF82090686A0D904120C4 +:1017700004E3607DA178884201D90620E9E50226CC +:101780002671E179204621F0E001E171617A21F0D2 +:10179000F0016172A17A21F0F001A172FFF7C8FC9B +:1017A0002E708DF82090686A0D900720E6E20420E4 +:1017B000ACE6387805289DD18DF82000686A0D9038 +:1017C000B8680A900720ADF824000A988DF830B068 +:1017D0006168016021898180A17A81710420207073 +:1017E000F4E23978052985D18DF82010696A0D91C8 +:1017F000391D09AE0EC986E80E004121ADF824104E +:101800008DF830B01070A88CD7F80C8080B24026CC +:10181000A769FFF711FA41463A463346C846CDF864 +:101820000090FEF71EFE002108A8FFF75DFCE0789F +:1018300020F03E00801CE0702078052802D00F20A8 +:101840000CE049E1A07D20B1012802D0032802D09C +:1018500002E10720BFE584F80080EEE42070ECE4AC +:10186000102104F15C0002F034FA606BB0BBA07D83 +:1018700018B1012801D00520FDE006202870F748A6 +:101880006063A063BEE23878022894D1387908B149 +:101890002875B3E3A07D022802D0032805D022E0FA +:1018A000B8680028F5D060631CE06078012806D095 +:1018B000A07994F82E10012805D0E84806E0A17917 +:1018C00094F82E00F7E7B8680028E2D06063E0786B +:1018D000C00701D0012902D0E04803E003E0F86826 +:1018E0000028D6D0A063062010E68DF82090696A03 +:1018F0000D91E1784846C90709D06178022903D1E2 +:10190000A17D29B1012903D0A17D032900D00720A1 +:10191000287031E138780528BBD1207807281ED0FF +:1019200084F800A005208DF82000686A0D90B86842 +:101930000A90ADF824A08DF830B003210170E17851 +:10194000CA070FD0A27D022A1AD000210091D4E943 +:10195000061204F15C03401CFFF725FA67E384F8E4 +:101960000090DFE7D4E90923211D8DE80E0004F182 +:101970002C0304F15C02401C616BFFF722FB56E371 +:10198000626BC1F34401491E1268CA4002F00101B2 +:1019900041F08001DAE738780528BDD18DF82000C4 +:1019A000686A0D90B8680A90ADF824A08DF830B040 +:1019B000042100F8011B102204F15C0112F0F8FB75 +:1019C000002108A8FFF790FB2078092801D01320F8 +:1019D00044E70A2020709BE5E078C10742D0A17D52 +:1019E000012902D0022927D038E0617808A801290E +:1019F00016D004F16C010091D4E9061204F15C03E5 +:101A0000001DFFF7BBFA0A20287003268DF82080FE +:101A1000686A0D90002108A8FFF766FBDDE2C3E2CB +:101A200004F15C010091D4E9062104F16C03001D6E +:101A3000FFF7A4FA0026E9E7C0F3440114290DD208 +:101A40004FF0006101EBB0104FEAB060E0706078D9 +:101A5000012801D01020BEE40620FFE660780128AE +:101A60003FF4B7AC0A2051E5E178C90708D0A17D61 +:101A7000012903D10B20287004202FE028702DE0CD +:101A80000E2028706078616B012817D004F15C0388 +:101A900004F16C020EA8FFF7E1FA2046FFF748FBBD +:101AA000A0780EAEC0F11001304412F000FC062008 +:101AB0008DF82000686A09960D909AE004F16C0395 +:101AC00004F15C020EA8FFF7C9FAE9E739780229A8 +:101AD00003D139790029D1D029758FE28DF8200002 +:101AE000686A0D9058E538780728F6D1D4E90921BD +:101AF0006078012808D004F16C00CDE90002029161 +:101B000005D104F16C0304E004F15C00F5E704F195 +:101B10005C0304F14C007A680646216AFFF764F919 +:101B20006078012821D1A078216A0A18C0F110013B +:101B3000104612F0BCFBD4E90923606B04F12D01BF +:101B40008DE80F0004F15C0304F16C0231460EA82D +:101B500000E055E2FFF7CAF910220EA904F13C009B +:101B600012F0FAFA08B10B20AFE485F8008000BF4C +:101B70008DF82090686A0D908DF824A00CE53878D7 +:101B80000528AAD18DF82000686A0D90B8680A90DF +:101B9000ADF824A08DF830B080F80080617801297C +:101BA0001AD0D4E9093204F12D01A66B03920096F4 +:101BB000CDE9011304F16C0304F15C0204F14C0162 +:101BC000401CFFF793F9002108A8FFF78DFA607811 +:101BD000012805D0152041E6D4E90923611DE4E779 +:101BE0000E20287006208DF82000686ACDF824B0F9 +:101BF0000D90A0788DF82800CEE438780328C0D165 +:101C0000E079C00770D00F202870072066E7387889 +:101C100004286BD11422391D04F1140012F00DFBBD +:101C2000616A208CA1F80900616AA078C871E17925 +:101C3000626A01F003011172616A627A0A73616A71 +:101C4000A07A81F82400162060E485F800A08DF8C1 +:101C50002090696A50460D9190E00000A447020070 +:101C60003878052842D1B868A8616178606A02298D +:101C700001D0012100E0002101EB4101142606EB17 +:101C8000C1014058082102F024F86178606A0229F5 +:101C900001D0012100E0002101EB410106EBC1016F +:101CA000425802A8E169FFF70DFA6078626A0228DB +:101CB00001D0012000E0002000EB4001102000EBEB +:101CC000C1000223105802A90932FEF7F1FF626A2F +:101CD000FD4B0EA80932A169FFF7E3F96178606A4C +:101CE000022904D0012103E042E18BE0BDE00021A4 +:101CF00001EB4101182606EBC101A27840580EA95C +:101D000012F056FA6178606A022901D0012100E0E0 +:101D1000002101EB410106EBC1014058A1780844C4 +:101D2000C1F1100112F0C3FA05208DF82000686A95 +:101D30000D90A8690A90ADF824A08DF830B0062166 +:101D400001706278616A022A01D0012200E000225B +:101D500002EB420206EBC202401C8958102212F02C +:101D600027FA002108A8FFF7BFF91220C5F818B01C +:101D700028708DF82090686A0D900B208DF8240053 +:101D80000AE43878052870D18DF82000686A0D9033 +:101D9000B8680A900B20ADF824000A98072101705A +:101DA0006178626A022901D0012100E0002101EB83 +:101DB0004103102101EBC30151580988A0F801101B +:101DC0006178626A022902D0012101E02FE100213D +:101DD00001EB4103142101EBC30151580A6840F89B +:101DE000032F4968416059E01920287001208DF8BF +:101DF000300077E6162028708DF830B0002108A852 +:101E0000FFF772F9032617E114202870B0E638783E +:101E100005282AD18DF82000686A0D90B8680A90CC +:101E2000ADF824A08DF830B080F800906278616A37 +:101E30004E46022A01D0012200E0002202EB4202BB +:101E40001C2303EBC202401C8958102212F0B0F987 +:101E5000002108A8FFF748F9152028708DF82060A8 +:101E6000686A0D908DF824603CE680E0387805289B +:101E70007DD18DF82000686A0D90B8680A90ADF8A1 +:101E800024900921017061690978490841706169EC +:101E900051F8012FC0F802208988C18020781C28C1 +:101EA000A8D1A1E7E078C00702D04FF0060C01E00E +:101EB0004FF0070C607802280AD04FF0000000BFF6 +:101EC00000EB040101F1090105D04FF0010004E02D +:101ED0004FF00100F4E74FF000000B78204413EAC4 +:101EE0000C030B7010F8092F02EA0C02027004D1E7 +:101EF0004FF01B0C84F800C0D2B394F801C0BCF1C1 +:101F0000010F00D09BB990F800C0E0465FEACC7C9E +:101F100004D028F001060670102606E05FEA887CEF +:101F200005D528F00206067013262E70032694F8B5 +:101F300001C0BCF1020F00D092B991F800C05FEA75 +:101F4000CC7804D02CF001060E70172106E05FEA71 +:101F50008C7805D52CF002060E7019212170002610 +:101F60000078D0BBCAB3C3BB1C20207035E012E0A0 +:101F700002E03878062841D11A2019E42078012897 +:101F80003CD00C283AD02046FFF7F0F809208DF815 +:101F90002000686A0D9031E03878052805D00620C9 +:101FA000387003261820287046E005218DF820108F +:101FB000686A0D90B8680A900220ADF824000120EC +:101FC0008DF830000A980170297D4170394608A8C3 +:101FD000FFF78AF8064618202870012E0ED02BE055 +:101FE00001208DF82000686A0D9003208DF82400F0 +:101FF000287D8DF8250085F814B012E0287D80B189 +:102000001D202070172028708DF82090686A0D9090 +:1020100002208DF82400394608A8FFF765F8064627 +:102020000AE00CB1FE2020709DF8200020B10021B4 +:1020300008A8FFF759F810E413B03046BDE8F08F58 +:102040002DE9F04387B00C464E6900218DF804104D +:1020500001202578034602274FF007094FF0050CB1 +:1020600085B1012D53D0022D39D1FE2030708DF86D +:102070000030606A059003208DF80400207E8DF802 +:10208000050063E02179012925D002292DD00329FB +:1020900028D0042923D1B17D022920D131780D1F08 +:1020A000042D04D30A3D032D01D31D2917D1218905 +:1020B000022914D38DF80470237020899DF8041030 +:1020C00088421BD2082001E09C4702008DF80000E6 +:1020D000606A059057E070780128EBD0052007B0C2 +:1020E000BDE8F0831D203070E4E771780229F5D156 +:1020F00031780C29F3D18DF80490DDE7083402F82B +:1021000004CB94E80B0082E80B000320E7E7157886 +:10211000052DE4D18DF800C0656A05959568029596 +:102120008DF8101094F80480B8F1010F13D0B8F1B5 +:10213000020F2DD0B8F1030F1CD0B8F1040FCED18F +:10214000ADF804700E202870207E6870002168466B +:10215000FEF7CAFF0CE0ADF804700B202870207E5B +:10216000002100F01F0068706846FEF7BDFF377061 +:102170000020B4E7ADF804708DF8103085F800C089 +:10218000207E6870277011466846FEF7ADFFA6E70F +:10219000ADF804902B70207F6870607F00F0010024 +:1021A000A870A07F00F01F00E870E27F2A71C007CE +:1021B0001CD094F8200000F00700687194F821000A +:1021C00000F00700A87100216846FEF78DFF28681F +:1021D000F062A8883086A87986F83200A069407835 +:1021E00070752879B0700D203070C1E7A9716971E0 +:1021F000E9E700B587B004280CD101208DF8000074 +:102200008DF80400002005918DF805000146684610 +:10221000FEF76AFF07B000BD70B50C46054602F038 +:1022200031F821462846BDE870407823002201F0AD +:102230007FBF08B1007870470C20704770B50C0064 +:1022400005784FF000010CD021702146F3F701F81A +:1022500069482178405D884201D1032070BD022089 +:1022600070BDF2F7F6FF002070BD0279012A05D09B +:1022700000220A704B78012B02D003E00420704743 +:102280000A758A6102799300521C0271C1500320C1 +:102290007047F0B587B00F4605460124287905EB55 +:1022A000800050F8046C7078411E02290AD252490D +:1022B0003A46083901EB8000314650F8043C284684 +:1022C000984704460CB1012C11D12879401E10F01A +:1022D000FF00287101D00324E0E70A208DF80000F8 +:1022E000706A0590002101966846FFF7A7FF032C4E +:1022F000D4D007B02046F0BD70B515460A46044656 +:1023000029461046FFF7C5FF064674B12078FE281F +:102310000BD1207C30B100202870294604F10C003C +:10232000FFF7B7FF2046FEF721FF304670BD70472C +:1023300070B50E4604467C2111F0DBFF0225012E0C +:1023400003D0022E04D0052070BD0120607000E093 +:1023500065702046FEF70AFFA575002070BD28B104 +:10236000027C1AB10A4600F10C01C5E70120704752 +:1023700010B5044686B0042001F084FF2078FE28C2 +:1023800006D000208DF8000069462046FFF7E7FFE1 +:1023900006B010BD7CB50E4600218DF804104178C2 +:1023A000012903D0022903D0002405E0046900E0DC +:1023B00044690CB1217C89B16D4601462846FFF77E +:1023C00054FF032809D1324629462046FFF794FFDF +:1023D0009DF80410002900D004207CBD04F10C05F8 +:1023E000EBE730B40C460146034A204630BC034BB1 +:1023F0000C3AFEF756BE0000E04702009C47020080 +:1024000070B50D46040011D085B12101284611F0A8 +:102410004EFF10224E49284611F0CAFE4C480121B9 +:102420000838018044804560002070BD012070BDE7 +:1024300070B5474E00240546083E10E07068AA7B40 +:1024400000EB0410817B914208D1C17BEA7B914271 +:1024500004D10C22294611F07FFE30B1641C308873 +:102460008442EBDB4FF0FF3070BD204670BD70B58D +:102470000D46060006D02DB1FFF7DAFF002803DB7A +:10248000401C14E0102070BD314C083C208862884C +:10249000411C914201D9042070BD6168102201EBFA +:1024A0000010314611F084FE2088401C20802870E6 +:1024B000002070BD70B514460D0018D0BCB10021CD +:1024C000A170022802D0102811D105E0288870B12F +:1024D0000121A170108008E02846FFF7A9FF00281D +:1024E00005DB401CA070A8892080002070BD012061 +:1024F00070BD70B5054614460E000BD0002030703C +:10250000A878012808D005D91149A1F108010A8845 +:1025100090420AD9012070BD24B128782070288803 +:10252000000A5070022008700FE064B14968102260 +:1025300001EB00112046103911F03AFE2878207383 +:102540002888000A607310203070002070BD0000E1 +:102550007C0000202DE9F04190460C4607460025FE +:10256000FE48072F00EB881607D2DFE807F00707C1 +:10257000070704040400012500E0FFDF06F81470DB +:10258000002D13D0F548803000EB880191F827002A +:10259000202803D006EB4000447001E081F826407B +:1025A00006EB44022020507081F82740BDE8F081FE +:1025B000F0B51F4614460E460546202A00D1FFDF1F +:1025C000E649E648803100EB871C0CEB440001EB48 +:1025D0008702202E07D00CEB460140784B784870DC +:1025E000184620210AE092F82530407882F825002C +:1025F000F6E701460CEB410005704078A142F8D1A6 +:1026000092F82740202C03D00CEB4404637001E0C7 +:1026100082F826300CEB41042023637082F82710E7 +:10262000F0BD30B50D46CE4B44190022181A72EB9E +:10263000020100D2FFDFCB48854200DDFFDFC94841 +:102640004042854200DAFFDFC548401C844207DA79 +:10265000002C01DB204630BDC148401C201830BD95 +:10266000BF48C043FAE710B504460168407ABE4A45 +:1026700052F82020114450B10220084420F07F403D +:10268000F0F779FA94F90810BDE81040C9E7042082 +:10269000F3E72DE9F047B14E803696F82D50DFF87C +:1026A000BC9206EB850090F8264034E009EB8517D4 +:1026B0004FF0070817F81400012806D004282ED080 +:1026C00005282ED0062800D0FFDF01F0E3F80146F0 +:1026D00007EB4400427806EB850080F8262090F84E +:1026E0002720A24202D1202280F82720084601F0AC +:1026F000DCF82A4621460120FFF72CFF9B48414683 +:1027000000EB041002682046904796F82D5006EB27 +:10271000850090F82640202CC8D1BDE8F087022023 +:1027200000E003208046D0E710B58C4C2021803497 +:1027300084F8251084F8261084F82710002084F8E7 +:10274000280084F82D0084F82E10411EA16044F862 +:10275000100B2074607420736073A0738449E07759 +:1027600020750870487000217C4A103C02F8110066 +:10277000491CC9B22029F9D30120F0F7EAF800205A +:10278000F0F7E7F8012084F82200F9F7D1FA794848 +:10279000F9F7DDFA764CA41E20707748F9F7D7FADE +:1027A0006070BDE81040F0F761B810B5F0F783F83D +:1027B0006F4CA41E2078F9F7E3FA6078F9F7E0FA95 +:1027C000BDE8104001F09EB8202070472DE9F34F7E +:1027D000624E0025803606EB810A89B09AF8250002 +:1027E000202822D0691E02916049009501EB00105B +:1027F0008146D0E90112C0680391CDE90420B08B75 +:10280000ADF81C00B07F8DF81E009DF81500C8B112 +:102810000227554951F820400399E219114421F04B +:102820007F41019184B102210FE00120F0F791F87E +:102830000020F0F78EF8F0F75CF801F063F886F806 +:102840002F50A0E00427E4E700218DF8181002289B +:1028500001D0012820D10398391901440998081A98 +:102860009DF81C1020F07F4001B1022133318142DC +:102870000BD203208DF815000398C4F13201401AE1 +:1028800020F07F40322403900CE096F8240018B921 +:10289000F0F782FB00284CD0322C03D214B101F0A7 +:1028A00025F801E001F02EF8314A107818B393466C +:1028B0005278039B121B00219DF81840984601286E +:1028C0001AD0032818D000208DF81E00002A04DD3D +:1028D000981A039001208DF818009DF81C0000B193 +:1028E00002210398254A20F07F40039003AB09980A +:1028F00001F014F810B110E00120E5E79DF81D008B +:1029000018B99BF80000032812D08DF81C50CDF8A0 +:102910000C808DF818408DF81E509DF8180058B1A5 +:1029200003980123C11900221846F0F765F806E064 +:1029300000200BB0BDE8F08F0120F0F70AF899F9FC +:102940000C20012300200199F0F756F8012086F8A9 +:102950002F008AF828502022694611E098080020AC +:10296000FF7F841E0020A107F04702009806002088 +:102970008E000020DF3F010093260100FFFF3F0093 +:10298000F94811F05AFC0120D3E72DE9F05FDFF898 +:10299000D883064608EB860090F82550202D1FD0DE +:1029A000A8F180002C4600EB8617A0F50079DFF82F +:1029B000BCB305E0A24607EB4A004478202C0AD0BD +:1029C000F0F766F809EB04135A4601211B1D00F0CD +:1029D000A5FF0028EED0AC4202D0334652461EE09E +:1029E000E34808B1AFF30080F0F752F898F82F20D1 +:1029F0006AB1D8F80C20411C891A0902CA1701EBE8 +:102A000012610912002902DD0020BDE8F09F314665 +:102A1000FFF7DCFE08B10120F7E733462A46202104 +:102A20000420FFF7C5FDEFE72DE9F041CE4C256905 +:102A3000F0F72EF8401B0002C11700EB11600012E6 +:102A400000D4FFDF94F8220000B1FFDF012784F8F3 +:102A5000227094F82E00202800D1FFDF94F82E6019 +:102A6000202084F82E00002584F82F5084F8205070 +:102A700084F82150BF4825600078022833D003280D +:102A800031D000202077A068401C05D04FF0FF30E7 +:102A9000A0600120EFF75DFF0020EFF75AFFF0F78D +:102AA00058F8F0F750F8EFF724FF10F0D7FDB248D0 +:102AB000056005604FF0E0214FF40040B846C1F8D2 +:102AC0008002F0F7E0F894F82D703846FFF75DFFCC +:102AD0000028FAD0A448803800EB871010F81600C0 +:102AE000022802D006E00120CCE73A463146062013 +:102AF000FFF730FD84F8238004EB870090F8260070 +:102B0000202804D09B48801E4078F9F73FF9207FA9 +:102B1000002803D0F0F70DF82577657746E50146E4 +:102B2000914810B590F82D200024803800EB8210D9 +:102B300010F814302BB1641CE4B2202CF8D3202000 +:102B400010BD8E4800EB0410016021460120FFF704 +:102B500001FD204610BD10B5012801D0032800D189 +:102B600071B3814A92F82D307F4C0022803C04EBF7 +:102B7000831300BF13F812400CB1082010BD521C83 +:102B8000D2B2202AF6D37B4A48B1022807D00729BF +:102B900016D2DFE801F01506080A0C0E100000211D +:102BA0000AE01B2108E03A2106E0582104E07721E1 +:102BB00002E0962100E0B52151701070002010BD98 +:102BC000072010BD6B4810B54078EFF7D4FF80B2F6 +:102BD00010BD10B5202811D2634991F82D30A1F114 +:102BE000800202EB831414F810303BB191F82D30C1 +:102BF00002EB831212F81020012A01D0002010BD30 +:102C000091F82D2001460020FFF7A4FC012010BD03 +:102C100010B5EFF73DFFBDE81040EFF7ACBF2DE971 +:102C2000F0410E46504F01782025803F0C4607EBBF +:102C3000831303E0254603EB45046478944202D0F5 +:102C4000202CF7D108E0202C06D0A14206D103EBBE +:102C500041014978017007E00020A7E403EB44003C +:102C600003EB450140784870454F7EB127B1002104 +:102C700040F2DA30AFF300803078A04206D127B1BD +:102C8000002140F2DD30AFF30080357027B1002124 +:102C900040F2E230AFF30080012087E410B54268D3 +:102CA0000B689A1A1202D41702EB1462121216D48D +:102CB000497A91B1427A82B9324A006852F82110B9 +:102CC000126819441044001D891C081A0002C1171B +:102CD00000EB11600012322801DB012010BD002042 +:102CE00010BD2DE9F04781461F48244E00EB8100BE +:102CF000984690F825402020107006F50070154683 +:102D000000EB81170BE000BF06EB04104946001DE5 +:102D1000FFF7C4FF28B107EB44002C704478202C47 +:102D2000F2D1297888F8001013E000BF06EB0415F3 +:102D3000291D4846FFF7B2FF68B988F80040A97B13 +:102D400099F80A00814201D80020E6E407EB44002C +:102D50004478202CEAD10120DFE42DE9FC410E4625 +:102D600007460024054D18E018090020FFFF3F002A +:102D7000000000008E00002000F5004098060020B2 +:102D800000000000F04702009DF8000005EB001075 +:102D90008168384600F0D6FD01246B4601AA314611 +:102DA0003846FFF79EFF0028EED02046BDE8FC81A4 +:102DB00070B50446FF480125A54300EB841100EBE4 +:102DC0008510402211F0F4F9FB4E26B1002140F2AB +:102DD0005C40AFF30080F748803000EB850100EBEA +:102DE0008400D0F82500C1F8250026B100214FF459 +:102DF0008C60AFF30080284670BD2DE9FC4184460D +:102E0000EC481546089C00EB85170E4617F8140091 +:102E1000012803D0022801D00020C7E70B46E74A6B +:102E20000121604600F07AFDA8B101AB6A4629464F +:102E30003046FFF756FF70B1DE489DF804209DF83C +:102E40000010803000EB85068A4208D02B46052012 +:102E5000FFF7AEFB0BE02A462146042014E02029B0 +:102E600003D007EB4100407801E096F8250007EB1E +:102E7000440148709DF80000202809D007EB40006D +:102E800044702A4621460320FFF764FB01208DE7AA +:102E900006F8254F0120F070F3E7C94901EB001057 +:102EA000001DFFF7E0BB7CB51D46134604460E46E9 +:102EB00000F1080221461846EFF76AFE94F908006F +:102EC0000F2804DD1F3820722068401C206096B156 +:102ED0000220BC4951F82610461820686946801B1C +:102EE00020F07F40206094F908002844C01C1F286F +:102EF00003DA012009E00420EBE701AAEFF748FE1E +:102F00009DF8040010B10098401C009000992068C2 +:102F100031440844C01C20F07F4060607CBD2DE936 +:102F2000FE430C46064609786079907220799846EF +:102F30001546507241B19F48803090F82E102029DC +:102F40000AD00069401D0BE0D4E90223217903B0C7 +:102F50002846BDE8F043A6E79B484178701D084429 +:102F600020F07F47217900222846A368FFF79BFFC6 +:102F70003946284600F0E6FCD4E902322179684659 +:102F8000FFF791FF41462846019CFFF7E6FE2B46DE +:102F900022460021304600F0C1FC002803D1314612 +:102FA000284600F0CFFCBDE8FE832DE9FE4F8146A8 +:102FB00000F084FC30B1002799F8000020B1002017 +:102FC000BDE8FE8F0127F7E77A4D7B4C4FF0000AF2 +:102FD000803524B1002140F2D340AFF3008095F852 +:102FE0002D8085F823A0002624B100214FF49B609A +:102FF000AFF300801FB94046FFF7DAFE804624B1E8 +:1030000000214FF49C60AFF30080EFF741FD434691 +:103010006A464946FFF783FF24B1002140F2E640AB +:10302000AFF3008095F82E0020280CD02969009875 +:10303000401A0002C21700EB1260001203D5684666 +:1030400000F080FC012624B100214FF49E60AFF314 +:10305000008095F823000028BBD124B1002140F264 +:10306000F640AFF30080EFF713FD6B46534A0021A3 +:1030700000F054FC0028A3D027B941466846FFF76A +:103080006CFE064326B16846FFF7EDFAC9F8080062 +:1030900024B1002140F20950AFF3008001208FE7F6 +:1030A0002DE9FF5F8A46814600F008FC414C8034E0 +:1030B00010B39AF80000002710B1012800D0FFDFFC +:1030C0003D4D25B1002140F27F50AFF3008001203B +:1030D000A84600905FEA080604D0002140F287501D +:1030E000AFF30080009800F0E0FB94F82D50002032 +:1030F00084F8230067B119E094F82E0001272028F6 +:1031000000D1FFDF9AF800000028D9D0FFDFD7E711 +:103110002846FFF74DFE054626B1002140F29150AA +:10312000AFF3008094F823000028D3D126B100210A +:1031300040F29B50AFF30080EFF7AAFC83462B468A +:1031400001AA5146FFF7EBFE5FEA060804D0002112 +:1031500040F2A250AFF300803B462A4601A95846F0 +:10316000CDF80090FFF749FE064604EB850090F885 +:1031700028B0B8F1000F04D0002140F2A950AFF3FD +:10318000008000F087FB0090B8F1000F04D0002110 +:1031900040F2AF50AFF3008094F82300002899D19B +:1031A000B8F1000F04D0002140F2B750AFF3008017 +:1031B00003490BE09808002000000000FFFF3F00DB +:1031C00098060020F04702008E00002001EB091055 +:1031D0000DF1040C00F104009CE80E0080E80E00E4 +:1031E0004EB35FEA080604D0002140F2C450AFF3AA +:1031F00000803BEA070012D094F82E0020280ED160 +:1032000026B1002140F2C950AFF300802846FFF7F5 +:10321000BCFB20B99AF80000D8B3012849D0B8F116 +:10322000000F04D0002140F2E650AFF300802846A2 +:1032300000F029FB01265FEA080504D0002140F2D6 +:10324000EF50AFF30080009800F02FFB25B1002174 +:1032500040F2F350AFF300808EB194F82D0004EBF0 +:10326000800090F82600202809D025B1002140F2E6 +:10327000FA50AFF30080F9484078F8F787FD25B1A0 +:10328000002140F2FF50AFF3008004B03046BDE8AB +:10329000F09FFFE7B8F1000F04D0002140F2D150B9 +:1032A000AFF3008094F82D2049460420FFF752F92F +:1032B000C0E7002E3FF40EAF002140F2DC50AFF328 +:1032C000008007E72DE9F84FE54D814695F82D0080 +:1032D0004FF00008E34C4FF0010B474624B10021AA +:1032E00040F20D60AFF30080584600F0DEFA85F83A +:1032F000237024B1002140F21260AFF3008095F8F2 +:103300002D00FFF755FD064695F8230028B1002C47 +:10331000E4D000214FF4C3604BE024B1002140F21F +:103320001C60AFF30080CE48803800EB861111F8A6 +:103330001900032856D1334605EB830A4A469AF80A +:103340002500904201D1012000E0002000900AF108 +:1033500025000021FFF763FC01460098014203D0DD +:1033600001228AF82820AF77E1B324B1002140F28E +:103370002160AFF30080324649460120FFF7EAF8AA +:103380009AF828A024B1002140F22C60AFF300800D +:1033900000F080FA834624B1002140F23160AFF39F +:1033A000008095F8230038B1002C97D0002140F21E +:1033B0003560AFF3008091E7BAF1000F07D095F8C0 +:1033C0002E00202803D13046FFF7DFFAE0B124B108 +:1033D000002140F24960AFF30080304600F053FA1C +:1033E0004FF0010824B1002140F25260AFF3008099 +:1033F000584600F05AFA24B1002140F25660AFF36B +:1034000000804046BDE8F88F002CF1D0002140F24A +:103410004460AFF30080E6E70020EFF773BA0120C5 +:10342000EFF770BA8D48007870472DE9F0418C4C69 +:1034300094F82E0020281FD194F82D6004EB860705 +:1034400097F82550202D00D1FFDF8549803901EB09 +:10345000861000EB4500407807F8250F0120F87032 +:1034600084F82300294684F82E5032460220223464 +:10347000FFF770F8002020700FE42DE9F0417A4E3C +:10348000774C012538B1012821D0022879D00328B2 +:103490007DD0FFDFF0E700F029FAFFF7C6FF207EBE +:1034A00000B1FFDF84F821500020EFF752FAA16845 +:1034B000481C04D0012300221846EFF79DFA14F8A7 +:1034C0002E0F217806EB01110A68012154E0FFF765 +:1034D000ACFF0120EFF73DFA94F8210050B1A0684D +:1034E000401C07D014F82E0F217806EB01110A6852 +:1034F000062141E0207EDFF86481002708F1020800 +:10350000012803D002281ED0FFDFB5E7A777EFF729 +:1035100010FB98F80000032801D165772577607DBE +:10352000524951F8200094F8201051B948B161680F +:103530000123091A00221846EFF75EFA02202076CE +:103540009AE7277698E784F8205000F0CFF9A07F1B +:1035500050B198F8010061680123091A0022184649 +:10356000EFF74AFA257600E0277614F82E0F217837 +:1035700006EB01110A680021BDE8F041104700E0A8 +:1035800005E036480078BDE8F041F8F7FFBBFFF7EB +:103590004CFF14F82E0F217806EB01110A68052163 +:1035A000EAE710B52E4C94F82E00202800D1FFDF5A +:1035B00014F82E0F21782C4A02EB01110A68BDE89D +:1035C0001040042110477CB5254C054694F82E0088 +:1035D000202800D1FFDFA068401C00D0FFDF94F856 +:1035E0002E00214901AA01EB0010694690F90C0058 +:1035F0002844EFF7CDFA9DF904000F2801DD0120E2 +:1036000000E00020009908446168084420F07F41F0 +:10361000A16094F82100002807D002B00123BDE882 +:10362000704000221846EFF7E7B97CBD30B5104A6C +:103630000B1A541CB3EB940F1ED3451AB5EB940F21 +:103640001AD3934203D9101A43185B1C14E0954215 +:1036500010D9511A0844401C43420DE08C00002050 +:10366000180900200000000098060020F047020022 +:10367000FF7F841EFFDF0023184630BD0123002298 +:1036800001460220EFF7B8B90220EFF762B9EFF771 +:10369000FFB92DE9FC47B14C054694F82E002028CF +:1036A00000D1FFDF642D58D3AD4A0021521B71EBCE +:1036B000010052D394F82E20A0462046DFF8A492B1 +:1036C00090F82D7009EB0214D8F8000001AA2844E4 +:1036D0006946EFF75DFA9DF90400002802DD0098C5 +:1036E000401C0090A068009962684618B21A22F047 +:1036F0007F42B2F5800F30D208EB8702444692F841 +:103700002520202A0AD009EB02125268101A000262 +:10371000C21700EB1260001288421EDBA068401C3A +:1037200010D0EFF7B5F9A168081A0002C11700EB35 +:1037300011600012022810DD0120EFF70AF94FF0A6 +:10374000FF30A06020682844206026F07F40206180 +:10375000012084F82300BDE8FC870020FBE72DE969 +:10376000F0477E4C074694F82D00A4F1800606EB46 +:10377000801010F8170000B9FFDF94F82D50A04614 +:10378000794C24B1002140F66500AFF3008040F68B +:10379000710940F67A0A06EB851600BF16F8170085 +:1037A000012818D0042810D005280ED006280CD0E7 +:1037B0001CB100214846AFF3008020BF002CEDD0A3 +:1037C00000215046AFF30080E8E72A463946012041 +:1037D000FEF7C0FEF2E74FF0010A4FF00009454640 +:1037E00024B1002140F68100AFF30080504600F084 +:1037F0005CF885F8239024B1002140F68600AFF3F1 +:10380000008095F82D00FFF7D3FA064695F82300BF +:1038100028B1002CE4D0002140F68C001FE024B138 +:1038200000214FF40960AFF3008005EB860000F142 +:10383000270133463A462630FFF7F1F924B100213B +:1038400040F69400AFF3008000F024F8824695F82B +:10385000230038B1002CC3D0002140F69A00AFF30A +:103860000080BDE785F82D60012085F823005046D3 +:1038700000F01BF8002C04D0002140F6A700AFF3A5 +:103880000080BDE8F087354981F82D00012081F8DE +:103890002300704710B5354808B1AFF30080EFF34F +:1038A000108000F0010072B610BD10B5002804D1E0 +:1038B0002F4808B1AFF3008062B610BD2D480068F4 +:1038C000C005C00D10D0103840B2002806DA00F054 +:1038D0000F0000F1E02090F8140D03E000F1E0206B +:1038E00090F80004400970470820704710B51B4C41 +:1038F00094F82400002804D1F8F72AF8012084F86D +:10390000240010BD10B5154C94F82400002804D0F4 +:10391000F8F747F8002084F8240010BD10B51C68A3 +:103920005B68241A181A24F07F4420F07F40A142DB +:1039300006D8B4F5800F03D2904201D8012010BD03 +:10394000002010BDD0E90032D21A21F07F4311448B +:1039500021F07F41C0E900317047000018090020C4 +:10396000FF1FA107980600200000000000000000D3 +:103970000000000004ED00E02DE9F041044680075E +:103980004FF000054FF001060CD560480560066059 +:103990000FF0C6FC20B15E48016841F4806101600F +:1039A00024F00204E0044FF0FF3705D55948466083 +:1039B000C0F8087324F48054600003D556480560AD +:1039C00024F08044E0050FD55448C0F80052C0F8F8 +:1039D000087353490D60091D0D60514A04210C32D2 +:1039E0001160066124F48074A00409D54D48466036 +:1039F000C0F80052C0F808734B48056024F4005426 +:103A0000C4F38030C4F3C031884200D0FFDF14F427 +:103A1000404F14D045484660C0F80873444886605B +:103A2000C0F80052C0F8087342490D600A1D1660C4 +:103A30008660C0F808730D60166024F440442005C9 +:103A40000AD53D4846608660C0F80873C0F84873E0 +:103A50003A48056024F400640FF0DAFD3848044267 +:103A600000D0FFDFBDE8F08170B5202500221346AD +:103A700020FA02F1C90719D051B201F01F06012442 +:103A8000B4404E09B60006F1E026C6F88041C6F8FB +:103A90008042002906DA01F00F0101F1E02181F8EE +:103AA000143D03E001F1E02181F80034521CAA42E8 +:103AB000DED370BD70B5234C0D462060FFF75CFF70 +:103AC0002068FFF7D1FF2846F8F71FF80FF0FAF942 +:103AD00000F0AFF80FF09CFD0FF0E7FCF8F728F9C5 +:103AE000BDE870400FF09CBA10B5164C2068FFF787 +:103AF00043FF2068FFF7B8FF0FF08AFDF8F794F84E +:103B00000020206010BD0A2070470000FC1F00400C +:103B10003C17004000C0004004E501400080004028 +:103B20000485004000D0004004D5004000E0004083 +:103B300000F0004000F5004000B0004008B5004033 +:103B4000FEFF0FFD9000002070B526490A680AB3F9 +:103B50000022154601244B685B1C4B60092B00D3E7 +:103B60004D600E7904FA06F30E681E420FD0EFF393 +:103B7000108212F0010272B600D001220C689C4340 +:103B80000C6002B962B649680160002070BD521C29 +:103B9000092AE0D3052070BD4FF0E0214FF48000EA +:103BA000C1F800027047EFF3108111F0010F72B6F7 +:103BB0004FF0010202FA00F20A48036842EA0302E7 +:103BC000026000D162B6E7E706480021016041606B +:103BD00070470121814003480068084000D001205F +:103BE00070470000940000202DE9F04115460E4674 +:103BF0000446002700F0E7F8A84215D3002341202F +:103C00000FE000BF94F84220A25CF25494F84210F6 +:103C1000491CB1FBF0F200FB12115B1C84F842104E +:103C2000DBB2AB42EED3012700F0D9F83846BDE84D +:103C3000F081704910B5802081F800046E490020A1 +:103C400081F8420081F84100433181F8420081F857 +:103C50004100433181F8420081F8410067480FF08C +:103C60006DFB6648401C0FF069FBEFF71BF8BDE8E1 +:103C7000104000F0B4B8402070475F4800F0A3B88F +:103C80000A4601465C48AFE7402070475A48433037 +:103C900000F099B80A46014657484330A4E740214E +:103CA00001700020704710B504465348863000F07C +:103CB0008AF82070002010BD0A4601464E4810B513 +:103CC0008630FFF791FF08B1002010BD42F20700D7 +:103CD00010BD70B50C460546412900D9FFDF4848A4 +:103CE0000068103840B200F050F8C6B20D2000F065 +:103CF0004CF8C0B2864203D2FFDF01E0EFF722F8B2 +:103D0000224629463C48FFF76FFF0028F6D070BDD9 +:103D10002DE9F041394F002506463F1D57F8254053 +:103D2000204600F041F810B36D1CEDB2032DF5D321 +:103D30003148433000F038F8002825D02E4800F0F4 +:103D400033F8002820D02C48863000F02DF80028C9 +:103D50001AD0EEF7CDFF29480FF0F8FAB0F5005F62 +:103D600000D0FFDFBDE8F04124480FF005BB94F818 +:103D700041004121265414F8410F401CB0FBF1F2E0 +:103D800001FB12002070D3E751E7002806DA00F0AB +:103D90000F0000F1E02090F8140D03E000F1E020A6 +:103DA00090F800044009704710F8411F4122491C57 +:103DB000B1FBF2F302FB13114078814201D10120E3 +:103DC00070470020704710F8411F4078814201D3AE +:103DD000081A02E0C0F141000844C0B2704710B5B3 +:103DE00006480FF0B3FA002803D1BDE81040EEF703 +:103DF0006ABF10BD0DE000E0480900209C000020D3 +:103E000004ED00E070B5154D2878401CC4B2687808 +:103E1000844202D0EFF727F82C7070BD2DE9F041F5 +:103E20000E4C4FF0E02600BFEFF712F820BF40BF66 +:103E300020BF677820786070D6F80052EDF76EFAF0 +:103E4000854305D1D6F8040210B92078B842EBD0EA +:103E5000EEF7F9FF0020BDE8F0810000AC00002083 +:103E60002DE9F041012528034FF0E0210026C1F89B +:103E700080011E4CC4F800610C2000F02CF81C4896 +:103E800001680268C94341F3001142F01002026068 +:103E9000C4F804532560491C00E020BFD4F8002179 +:103EA000002AFAD019B9016821F010010160114807 +:103EB00007686560C4F80853C4F800610C2000F07E +:103EC0000AF83846BDE8F08110B50446FFF7C8FF90 +:103ED0002060002010BD00F01F0201219140400928 +:103EE000800000F1E020C0F88012704700C0004060 +:103EF00010ED00E008C500402DE9F047FF4C0646F4 +:103F0000FF21A06800EB061211702178FF2910D064 +:103F10004FF0080909EB011109EB06174158C05988 +:103F200000F0F4F9002807DDA168207801EB061104 +:103F300008702670BDE8F08794F8008045460DE0D3 +:103F4000A06809EB05114158C05900F0DFF90028BD +:103F500006DCA068A84600EB08100578FF2DEFD11D +:103F6000A06800EB061100EB08100D700670E1E789 +:103F7000F0B5E24B0446002001259A680C269B7898 +:103F80000CE000BF05EB0017D75DA74204D106EB9C +:103F90000017D7598F4204D0401CC0B28342F1D8D9 +:103FA000FF20F0BD70B5FFF772FBD44C08252278D6 +:103FB000A16805EB0212895800F0A8F9012808DD74 +:103FC0002178A06805EB01114058BDE87040FFF76B +:103FD00055BBFFF727FABDE87040F7F7D7BE2DE9CC +:103FE000F041C64C2578FFF752FBFF2D6ED04FF005 +:103FF0000808A26808EB0516915900F087F9022815 +:10400000A06801DD80595DE000EB051109782170A1 +:10401000022101EB0511425C5AB1521E42548159F2 +:1040200001F5800121F07F4181512846FFF764FFAF +:1040300034E00423012203EB051302EB051250F8D0 +:1040400003C0875CBCF1000F10D0BCF5007F10D915 +:10405000CCF3080250F806C00CEB423C2CF07F4C2D +:1040600040F806C0C3589A1A520A09E0FF21815449 +:104070000AE0825902EB4C3222F07F428251002248 +:1040800042542846FFF738FF0C21A06801EB0511C8 +:104090004158E06850F82720384690472078FF289C +:1040A00014D0FFF7F4FA2278A16808EB0212454613 +:1040B000895800F02BF9012893DD2178A06805EBE1 +:1040C00001114058BDE8F041FFF7D8BABDE8F081D2 +:1040D000F0B51D4614460E460746FF2B00D3FFDF02 +:1040E000A00700D0FFDF8548FF210022C0E902477A +:1040F000C57006710170427082701046012204E0A2 +:1041000002EB0013401CE154C0B2A842F8D3F0BD4A +:1041100070B57A4C064665782079854200D3FFDF7A +:10412000E06840F825606078401C6070284670BDEB +:104130002DE9FF5F1D468B460746FF24FFF7A7FAD0 +:10414000DFF8B891064699F80100B84200D8FFDFC1 +:1041500000214FF001084FF00C0A99F80220D9F81D +:1041600008000EE008EB0113C35CFF2B0ED0BB422E +:1041700005D10AEB011350F803C0DC450CD0491CF3 +:10418000C9B28A42EED8FF2C02D00DE00C46F6E709 +:1041900099F803108A4203D1FF2004B0BDE8F09FD4 +:1041A0001446521C89F8022008EB04110AEB041291 +:1041B000475440F802B00421029B0022012B01EB7E +:1041C00004110CD040F801204FF4007808234FF080 +:1041D000020C454513D9E905C90D02D002E045504E +:1041E000F2E7414606EB413203EB041322F07F4233 +:1041F000C250691A0CEB0412490A81540BE005B94C +:10420000012506EB453103EB041321F07F41C1503A +:104210000CEB0411425499F800502046FFF76CFE55 +:1042200099F80000A84201D0FFF7BCFE3846B4E779 +:1042300070B50C460546FFF72AFA06462146284681 +:10424000FFF796FE0446FF281AD02C4D082101EBFB +:104250000411A8684158304600F058F800F5805025 +:10426000C11700EBD14040130221AA6801EB0411F1 +:10427000515C09B100EB4120002800DC012070BD39 +:10428000002070BD2DE9F04788468146FFF770FE9B +:104290000746FF281BD0194D2E78A86831463446B2 +:1042A00005E0BC4206D0264600EB06121478FF2C2F +:1042B000F7D10CE0FF2C0AD0A6420CD100EB011084 +:1042C00000782870FF2804D0FFF76CFE03E0002080 +:1042D00030E6FFF7D9F941464846FFF7A9FF012329 +:1042E000A968024603EB0413FF20C854A878401EB7 +:1042F000B84200D1A87001EB041001E0140A0020BC +:1043000001EB061100780870104613E6081A000247 +:10431000C11700EB116000127047000070B5044631 +:10432000A0F500002D4EB0F1786F02D23444A4F510 +:1043300000042B48844201D2012500E0002500F052 +:1043400043F848B125B9B44204D32648006808E0D0 +:10435000012070BD002070BD002DF9D1B442F9D309 +:1043600021488442F6D2F3E710B50446A0F50000D8 +:10437000B0F1786F03D219480444A4F5000400F0AA +:1043800023F84FF0804130B11648006804E08C42B9 +:1043900004D2012003E014488442F8D2002080F0C7 +:1043A000010010BD10B520B1FFF7DEFF08B10120FC +:1043B00010BD002010BD10B520B1FFF7AFFF08B150 +:1043C000012010BD002010BD08480949006888423E +:1043D00001D101207047002070470000000000203C +:1043E000006002002000002008000020B000002033 +:1043F000BEBAFECA0548064A0168914201D10021B1 +:10440000016004490120086070470000B0000020EE +:10441000BEBAFECA40E50140534800210170417018 +:1044200010218170704770B5054616460C46022073 +:10443000EEF7D7F94C49012008704C49F01E08608E +:104440004B480560001F046070BD10B50220EEF7F8 +:10445000C8F945490120087046480021C0F80011FC +:10446000C0F80411C0F8081143494FF40000086077 +:1044700010BD3D480178C9B1404A4FF400011160B8 +:104480003C49D1F800310022002B1CBFD1F8043187 +:10449000002B02D0D1F8081111B14270102103E0B5 +:1044A0000121417036490968817002700020EEF7E1 +:1044B00098B92D480178002904BF407870472D48ED +:1044C000D0F80011002904BF02207047D0F8001175 +:1044D00000291CBFD0F80411002905D0D0F808012C +:1044E000002804BF01207047002070471E4800B517 +:1044F0000278204B4078C821491EC9B282B1D3F856 +:1045000000C1BCF1000F10D0D3F8000100281CBF7F +:10451000D3F8040100280BD0D3F8080150B107E00C +:10452000022802D0012805D002E00029E4D1FFDFF3 +:10453000002000BD012000BD0B480178002904BF08 +:10454000807870470B48D0F8001100291CBFD0F8C4 +:104550000411002902D0D0F8080108B110207047DA +:1045600007480068C0B27047B400002010F5004052 +:1045700008F5004000F0004004F5014008F5014056 +:1045800000F400404C48002101704170704770B544 +:10459000064614460D460120EEF723F9474806600B +:1045A000001D0460001D056070BD70B54249012505 +:1045B0000D7040EA0241424A41F080711160414C65 +:1045C0000026C4F80461404A4FF040711160002891 +:1045D00002BFC4F80052256070BD012818BFFFDF7C +:1045E000C4F8006225604FF000703849086070BD63 +:1045F0003148017879B1344A4FF040711160314946 +:10460000D1F804210021002A08BF417002D0304AAD +:104610001268427001700020EEF7E3B82648017876 +:10462000002904BF407870472648D0F804010028CC +:1046300008BF704726480068C0B27047002808BF0E +:10464000704730B51C480078002808BFFFDF1D48C0 +:10465000D0F80411002918BF30BD0224C0F804436B +:10466000DFF870C0DCF80010C1F30015DCF80010B2 +:1046700041F01001CCF80010D0F80411002904BF5B +:104680004FF400414FF0E02207D100BFC2F8801282 +:1046900020BFD0F80431002BF8D02DB9DCF8001081 +:1046A00021F01001CCF80010C0F8084330BD0549D6 +:1046B0000120886070470000B700002008F5004026 +:1046C00004F5004000F0004008F5014004F5014009 +:1046D00000F4004010ED00E010B5FF480024012177 +:1046E0004470047044728472C17280F82140846204 +:1046F000446314300FF004FFF849601E0860091D80 +:104700000860091D0C60091D0860091D0C60091D69 +:104710000860091D0860091D0860091D0860091D61 +:104720000860091D0860091D0860091D0860091D51 +:10473000086010BDEA48016801F00F01032904BFB9 +:1047400001207047006800F00F00042804BF022019 +:10475000704700B5FFDF012000BD30B4DE490268BC +:10476000DFF884C34A6142688A61007A08770A7D6B +:10477000DC4BACF1040401204AB10A7E00FA02F2DB +:104780001A608D7D002D0CBF2260CCF800204A7D80 +:10479000002A04BF30BC70474A7E90401860C97D33 +:1047A00000290CBF2060CCF8000030BC704730B549 +:1047B00000250446012904D002290CBF4FF0807562 +:1047C000FFDF45F4847040F48010C849086044F469 +:1047D0004030091D40F00070086030BD30B5002544 +:1047E0000446012904D002290CBF4FF08075FFDF79 +:1047F00045F4847040F48010BC49086044F44030B3 +:10480000091D40F000700860B948D0F80001002888 +:1048100018BFFFDF30BD2DE9F04102264FF0E02741 +:1048200001240025C7F88061B248056004600EF0DD +:1048300077FDB14918B1086840F4806008600868E5 +:1048400020F0770040F0880040F0004008600EF053 +:1048500051FD30B1A948016821F47F4141F4B051C4 +:1048600001600EF047FD9C4940B1A5484E770660B7 +:10487000A54AA4481060121FA4481060A44A40F240 +:104880005B601060121F40F203101060101F046084 +:10489000934A032010609F4A96201060487F0028AA +:1048A00014BF4FF4C0209C4840F440209B4A106045 +:1048B0009C4A9B481060121F9B481060C7F880629A +:1048C0008B4A1020C2F8040381F82D50BDE8F08116 +:1048D0009648016821F0010141F080710160704744 +:1048E0007D4A0368C2F802308088D0801172704718 +:1048F000794B10B51A7A8A4208D101460622981CD3 +:104900000FF02AFC002804BF012010BD002010BDBC +:10491000714890F8210070476F4A517010707047CD +:10492000F0B50546800000F1804000F580508B888E +:10493000C0F820360B78D1F8011043EA0121C0F805 +:10494000001605F10800012707FA00F6784C002A46 +:1049500004BF2068B04304D0012A18BFFFDF2068DD +:1049600030432060206807FA05F108432060F0BD5D +:104970000EF096BF584890F82E007047564890F8B1 +:10498000300070476B4AC178116000686A490002C4 +:1049900008607047252808BF02210ED0262808BFCE +:1049A0001A210AD0272808BF502106D00A2894BF10 +:1049B0000422062202EB4001C9B2604A116060493C +:1049C00008607047F0B4444B9D7A012D61D0022DF0 +:1049D0001CBFF0BC704793F815C0BCF1000F04BFBA +:1049E000F0BC70474FF47A7C012D564C564F57D08F +:1049F000DE7D5D7E002E18BF0126012908BF29211A +:104A00000CD0022A0CBF514C012A03D0042A0CBF3F +:104A10003C464F4C04F2E141B1FBFCF1491F084414 +:104A20004C4908604C490020C1F84C01280286F02E +:104A3000010140EA015040F00311187F820002F1A9 +:104A4000804202F5C042C2F81015444901EB8002D1 +:104A5000997EC80000F1804000F5F830C0F81425B8 +:104A6000DFF8FCC0C0F810C5D87EC30003F1804356 +:104A700003F5F833C3F814252B4AC3F81025012297 +:104A800002FA01F102FA00F0084336490860F0BC6E +:104A9000704793F814C0BCF1000FA3D1F0BC70476D +:104AA0009E7D1D7E002E18BF0126012965D0022A99 +:104AB00004BF2D4C4FF47A710CD0012A08BF4FF47B +:104AC000C86107D0042A07BF3C4640F69801274C2E +:104AD00040F6E44121444BE0240A0020000E00404F +:104AE00010150040180500500C050050141500402A +:104AF00000100040FC1F00403C17004040170040E1 +:104B000060150040448000409CF5014028110040A1 +:104B100038150040441500400000040408F5014029 +:104B200040800040A4F5014010110040741700407F +:104B300040160040241500401C1500400815004098 +:104B400054150040A2240200D0FB010004360200EC +:104B5000C0D401004C85004000800040006000404F +:104B60004C81004004F501406836020030D301005A +:104B700001F5FA71B1FBFCF150E7022A08BF4FF4CE +:104B80007A710AD0012A08BF4FF4C86105D0042AFF +:104B90000CBF40F6980140F6E44149F6FC6211442E +:104BA000E8E72DE9F047FC4E80460320154689468C +:104BB000C6F80002F94F787F002814BF4FF4C020D8 +:104BC000F748F849086048460EF0A5FE28460EF062 +:104BD00095FE0124B8F1000F03D0B8F1010F16D0F3 +:104BE00018E00EF087FB78B1EF490A684806022DFD +:104BF000D0F820030CBFC0F30660C0F3062022F4F7 +:104C0000FE4242EA00200860BC72346002E00220EA +:104C1000B8727460E548C464E54800682A464946AD +:104C2000BDE8F047CEE62DE9F0418846DA4907466F +:104C300003201546C1F80002D84C607F002814BF3D +:104C40004FF4C020D648D74E306040460EF063FE89 +:104C500028460EF053FE17B1012F1CD024E00EF0B1 +:104C600049FB78B1D04A11685006022DD0F82003D4 +:104C70000CBFC0F30660C0F3062021F4FE4141EAF8 +:104C8000002010600120A072606B40F4801060630F +:104C90004FF4801007E00220A072606B40F4001017 +:104CA00060634FF4001030602A464146BDE8F04191 +:104CB000002087E62DE9FF4FB74C8346002581B0E1 +:104CC00003208946C4F80002B44E707F002814BF48 +:104CD0004FF4C020B248B34F386003980EF01BFE6B +:104CE00004980EF00BFEDFF8CCA24FF00108BBF1E8 +:104CF000000F03D0BBF1010F35D046E00EF0FAFAF9 +:104D000080B1A94A0498116853060228D3F82003F9 +:104D10000CBFC0F30660C0F3062021F4FE4141EA57 +:104D200000201060CAF8004096F82D00012806D037 +:104D3000022818BFFFDF0CD086F80A8025E0DDE9E5 +:104D4000031396F82C2048460EF066FEB16A45180B +:104D5000F2E7DDE9031296F82C3048460EF0EAFD42 +:104D6000B16A4518E8E79448CAF8000096F82D00A3 +:104D7000DDE90313012896F82C20484624D00EF0D4 +:104D800095FEB16A45180220B0728C4805608D49C5 +:104D90008B480860706B40F400207063D4F8009278 +:104DA0004FF0100AC4F808A30026C4F80062864831 +:104DB0004FF4802BC0F800B0FF208DF80000C4F83D +:104DC0001061C4F810800AE00EF0F2FDB16A4518D7 +:104DD000D9E700BF9DF80000401E8DF800009DF847 +:104DE000000018B1D4F810010028F3D09DF800009D +:104DF000002808BFFFDFC4F80061C4F80C61C4F8E4 +:104E00001061C4F80461C4F81461C4F818610EF0AC +:104E100071FA002818BFC4F828616C480068009037 +:104E2000C4F80092C7F800B0C4F804A34FF40020FF +:104E300038605E48C0F84C805D480068A84228BFD2 +:104E4000FFDF2846DDE9031205B0BDE8F04FB9E504 +:104E50002DE9F84F504CD4F8000220F00B09D4F89B +:104E600004034FF0100AC0F30018C4F808A300268A +:104E7000C4F80062494D687F002814BF4FF4C02079 +:104E8000474840F4402150480160A97A0127012990 +:104E900002D0022903D014E0297D11B911E0697D07 +:104EA00079B1A97EEA7E07FA01F107FA02F211430D +:104EB0000160287F800000F1804000F5C040C0F80C +:104EC0001065FF208DF80000C4F81061276104E030 +:104ED0009DF80000401E8DF800009DF8000018B1FC +:104EE000D4F810010028F3D09DF80000002808BF76 +:104EF000FFDFC4F810610EF0FDF9002818BFC4F8F8 +:104F000028616E72AE72EF72C4F80092B8F1000FB1 +:104F100018BFC4F804A3BDE8F88F00682C4920F03E +:104F20007F40086070474FF0E0200221C0F88011F8 +:104F3000C0F8801270474FF0E0210220C1F8000154 +:104F4000704724490870704723490860704730B59E +:104F5000124C0546A06AA84228BFFFDF012020733B +:104F60002561607F40B1284420610B48D0F80012D1 +:104F700041F04001C0F800120C490020C1F8440182 +:104F8000164920690860606B064940F48000606340 +:104F90004FF48000086030BD00100040240A00205B +:104FA0000000040404F50140881500400080004022 +:104FB0004C850040ACF5014004100040488500409D +:104FC00048810040A8F5014008F501401811004053 +:104FD0003C150040B9000020041500404485004005 +:104FE00070B505460E460220FE4C2073FE4801684F +:104FF00001F00F01032908BF012207D0006800F06B +:105000000F0004280EBF0222FFDF012294F82D00BA +:1050100094F82C10012819D028460EF0A5FD206127 +:10502000607F48B1216908442061F048D0F800123F +:1050300041F04001C0F80012ED490020C1F84401E0 +:105040002169A06A0844EB49086070BD33462846D0 +:105050000EF053FDE3E7E8494FF480000860E148B3 +:10506000416B21F480014163002101737047C2004C +:1050700002F1804202F5F832E04BC2F81035C2F876 +:10508000141501218140DE480160D648426B11436E +:1050900041637047D64801214160C1600021C0F8DA +:1050A0004411D4480160CF488162704710B504466E +:1050B0000EF020F900281CBFCA484477D14804608C +:1050C000CA48D0F8001241F04001C0F8001210BDEB +:1050D000C64810B5D0F8001221F04001C0F8001207 +:1050E0000EF008F9C749002818BF0220086010BD5B +:1050F000BE48D0F8001221F01001C0F800120121C2 +:1051000081617047B9480021C0F81C11D0F8001225 +:1051100041F01001C0F800127047B44981B0D1F8D5 +:105120001C21012A1EBF002001B07047B64A126838 +:1051300002F07F02524202700020C1F81C01B34805 +:1051400000680090012001B0704730B50C000546A2 +:1051500008BFFFDF14F0010F1CBF012CFFDF002D83 +:105160000CBF012002209F4901284872CC729F4940 +:1051700004BFD1F8000240F0040007D0022807BFA6 +:10518000D1F8000240F00800FFDF30BDC1F8000296 +:1051900030BD2DE9F84FDFF8789299F80000042827 +:1051A00028BFFFDFDFF848A2DAF84C1192488D4C97 +:1051B00000274FF00108D1B1A17A012902D00229BC +:1051C00003D014E0217D11B911E0617D79B1A17E98 +:1051D000E27E08FA01F108FA02F211430160217F30 +:1051E000890001F1804101F5C041C1F81075824884 +:1051F000616B01606763217B002019B1DAF844110B +:10520000012900D00021A27A784E012A6ED0022A0C +:1052100074D000BFD6F8101101290CBF1021002155 +:1052200041EA00057B48016811F0FF0F03D0D6F872 +:105230001411012900D0002184F82E10006810F00C +:10524000FF0F03D0D6F81801012800D0002084F801 +:105250002F007148006884F83000FFF72AF9012810 +:1052600018BF002084F83100C6F80071C6F80C7130 +:10527000C6F81071C6F80471C6F81471C6F8187132 +:105280000EF038F8002818BFC6F828716348006887 +:1052900000905748C0F8447161480068DFF854A195 +:1052A0000090DAF800006062617F00291CBF401A9C +:1052B00060625C480068A0624B48016801F00F0121 +:1052C000032908BF012007D0006800F00F00042860 +:1052D0000EBF0220FFDF012084F82C00A07ADFF847 +:1052E00048B184F82D00022824D116E0D6F80C012C +:1052F000012814BF002008208CE7FFE7D6F80C0136 +:10530000012814BF00200220484A1268012A14BF55 +:1053100004220022104308437CE7607850B1DBF898 +:10532000001009780840217831EA000008BF84F8AD +:10533000208001D084F8207015F0020F07D099F872 +:1053400000103B4A4908606A52F82110884715F05E +:10535000010F18BF00210DD0364A99F80030A06A1D +:1053600052F82320904700BF99F8000010F0010F79 +:105370002AD10AE015F0020F18BF0121ECD115F077 +:10538000080F18BF0221E7D1EEE7DBF80000007834 +:1053900000F00F00072828BF84F8217014D2DBF832 +:1053A0000000062200F10901A01C0EF0D5FE40B954 +:1053B000207ADBF800100978B0EBD11F08BF01207C +:1053C00000D0002084F82100E17A002011F0020FC3 +:1053D0001CBF15F0020F15F0040F45D111F0100F8E +:1053E0002AE00000240A00201015004000100040B0 +:1053F000008000404485004008F501400411004051 +:1054000004F5014060150040481500401C110040A3 +:10541000B900002040160040101400401811004050 +:1054200044810040408500400415004000140040C5 +:1054300008480200504802001CBF94F82F20002AA0 +:1054400002D094F831207AB111F0080F1CBF94F803 +:105450002020002A08D111F0040F02D094F8211066 +:1054600011B115F0010F00D00120617A19B198B186 +:10547000FFF7EEFC1EE0607F002814BF4FF4C02150 +:105480007F4980480160D6F8000220F00300C6F88A +:10549000000284F80B800DE04FF0000B012913D0BF +:1054A000022918BFFFDF21D0A06A01225844002141 +:1054B000FFF788FA15F0010F2BD0734899F8001008 +:1054C00050F82100804745E0D6F8000220F00400A3 +:1054D000C6F80002677284F80B80012384F80A8002 +:1054E0001A46002196200EF025FA10E0D6F80002A8 +:1054F00020F00800C6F80002677284F80B800220D2 +:10550000A07201231A46002196200EF051FA83461C +:10551000CAE715F0020F08D05C4999F8002028EA84 +:10552000950051F82210884714E015F0080F06D0B6 +:10553000574899F8001050F8210080470AE015F00C +:10554000100F08BFFFDF05D0524899F8001050F83F +:1055500021008047A07A022818BFBDE8F88F207B81 +:10556000002808BFBDE8F88F4B49C1F844710228F4 +:1055700014D0012818BFFFDFA16A2069884298BFB4 +:10558000FFDF2069CAF80000606B444940F48000E6 +:1055900060634FF480000860BDE8F88F2169A06A5D +:1055A0000844EFE738B500253D4C002818BFC4F883 +:1055B0000052C4F80051C4F80C51C4F81051C4F89A +:1055C0000451C4F81451C4F818510DF093FE00288A +:1055D00018BFC4F8285133480068009038BD01282E +:1055E00004BF28207047022804BF1820704700B568 +:1055F000FFDF282000BD012804BF41F6A4707047DA +:10560000022804BF41F28830704700B5FFDF41F641 +:10561000A47000BD012804BF41F2D4707047022875 +:1056200004BF41F20400704700B5FFDF41F2D470BF +:1056300000BD012812BF02280020704700B5FFDF1F +:10564000002000BD16490820C1F800021648407F1E +:10565000002814BF4FF4C02009480A4908601449C3 +:1056600012480860091D13480860091D12480860A7 +:10567000091D1248086009494FF44020086070472E +:105680000000040408F50140104802002048020010 +:1056900030480200404802000080004004F501400C +:1056A0000010004018110040240A002000110040A2 +:1056B000A0F50140141000401C11004010100040E3 +:1056C00010B53F4822210EF0F2FD3D48017821F04F +:1056D00010010170012107F017FC3A49002081F800 +:1056E00022004FF6FF70888437490880488010BD3B +:1056F000704734498A8C824218BF7047002081F875 +:1057000022004FF6FF70888470472D490160704772 +:105710002D49088070472B498A8CA2F57F43FF3BB7 +:1057200003D0002101600846704791F822202549E6 +:10573000012A1ABF0160012000207047214901F1B0 +:10574000220091F82220012A04BF00207047012284 +:1057500002701D4800888884104670471A494880A6 +:1057600070471849184B8A8C5B889A4206D191F889 +:105770002220002A1EBF01600120704700207047D0 +:105780001048114A818C5288914209D14FF6FF711D +:10579000818410F8221F19B1002101700120704787 +:1057A000002070470748084A818C5288914205D1F1 +:1057B00090F8220000281CBF00207047012070478D +:1057C000820A00205C0A0020BA0000207047574A75 +:1057D000012340B1012818BF70471370086890601A +:1057E00088889081704753700868C2F802008888E2 +:1057F000D08070474D4A10B1012807D00EE0507894 +:1058000060B1D2F802000860D08804E0107828B1B6 +:105810009068086090898880012070470020704758 +:10582000424910B1012803D006E0487810B903E0DE +:10583000087808B1012070470020704730B58DB05E +:105840000C4605460D2104A80EF053FDE0788DF8B6 +:105850001F0020798DF81E0060798DF81D002868E2 +:10586000009068680190A8680290E8680390684614 +:105870000DF0C2FB20789DF82F1088420CD1607883 +:105880009DF82E10884207D1A0789DF82D108842EF +:1058900002BF01200DB030BD00200DB030BD30B5CD +:1058A0000C4605468DB04FF0030104F1030012B120 +:1058B000FEF7F0F901E0FEF70CFA60790D2120F017 +:1058C000C00040F04000607104A80EF012FDE078C6 +:1058D0008DF81F0020798DF81E0060798DF81D006D +:1058E0002868009068680190A8680290E8680390B2 +:1058F00068460DF081FB9DF82F0020709DF82E006A +:1059000060709DF82D00A0700DB030BD10B500295D +:1059100004464FF0060102D0FEF7BCF901E0FEF7A5 +:10592000D8F9607920F0C000607110BDBE00002081 +:1059300070B5F84E0446306890F800110025012932 +:1059400019D090F8FA10012924D090F8D01001292C +:105950002AD090F8F21001291CBF002070BD65709C +:1059600017212170D0F8F4106160B0F8F81021818F +:1059700080F8F25016E065701C212170D0F80111FA +:105980006160D0F80511A16090F80911217380F8C9 +:10599000005107E0657007212170D0F8FC106160AC +:1059A00080F8FA50012070BD65701421217000F15B +:1059B000D2012022201D0EF0FBFB01212172306854 +:1059C00080F8D050D448B0F8D420A0F8FC207268F9 +:1059D000537B80F8FE3080F8FA101088FBF71AF934 +:1059E000FAF7C1FDDEE7CB48006890F8D010002937 +:1059F00014BFB0F8D4004FF6FF70704770B5C54CB7 +:105A00002068002808BFFFDF0025206845700028B7 +:105A100008BFFFDF2068417800291CBFFFDF70BD91 +:105A20004FF486710EF065FC2068FF2101707F2124 +:105A300080F8361013214184282180F8CC100121F0 +:105A400080F8B81080F8BD50FFF742FBFEF711FD5B +:105A5000B24806F0E5FFB24806F0E2FFBDE870404C +:105A6000B04806F0DDBFAB490968097881420CBF38 +:105A7000012000207047A748006890F82200C0F37A +:105A8000001070472DE9F04FA248016891F82400FA +:105A9000B1F822C0C0F38002C0F340031A4400F002 +:105AA00001001044CCF300121AB3BCF1130F1BD049 +:105AB0000BDCBCF1100F02BF9B4931F81000BDE8B0 +:105AC000F08FBCF1120F0FD00AE0BCF1150F08BF28 +:105AD00096490AD0BCF11D0F04BF9548BDE8F08F70 +:105AE000FFDF0020BDE8F08F924931F81000BDE8DB +:105AF000F08F002491F8BA2091F8BB108E4E8F4F92 +:105B00001CF0030F4FF47A7B4FF0190A25464FF42F +:105B1000C8784FF4BF794FF018037DD01CF0010F07 +:105B20001BD0082904BF44464FF0400C0FD0042975 +:105B300004BF4C464FF0100C09D0022907BF05F1F5 +:105B400018044FF0040C05F128044FF0080C0CEB7E +:105B50004C0E0EEB0C1CA44417E0082904BFC446ED +:105B600040240CD0042904BFCC46102407D00229BD +:105B700007BF05F1180C042405F1280C082404EBD8 +:105B8000C40404EB44040CEB440C022A04BF6C4E26 +:105B90004FF47A740CD0012A08BF4FF4C86407D0C0 +:105BA000042A07BF674E40F698043E4640F6E44498 +:105BB000344404F2E734B4FBFBF4C0EB001606EB0C +:105BC000860604EB8604082A30D0042A29D0022A4B +:105BD00007BF05F11802042505F128024FF0190A44 +:105BE00018BF08251AFB052212FB0040082922D005 +:105BF000042925D0022904BF0421C03004D0282361 +:105C000003F5A87108440821C1EBC10101EB410172 +:105C100003EB4101084400E017E0604400F52674FE +:105C200018E04A464FF0140A1025DBE742464FF0D1 +:105C3000140A4025D6E74346402100F53D60E3E7DE +:105C40004B46102100F57C70DEE71CF0020F18BFF8 +:105C5000FFDF02D02046BDE8F08F022A04BF384E95 +:105C60004FF47A7C0CD0012A08BF4FF4C86C07D0DF +:105C7000042A07BF334E40F6980C3E4640F6E44CEB +:105C8000B4440CF2E73CBCFBFBFCC0EB001404EB9F +:105C900084040CEB840C082A04BF4FF0140A402241 +:105CA0000CD0042A29D0022A07BF05F118080422C3 +:105CB00005F128084FF0190A18BF08221AFB0282C2 +:105CC00012FB00C0082904BF4FF4A87340210AD07A +:105CD000042904BF4FF4A873102104D002290EBF79 +:105CE000042128230821C1EBC10101EB410103EB91 +:105CF0004101084400F5B274ACE7C8464FF0140AFD +:105D00001022DBE7034840F271210068806A4843B3 +:105D100070470000CC000020A40A0020B00B002037 +:105D2000D80B0020000C0020744802007C480200C0 +:105D3000F18913006C480200A224020030D3010054 +:105D400068360200D0FB0100F848006890F8350082 +:105D5000002818BF0120704710B5F54C207B0228A1 +:105D600018BF032808D1207D04F1150105F018FDA6 +:105D700008281CBF012010BD207B002816BF022868 +:105D800000200120BDE81040FFF74ABDE74909683F +:105D900081F8300070472DE9F047E44D2968087B11 +:105DA000002816BF02280020012048730E31FFF79B +:105DB00021FD2968087B022816BF03280122002242 +:105DC00081F82F20082081F82D00487B012600272C +:105DD00001F10E03012804BF5B7913F0C00F0AD054 +:105DE00001F10E03012804D1587900F0C0004028C9 +:105DF00001D0002000E0012081F82E00002A04BF1D +:105E000091F8220010F0040F06D0087D153105F03E +:105E1000C7FC296881F82D0028684760FCF7F8FE68 +:105E20002968C34C4FF00009886094F82D0005F0F4 +:105E3000D3FC804694F82F00002818BFB8F1000F5B +:105E400004D01021404606F050FB68B194F83000B1 +:105E500000281CBF94F82E0000281DD0607B04F1A0 +:105E60000E0101280ED012E066734A4604F10E01BD +:105E70004046FFF714FD94F82D1004F10E0005F0D4 +:105E8000A4FD09E0487900F0C000402831D039462F +:105E900004F10E00FFF73AFD2868C77690F822005B +:105EA00010F0040F08BFBDE8F087002794F82D001C +:105EB00005F09BFC040008BFBDE8F087102106F048 +:105EC00014FB002818BFBDE8F08728683A4600F1A7 +:105ED0001C01C6762046FFF7E2FC286800F11C0191 +:105EE000944806F0D4FDBDE8F0470121914806F042 +:105EF000E9BD05F0A3FD4A4604F10E01FFF7CFFC12 +:105F0000CAE778B58A490446884D407B08732968FA +:105F1000207808706088ADF8000080B200F00102BF +:105F2000C0F3400342EA4302C0F3800342EA830223 +:105F3000C0F3C00342EAC302C0F3001342EA0312F3 +:105F4000C0F3401342EA4312C0F3801042EA8010CB +:105F50004884E07D012808BF012603D0022814BF31 +:105F6000FFDF0226286880F8BA60607E012808BF3B +:105F7000012603D0022814BFFFDF0226286880F81C +:105F8000BB60217B80F82410418C1D290CBF0021AF +:105F900061688162617D80F83510A17B002916BFA0 +:105FA0000229002101210175D4F80F10C0F8151045 +:105FB000B4F81310A0F81910A17EB0F8CE2061F348 +:105FC0000302A0F8CE20E17E012918BF002180F84D +:105FD0003410002078BD55480068408CC0F3001193 +:105FE00019B110F0040F05D002E010F0020F01D03B +:105FF00000207047012070474C4A00231268C2F805 +:10600000C030B2F822C0BCF11D0F02BFC2F8C830C8 +:1060100082F8C4307047002908BFC2F8C8300AD0DF +:10602000936A40F2712C03FB0CF31944491EB1FB37 +:10603000F3F1C2F8C81082F8C400704703463B4829 +:1060400010B50168D1F8C820002A1ABFD1F8C0C025 +:10605000BCF1000F012405D09A4205D90124D01AC1 +:10606000C1F8C800204610BD91F82210002411F09C +:10607000010F1CBF406800884FF0430108BF00209B +:1060800001F009F9EEE72948006890F8B700002808 +:106090000CBF01200020704770B51F2834BF044694 +:1060A0001F240022214D286880F8B920224678302C +:1060B0000EF07EF82868012180F8974080F8B9102A +:1060C00070BD10B51F2828BF1F20C2B2174C002377 +:1060D000206880F8B83080F8B72098300EF068F863 +:1060E0002168012081F8B80010BD1049096881F8C5 +:1060F000BD0070470D48006890F8220000F00100D4 +:1061000070470A48006890F82200C0F340007047CA +:106110000648006890F82200C0F34010704703481A +:10612000006890F82200C0F3C0007047CC00002047 +:10613000A40A0020B00B002001207047F748006837 +:1061400090F8BB00704770B5FEF7A4FFFEF783FF21 +:10615000FEF77EFEFEF7E7FEF04C2068D0F8C01098 +:10616000491CC0F8C01090F83300002530B1FEF78C +:10617000AFFFFEF77EF9206880F833502068457045 +:1061800090F8C410F9B1D0F8C02091421BD8042077 +:1061900002F050FA206890F8220010F0010F0CD0A5 +:1061A00060684321008801F076F860680088FAF79B +:1061B00031FDBDE87040FAF7C7B9BDE87040432132 +:1061C000002001F068B8D0F8C81019B1D0F8C0208C +:1061D000914202D990F83700D8B1042002F02AFA8F +:1061E000206890F8220010F0010F0CD060683C216C +:1061F000008801F050F860680088FAF70BFDBDE8F0 +:106200007040FAF7A1B9BDE870403C21002001F0D0 +:1062100042B8BDE87040002002F00CBA2DE9F84FFA +:10622000BE4E8046174630688B464FF0000A458CBC +:1062300015F0030F10D015F0010F05F0020005D086 +:10624000002808BF4FF0010A06D004E0002818BF5C +:106250004FF0020A00D1FFDF4FF000094C4615F065 +:10626000010F05F002000BD070B915F0040F0BD030 +:1062700049F00800002F18BF40F0030440D090E020 +:1062800010B115F0040F0DD015F0070F10D015F058 +:10629000010F05F0020036D0002808BF15F0040FEA +:1062A00027D03DE0002F18BF49F0090479D134E030 +:1062B0002FB149F0080415F0200F14D071E03168B7 +:1062C00005F0200291F87700104308BF49F001045F +:1062D00067D049F0180415F0200F62D191F8BA1078 +:1062E00008295AD156E0316891F8BA10082951D1DD +:1062F00053E049F00800002F18BF40F0010450D1CE +:1063000040F010044DE0002818BF15F0040F07D02E +:10631000002F18BF49F00B0443D149F0180440E0A6 +:1063200015F0030F3CD115F0040F39D077B1316867 +:1063300049F0080091F8BA1008290CBF40F0020497 +:1063400020F0020415F0200F22D02AE0316805F079 +:10635000200291F87700104308BF49F0030420D0D1 +:1063600049F0180015F0200F09D000BF91F8BA10BD +:10637000082914BF40F0020420F0020411E091F853 +:10638000BA20082A14BF40F0010020F00100EDE718 +:10639000082902D024F0010403E044F0010400E0E5 +:1063A000FFDF15F0400F18BFFFDFA8F8009098F846 +:1063B0000000072120F0200088F80000404606F089 +:1063C00034FB5146404606F033FD2146404606F078 +:1063D00038FD14F0010F0CD03068062300F10E01D7 +:1063E0000022404606F00AFD3068417B404606F038 +:1063F0005CFB14F0020F1BD03068BBF1000F0BD018 +:1064000000F11C0106230122404606F0F7FC0121A1 +:10641000404606F057FB0BE000F115010623012270 +:10642000404606F0EBFC3068017D404606F04AFB32 +:1064300014F0040F18BFFFDF14F0080F17D0CDF8C9 +:1064400000903068BDF800100223B0F8CE000209B9 +:1064500062F30B01ADF800109DF80110032260F308 +:1064600007118DF801106946404606F0C7FC012F60 +:1064700016D1306890F8770090B1404606F0D4FC11 +:106480003368401CC0B293F87710C0F125008142F8 +:10649000B8BF084682B203F15801404606F0FFFC3F +:1064A0000020002818BFFFDF0020002818BFFFDFF2 +:1064B0000020002818BFFFDFBDE8F88F2DE9F84362 +:1064C000164C2068002808BFFFDF2068417811BB08 +:1064D0000178FF291FD0002780F83170877080F87D +:1064E00037703846FEF72DFDFEF795F9206890F9D4 +:1064F000BD00FEF73DFA0A48FEF744FA0948FEF7E8 +:106500000CFD206890F8240010F0010F0CD025201D +:10651000FEF740FA10E00C20BDE8F883CC00002024 +:10652000684802006548020010F0020F18BF2620DC +:1065300068D000BFFEF72EFA206890F8BA10252028 +:10654000FEF735F9206880F82C70FEF7F4FC20681F +:10655000002190F8BA200846FEF765FB0F210520C0 +:10656000FEF7DAF92068FF4D012690F82E10002979 +:1065700001BF90F82F10002990F8220010F0040FAE +:1065800070D0FCF745FB8046206841468068FDF7E7 +:106590004DF8F54990FBF1F901FB190041424046E5 +:1065A000FCF73FF80146206881604168494441603A +:1065B00005F0F3F801462068426891426DD8C0E9C1 +:1065C00001784FF0010895F82D0005F005F9814696 +:1065D00095F82F00002818BFB9F1000F04D0102142 +:1065E000484605F082FFA0B195F8300000281CBF96 +:1065F00095F82E00002824D0687B05F10E010128B3 +:1066000015D019E010F0040F14BF2720FFDF91D13F +:1066100092E732466E7305F10E014846FFF73FF9E7 +:1066200095F82D1005F10E0005F0CFF909E0487935 +:1066300000F0C000402816D0414605F10E00FFF7DB +:1066400065F9206890F8220010F0040F25D095F825 +:106650002D0005F0CAF85FEA00081ED0102105F0F1 +:1066600044FF40B119E005F0E9F9324605F10E01A9 +:10667000FFF715F9E5E72068324600F11C01C67600 +:106680004046FFF70CF9206800F11C01B74806F0FE +:10669000FEF90121B54806F015FA2068417B0E305D +:1066A000FEF71EF9206890F8B81079B390F8B7207B +:1066B00080F8772000F1980158300DF0BEFD206879 +:1066C00090F82210C1F30011E9B9B0F8CE00022110 +:1066D0000609ADF800606846FDF7DCFA28B1BDF8A0 +:1066E0000000C0F30B00B04204D1BDF80000401C14 +:1066F000ADF800002168BDF80000B1F8CE2060F3CD +:106700000F12A1F8CE20206880F8B870206890F8A9 +:10671000B91059B190F8972080F8572000F178010E +:1067200038300DF08AFD206880F8B9702068B0F824 +:10673000CE10D0F8C020090951FA82F190F8BC209F +:10674000DFF82CC2114463460022E1FB0C3212092F +:106750006FF0240302FB031180F8BC1090F82210A4 +:10676000824E90F81B80C1F3001106F12809002920 +:106770005DD03780317821F020013170408C1328B2 +:1067800037D01CDC10284DD0122846D0FFDF00BFC8 +:1067900005F10E01754806F06CF9697B734806F047 +:1067A00084F92068418C1D2918BF15297ED090F8E6 +:1067B000772000F15801304606F0ADF97EE015284B +:1067C00018BF1D28E2D10121304606F02EF930789D +:1067D000B8F1000F40F020003070206812D000F1B6 +:1067E0001C01304606F053F90121304606F06AF9E3 +:1067F000CEE70021304606F018F9307840F020004E +:106800003070C5E700F11501304606F040F9206808 +:10681000017D304606F056F9BAE70621304606F00B +:1068200004F9B5E70221304606F0FFF8B0E7002290 +:1068300041463046FFF7F2FC206890F877100029B7 +:1068400004BF408C10F0010F05D110F0020F08BFFB +:1068500010F0200F04D0012241464846FFF7DEFC2D +:10686000F07810F03F0F1CBF307910F0100F25D0DA +:10687000304606F0D8F82268014692F82400C0F3AA +:106880008003C0F3400C634400F00100034492F81D +:106890002C00C0F38002C0F3400C624400F0010001 +:1068A0001044181AC0B200F00AFD00E006E00090A3 +:1068B000032304226946304606F0A0FA206890F8C7 +:1068C0002200C0F30010B0B12A4E042130463780B8 +:1068D00006F0ABF805F10E01304606F0CAF8697B08 +:1068E000304606F0E2F8206800F1380190F85720B1 +:1068F000304606F034F904F0C5FF03211E4805F0C8 +:1069000054F8216881F83300002005E61B494860EF +:1069100070472DE9F843194C8046206890F83120E3 +:1069200032B1408C1D2808BFFFDFBDE8F8430AE400 +:10693000012639B390F8BC00FEF72CF8206890F8D7 +:10694000BB102520FDF733FF206801224FF496711C +:1069500090F8BB300020FEF7ADF90948FEF7F4FAD5 +:10696000206810E0A40A002040420F00B00B002075 +:1069700053E4B36E000C0020280C0020CC00002053 +:10698000D80B002005E04670867080F83160BDE8C5 +:10699000F883FE48FEF7D8FA2068002590F8241006 +:1069A00090F82C0021EA000212F0010F18BF012517 +:1069B0000ED111F0020F04D010F0020F08BF022513 +:1069C00006D011F0040F03D010F0040F08BF042507 +:1069D0000027B8F1000F5CD0012D1CD0022D08BF9C +:1069E00026201CD0042D14BFFFDF272017D02068DD +:1069F00090F8BA102520FDF7DAFE206890F82210F2 +:106A0000C1F3001171B1002201234FF496711046B9 +:106A1000FEF750F93DE02520FDF7BCFFE7E7FDF765 +:106A2000B9FFE4E790F8BA3001224FF496710020E4 +:106A3000FEF740F9D548C17811F03F0F1CBF00792F +:106A400010F0100F25D0D14805F0EDFF2368014666 +:106A500093F82420C2F38000C2F3400C604402F09B +:106A6000010200EB020C93F82C20C2F38000C2F369 +:106A70004003184402F001020244ACEB0200C0B231 +:106A800000F01DFC0090032304226946BF4806F075 +:106A9000B5F9206890F82C10294380F82C1090F854 +:106AA000242032EA010112D04670408C132821D0F4 +:106AB0001CDC102808BFBDE8F88312281AD000BFDC +:106AC000C0F30010002818BFFFDFBDE8F883418C39 +:106AD0001D2908BF80F82C70E6D0C1F300110029F1 +:106AE00014BF80F8316080F83170DDE7152818BFD9 +:106AF0001D28E5D1BDE8F84301210846FEF725BB76 +:106B0000A34810B50068417841B90078FF2805D046 +:106B100000210846FFF7FDFE002010BDFEF7BAFA7F +:106B2000FEF799FAFEF794F9FEF7FDF90C2010BD77 +:106B300097490120096881F837007047944909682E +:106B400081F83200704770B5002501F0E3FB0028A2 +:106B50007CD08F4C2068417800260122012905D085 +:106B6000022901D003297DD0FFDF70BD8178022684 +:106B700039B390F8220010F0030F67D08548FEF774 +:106B8000E3F920680122962190F8BB301046FEF709 +:106B900091F800219620FEF723FA2068467090F8BD +:106BA000330020B1FDF751FC4020FEF77FFA20684A +:106BB00090F83400002808BF70BDBDE87040FEF7B3 +:106BC000A1BA418CC1F300129AB1102929D090F8D2 +:106BD000330020B1FDF739FC4020FEF767FA6D481D +:106BE000FEF7B2F9206890F8221011F0040F1DD0C2 +:106BF00027E090F8242090F82C309A4211D190F898 +:106C00007700002808BF11F0010F05D111F0020F25 +:106C100008BF11F0200F52D0BDE870400121084696 +:106C200077E6BDE870400021012072E690F835005B +:106C3000012814BF0328102545F00E010020FEF79F +:106C400084FA206890F83400002801E037E009E079 +:106C500018BFFEF757FA00219620FEF7C1F9206809 +:106C6000467070BD817801B3418C11F0010F21D0C5 +:106C700080F8D02090F8D210B0F8D40000F00BFBD0 +:106C800060680088F9F7C6FFF9F75EFC2068467077 +:106C9000FEF700FAFEF7DFF9FEF7DAF8FEF743F940 +:106CA000BDE87040032001F0C5BC8178BDE87040AC +:106CB00001202EE611F0020F04BFFFDF70BDBDE81A +:106CC0007040FFF740BAFFF73EBA10B5304C20686D +:106CD00090F8341049B13630FEF71FFA18B9216820 +:106CE0007F2081F83600FEF703FA206890F8330021 +:106CF00018B1FEF7EDF9FDF7BCFB01F00BFBA8B1F5 +:106D0000206890F82210C1F3001179B14078022870 +:106D100018BFFFDF00210120FFF7FBFD206841784D +:106D200000291EBF40780128FFDF10BDBDE81040DC +:106D3000FFF709BA2DE9F047154F0E4603283A68C8 +:106D4000518C0BD092F8320001F0010410F10009CF +:106D500018BF4FF001094FF0010805E0C1F34004EE +:106D60004FF000094FF00208FDF704FE054634EA33 +:106D7000090008BFBDE8F0873868064C90F833007A +:106D800098B104F064FD3070014605E0B00B0020BE +:106D9000CC000020280C0020FF2806D0E01C04F0C6 +:106DA0004BFD307804F05EFD05432078C0F3801180 +:106DB0003868027D914209D100F115010622E01CDC +:106DC0000DF0CAF9002808BF012000D0002031785A +:106DD000FF2906D0C0B9386890F82D00884215D137 +:106DE00012E098B12078E11CC0F3801004F0D8FCC8 +:106DF000064604F03BFE38B1304604F0F6FC18B10C +:106E0000102105F072FB08B1012000E00020396874 +:106E100091F8221011F0040F01D0F0B11AE0CDB9B1 +:106E2000FE4890F83500002818BF404515D114F8E9 +:106E3000030B2146C0F3801004F0B2FC044604F0BA +:106E400015FE38B1204604F0D0FC18B1102105F031 +:106E50004CFB10B10120BDE8F0870020BDE8F087B1 +:106E60002DE9F04FEE4D804683B02868002740782A +:106E7000022818BFFFDF28687F2490F8341049B13A +:106E80003630FEF74AF9002804BF286880F83640FB +:106E9000FEF72EF9E34805F0E8FD0646B8F1000FCD +:106EA00000F0A381DF4805F079FF002800F09D8104 +:106EB000FDF72EFD002800F098813046D94EFF21C5 +:106EC000DFF864A34FF000084FF0030B4FF0010907 +:106ED000062880F0B981DFE800F0FDFDFD03FD8F9D +:106EE0008DF8001069460320FFF724FF002828686A +:106EF0007CD090F8341011B190F8001159B1286885 +:106F0000807801283ED0C948FEF71EF8286880F82E +:106F100001B000F06EB99DF8003080F80091017862 +:106F200080F80111FF2B10D000F20312511E1846F9 +:106F300004F064FC002808BFFFDF286890F8021105 +:106F400041F0020180F802110DE03178C1F38011A7 +:106F500080F80211B149D1F88721C0F80321B1F8B6 +:106F60008B11A0F80711286800F2091690F8360076 +:106F70007F2808BFFFDF286890F83610317080F84E +:106F80003640BCE7A94CDAF8049004F12806A4F8CE +:106F900000800721204605F048FD0021204605F02D +:106FA00047FF4946204605F04CFF0623002206F124 +:106FB0000901204605F022FF2868417B204605F0A4 +:106FC00074FD286800F1380190F85720204605F03C +:106FD00066FF2046FDF7B8FF28680122962190F849 +:106FE000BB300020FDF766FE90E7FFE780780028C1 +:106FF00040F0FD8000F0F9B88DF8081002A90520D6 +:10700000FFF798FE0028286800F0EA808278884917 +:10701000002A7DD0A1F11F066C6890F8BB90D6F8CD +:107020000F00C4F80E00B6F813006082707D207562 +:10703000B07D6075B6F81700E082B6F81900608080 +:10704000B6F81B00A080B6F81D00E08004F108002F +:107050000DF064FA96F8240000F01F00207696F8F0 +:107060002400400984F86C0184F8549084F8559009 +:10707000286890F8CC1084F8561090F8BD0084F879 +:1070800057009DF80810686800F079F9022001F0B7 +:10709000D1FAA6F12804DAF80090A4F800800821BB +:1070A000204605F0C2FC0021204605F0C1FE4946FD +:1070B000204605F0C6FE6946304605F0EFFC304636 +:1070C00005F009FD0146204605F0EFFC06230022ED +:1070D000694600E0B8E0204605F090FE694630467B +:1070E00005F0CEFC304605F0E9FC0146204605F0EF +:1070F000E9FC062301226946204605F07FFE204672 +:10710000FDF722FF28680122962190F8BB3000E0AD +:1071100006E00020FDF7CEFD286880F801B068E0A9 +:107120006C6832783F4E607BC2F34012104060734F +:10713000D6F80F00C4F80E00B6F813006082707D18 +:107140002075B07D6075B6F81700E082B6F81900BA +:107150006080B6F81B00A080B6F81D00E0804FF0FC +:10716000010A04F108000DF0D9F996F8240000F0A6 +:107170001F00207696F82400400984F86C0184F8FA +:1071800054A084F855A0286890F8CC1084F85610C4 +:1071900090F8BD0084F857009DF80810686800F06A +:1071A000EEF8286880F8D09090F8D210B0F8D400AB +:1071B00000F071F868680088F9F72CFDF9F7C4F958 +:1071C000286880F80180FDF765FFFDF744FFFDF7B3 +:1071D0003FFEFDF7A8FE012001F02CFA09E000BFF8 +:1071E00090F82200C0F3001008B1012701E0FEF77B +:1071F000AAFF286890F8330018B1FDF769FFFDF782 +:1072000038F91FB100210120FFF783FB286841787E +:1072100000291ABF4178012903B00BE0A40A00201D +:10722000CC000020280C002060480200000C002048 +:10723000470C002008BFBDE8F08F4078032818BF36 +:10724000FFDF03B0BDE8F08F286890F82200C0F39C +:1072500000100028CBD0C8E770B5864C06460D4616 +:107260002068807858B1FDF765FA216803463046FA +:1072700091F8BB202946BDE8704001F048BAFDF7FF +:1072800059FA21680346304691F8BA202946BDE8EC +:10729000704001F03CBA784A137882F8F530A2F8D1 +:1072A000F60082F8F410012082F8F20092F8C4008F +:1072B000002818BF92F8C00082F8F800704778B52F +:1072C00004466C4800230093006890F8BA20082A0E +:1072D00004BF4FF4C87240230DD0042A04BF4FF4FA +:1072E000BF72102307D0022A07BF03F1180204233C +:1072F00003F128020823491D01FB032690F8BC2056 +:107300009DF8001062F3050141F040058DF8005032 +:1073100090F8BB00012804BF9DF8020020F0E000B7 +:107320002AD0022818BFFFDF21D000BF25F080003F +:107330008DF80000C4EB041106FB04F001EB8101A1 +:1073400000EB81044D48844228BFFFDF4C48A0FB7E +:107350000410BDF80110000960F30C01ADF8011034 +:10736000BDF800009DF8021040EA014078BD9DF88C +:10737000020020F0E00020308DF80200D6E72DE971 +:10738000F0413C4D04460E46286890F8D000002895 +:1073900018BFFFDF0027286880F8D2702188A0F886 +:1073A000D4106188A0F8EA10A188A0F8EC10E18858 +:1073B000A0F8EE1094F86C1180F8F01090F82F10EF +:1073C00049B1427B00F10E01012A04D1497901F053 +:1073D000C001402935D090F8301041B1427B00F116 +:1073E0000E01012A04BF497911F0C00F29D0DE3007 +:1073F0000DF082F82348FF2E0078C0F380106076ED +:107400001D48D0F88711C4F81A10B0F88B01E0833A +:1074100028681ED0C0F8E410E18BA0F8E81000F155 +:10742000D802511E304604F0E9F9002808BFFFDFFA +:10743000286890F8D71041F0020180F8D710BDE815 +:10744000F081D0F80E10C0F8DE10418AA0F8E210EA +:10745000D0E7C0F8E470A0F8E870617E80F8D7103B +:10746000D4F81A10C0F8D810E18BA0F8DC10BDE8F1 +:10747000F0810000CC000020A40A0020C4BF03005B +:1074800089888888280C0020FE48406870472DE9CC +:10749000F0410F46064601461446012005F098F9D2 +:1074A000054696F85500FEF7A6F8014696F85500F1 +:1074B000022808BFF44807D0012808BFF34803D0CA +:1074C00004280CBFF248F34808444FF47A7100F2E4 +:1074D000E140B0FBF1F0718840F271225143C0EB02 +:1074E0004100001BA0F5597402F0B6FD002818BF3A +:1074F0001E3CAF4234BF28463846A04203D2AF42BA +:107500002CBF3C462C467462BDE8F0812DE9FF4F4C +:107510008FB0044690F855601C98994640EA0900DF +:10752000039094F86500002790460D280CBF0120B9 +:1075300000200990B9F1000F04BF94F80C01032852 +:107540002BD1099848B3B4F88E01404525D1D4F821 +:107550001401C4F80001608840F2E2414843C4F8D5 +:107560000401B4F85A01B4F8E6100844C4F808015C +:10757000204602F07BFDB4F89201E08294F890017D +:107580006075B4F894016080B4F89601A080B4F8F6 +:107590009801E080022084F80C01D4F864010C907A +:1075A000B4F8E6B0B4F85801D4F860A1D4F8541196 +:1075B0000691B9F1000F03D094F8201149B193E07E +:1075C00004F1E00107917431089104F5A075091DDB +:1075D00007E004F59A710791091D089104F5927569 +:1075E000091D0A91B4F85810A8EB0000A8EB01019E +:1075F00009B200B20091002805DAD4F850010690D3 +:1076000001200390084694F80C11002971D001293B +:1076100000F03782022900F05F81032918BFFFDFE5 +:1076200000F0728239460698FAF7FBFF08990126A6 +:1076300040F2712208600A98A0F8008000202870AB +:107640002E7108980068A8606188D4F8140151432D +:10765000C0EB41009049A0F54D70886149698142B5 +:1076600087BF07990860079801600798616A0068FA +:10767000084400F5D270E86002F0EEFC10B1E86852 +:107680001E30E8606E71B4F8D000A0EB080000B2C4 +:107690000028C4BF03206871099800281C9800F0D6 +:1076A000A682C0B1B4F8F81000290CBF0020B4F8CD +:1076B000FA00A4F8FA0094F8FC20401C50438842D9 +:1076C00009D26879401E002805DD6E71B4F8FA0011 +:1076D000401CA4F8FA00B9F1000F00F0AB8294F856 +:1076E0002001002800F0A28213B00220BDE8F08F34 +:1076F000FFE7BAF1000F08BFFFDF94F855106148AB +:1077000090F8280005F079F90C90E18A40F2712098 +:1077100041430C98002200EB41011098002806D04C +:1077200000FB01F15D48B1FBF0F000F10102C4F88B +:107730001021608840F2E24100FB01F210994FF005 +:10774000000006D0554801FB02F1B1FBF0F000F15A +:107750000100C4F8140186B221464FF00100D4F8AC +:1077600028B005F035F8074694F85500FDF743FFBB +:10777000014694F85500022808BF434807D0012865 +:1077800008BF424803D004280CBF41484148084480 +:1077900000F2E1414FF47A70B1FBF0F1608840F201 +:1077A00071225043C1EB4000801BA0F5597602F0D6 +:1077B00053FC002818BF1E3EBB4534BF3846584610 +:1077C000B04203D2BB452CBF5E463E46666294F88B +:1077D0005500FDF72EFF4FF47A7600F2E140B0FB42 +:1077E000F6F000EB0A0794F85500FDF722FF01467A +:1077F00094F85500022808BF234A07D0012808BF83 +:10780000224A03D004280CBF214A224A01EB020B72 +:10781000FDF7F1FE584400F2DB514FF47A70B1FBF2 +:10782000F0F1E08A40F2712242430C98D4F810B192 +:1078300000EB4200401AA0EB0B003844A0F12007F7 +:10784000607D40F2E24110FB01F0049094F8556035 +:107850003046FDF7D0FE0146022E08BF0A4807D089 +:10786000012E08BF094803D0042E0CBF0848094860 +:10787000084400F2E1414FF47A70B1FBF0F000EB04 +:107880004B010DE0500C002004360200A22402003F +:10789000D0FB0100C0D40100D400002040420F0002 +:1078A000049801EB000B3046FDF799FE584400F1B7 +:1078B0006201FD48416194F85500FDF7BAFE00F2FF +:1078C000E1414FF47A70B1FBF0F05044381AB0F552 +:1078D0003D7F38BFFFDFA5E6E08A40F27121D4F892 +:1078E0000421484302EB400210980021002806D0F2 +:1078F00000FB02F1ED48B1FBF0F000F10101C4F82A +:107900001011618840F2E24001FB00F210994FF043 +:10791000000006D0E54801FB02F1B1FBF0F000F1F8 +:107920000100C4F8140186B221464FF00100D4F8DA +:1079300028A004F04DFF074694F85500FDF75BFEC4 +:10794000014694F85500022808BFD94807D00128FD +:1079500008BFD84803D004280CBFD748D7480844EC +:1079600000F2E1414FF47A70B1FBF0F1608840F22F +:1079700071225043C1EB4000801BA0F5597602F004 +:107980006BFB002818BF1E3EBA4534BF3846504630 +:10799000B04203D2BA452CBF56463E466662BBF1A2 +:1079A000000F2ED11C9860B394F855603046FDF757 +:1079B00022FE022E08BFBE4907D0012E08BFBD49D6 +:1079C00003D0042E0CBFBC49BC49084400F2E1417D +:1079D0004FF47A70B1FBF0F0D4F81011E38A084448 +:1079E00040F27121D4F80421594302EB41010F1AEE +:1079F0003046FDF7F4FD0C99081A3844A0F1200731 +:107A00000AE0E18A40F27122D4F80401514300EB0C +:107A10004100D4F81011471AD4F80821D4F8001105 +:107A2000D4F8100101FB020B607D40F2E24110FB33 +:107A300001FA94F855603046FDF7DDFD0146022E4F +:107A400008BF9B4807D0012E08BF9A4803D0042ED8 +:107A50000CBF99489948084400F2E1414FF47A700C +:107A6000B1FBF0F000EB4B0082443046FDF7B7FD70 +:107A7000504400F160018C484161012084F80C0100 +:107A8000D0E5628840F27123D4F814115A43C1EB57 +:107A9000420202FB00F70098D4F800C10BEB000291 +:107AA000D4F80801D4F81031121A0CFB0030521E21 +:107AB00002FB010B607D40F2E24110FB01FA94F8F9 +:107AC00055000646FDF797FD0146022E08BF78488F +:107AD00007D0012E08BF774803D0042E0CBF76488C +:107AE0007648084400F2E1414FF47A70B1FBF0F0BF +:107AF00000EB4B0082443046FDF771FD504400F12D +:107B00006001694841618DE5628840F27123D4F8D3 +:107B100014115A43C1EB420101FB00F794F86400D1 +:107B200024281CBF94F8650024280BD1B4F88E01DA +:107B3000A8EB000000B2002804DB94F891010028B3 +:107B400018BF0646039850B3BBF1000F27D10C981D +:107B5000002814BFBAF1000FFFDF94F85500FDF7BD +:107B60004AFD022E08BF524907D0012E08BF5149D5 +:107B700003D0042E0CBF50495049084400F2E141A3 +:107B80004FF47A70B1FBF0F03F1A94F85500FDF70E +:107B900026FD01460C98401A3844A0F120070098B1 +:107BA000D4F81411584400FB01FA3046FDF723FDC8 +:107BB0000146022E08BF3E4807D0012E08BF3D48AF +:107BC00003D0042E0CBF3C483C48084400F2E1417D +:107BD0004FF47A70B1FBF0F000EB4A0A3046FDF743 +:107BE000FEFC504400F160012F4841611AE5002875 +:107BF0007FF458AD94F80C0100283FF46CAD618817 +:107C000040F27122D4F814015143C0EB41012846DF +:107C100004F08DFD0004000C3FF45DAD1D990029BA +:107C200018BF0880012013B0BDE8F08F94F85C0104 +:107C3000FBF748FB94F85C012946FBF731FA002872 +:107C40001CBF89F0010084F82101002013B0BDE8B9 +:107C5000F08F2DE9F04F1A4C074683B02078894603 +:107C6000114E00254FF00208032804BF207BB842C4 +:107C70007ED1606830612078032818BFFFDF0327BA +:107C8000B9F1080F7FD2DFE809F0041D2828237E10 +:107C90007E796562FEF712FC002818BFFFDFB7701F +:107CA00003B0BDE8F08F0000D400002040420F0078 +:107CB00004360200A2240200D0FB0100C0D401005F +:107CC000500C0020FEF71CFF002818BFFFDFE7E77D +:107CD00003B0BDE8F04FFDF75CBA2775257494F842 +:107CE0002C00012658B14FF47A71A069FAF799FC7B +:107CF000A061002104F1100004F019FD1AE0012137 +:107D00006846FBF7BDFF9DF8000042F210710002CB +:107D1000B0FBF1F201FB1205FDF7F4FF0544294623 +:107D2000A069FAF77EFCA061294604F1100004F076 +:107D3000FEFC461C208C411C0A293CBF3044208498 +:107D4000606830B1208C401C0A2828BF84F8158058 +:107D500000D267753046FEF771F90028A0D0607A2E +:107D600000289DD1207B04F11001FBF799F901E077 +:107D70000BE008E0002808BFFFDF91E7207BFAF75F +:107D800028FF25708CE7FFDF8AE7202F28BFFFDF61 +:107D9000DFF804A407213AF81700F8F709FE0400F9 +:107DA00008BFFFDF202F28BFFFDFFB48218830F806 +:107DB0001700884218BFFFDF01273461B9F1080FAF +:107DC00080F05481DFE809F0049EA6A6A1F0F0EF50 +:107DD000C4F86051F580C4F8645194F8210138B9B1 +:107DE000FAF716FFD4F82C11FBF720FC00281BDC57 +:107DF000B4F81E11B4F85800814206D1B4F8D4107A +:107E0000081AA4F8D600204605E0081AA4F8D600FF +:107E1000B4F81E112046A4F85810D4F84811C4F83C +:107E20002C11C0F850111DE0B4F81C11B4F8580022 +:107E3000091AA4F8D610B4F81C112046A4F858105A +:107E4000D4F82C11C4F84811C4F85011D4F83411E6 +:107E5000C4F8E010D4F83811C4F85411B4F83C1147 +:107E6000A4F8581101F0ACFFFAF7ACFE94F855A055 +:107E700081465046FDF7BFFBBAF1020F08BFC74964 +:107E800009D0BAF1010F08BFC54904D0BAF1040FF7 +:107E90000CBFC449C44908444FF47A7100F2E14070 +:107EA000B0FBF1F1D4F8140140F271220144608872 +:107EB0005043C1EB4000A0F1300AB9F1B70F98BFB1 +:107EC0004FF0B7092146012004F082FC4844AAEB98 +:107ED0000000A0F21939A2462146012004F078FCE6 +:107EE000DAF824109C30814288BF0D1AC6F80C9035 +:107EF0004D4538BFA946C6F8089084F8207186F829 +:107F00000280CDE602F0A3F801E0FDF742F984F823 +:107F10002071C5E6FAF77CFED4F8502101461046E0 +:107F2000FBF784FB48B1628840F27123D4F8141146 +:107F30005A43C1EB4201B0FBF1F094F865100D29F2 +:107F40000FD0B4F85820B4F81E1113189942AEBFE0 +:107F5000481C401C1044A4F81E0194F8220178B972 +:107F600005E0B4F81E01401CA4F81E0108E0B4F8B6 +:107F70001E01B4F8D410884204BF401CA4F81E01AE +:107F8000B4F85A01DFF82492401CA4F85A01B4F85E +:107F90008000B4F87E10401AB4F85810401E08440F +:107FA0001FFA80FB24E053E060E000BF96F80080F9 +:107FB000B8F10C0F28BFFFDF39F8188094F86CA1D6 +:107FC000BAF10C0F28BFFFDF39F81A000023404434 +:107FD00081B202A8CDE90050B4F81E212046FFF777 +:107FE00095FA00283FF45CAE012818BFFFDF27D0C8 +:107FF000B4F81E01ABEB000000B20028D6DA08206E +:1080000084F8740084F87370204601F02AFB84F829 +:108010000C5194F85C514FF6FF77202D00D3FFDF11 +:108020005D4820F8157094F85C01FAF7D2FD202025 +:1080300084F85C01307903B0BDE8F04FF3F7A6BED9 +:10804000B4F81E01BDF808100844A4F81E01CFE7DB +:1080500094F80C01042818BFFFDF84F80C5194F841 +:108060005C514FF6FF77202DDAD3D8E7FFDF17E614 +:1080700010B54F4C207850B101206072FEF75EFDC4 +:108080002078032805D0207A002808BF10BD0C20D6 +:1080900010BD207BFBF716F9207BFBF760FB207BF4 +:1080A000FAF797FD002808BFFFDF0020207010BD01 +:1080B0002DE9F04F3E4F83B0387801244FF000088F +:1080C00040B17C720120FEF739FD3878032818BFD3 +:1080D000387A0DD0DFF8DC9089F803406946072034 +:1080E000F8F7EFFB002818BFFFDF4FF6FF7440E002 +:1080F000387BFBF7E7F8387BFBF731FB387BFAF787 +:1081000068FD002808BFFFDF87F80080E2E70298DB +:1081100000281CBF90F80C1100292AD00088A0422A +:108120001CBFDFF874A04FF0200B4AD00721F8F7EE +:108130003FFC040008BFFFDF94F85C01FBF70FFB76 +:1081400084F80C8194F85C514FF6FF76202D28BFFF +:10815000FFDF2AF8156094F85C01FAF73AFD84F81D +:108160005CB169460720F8F7ACFB002818BFFFDFB9 +:1081700022E06846F8F783FB0028C8D021E0029887 +:1081800000281CBF90F80C11002915D00088A0F51C +:108190007F41FF39CAD114E0840C0020043602006C +:1081A000A2240200D0FB0100C0D4010084480200D8 +:1081B000500C0020D40000206846F8F760FB00282F +:1081C000DDD089F8038087F82C8087F80B8003B016 +:1081D0000020BDE8F08F70B50446FD4890F800041B +:1081E000FC4D400995F800144909884218BFFFDF8B +:1081F00095F8140D4009F84991F80014490988428E +:1082000018BFFFDFF549002001220C7188700A7049 +:108210004870C870F2490870BDE8704048E7EF49FF +:10822000087070472DE9F843ED4C064688462078E3 +:1082300000285CD1EB48FAF772FC2073202856D056 +:10824000032766602770002565722572AEB1012193 +:1082500006F1FC00FBF73DFD0620F8F751FB8146D7 +:108260000720F8F74DFB96F8FC104844B1FBF0F2FC +:1082700000FB1210401C86F8FC00FAF7A3FCDA4958 +:10828000091838BF40F2F65000F23D1086B2FDF7F3 +:10829000F9FBE061FDF736FD4FF0010950B384F8BA +:1082A0000A9001216846FBF7EBFC9DF8000042F2C2 +:1082B00010710002B0FBF1F201FB12000644FAF764 +:1082C000A7FC3146FAF7ADF9A061277567752574EB +:1082D000207B04F11001FAF7E3FE002808BFFFDF5E +:1082E00025840020FEF72AFC0020BDE8F8830C203E +:1082F000BDE8F883FAF78CFC3146FAF792F9A061F1 +:10830000A57284F82C90A8F226502063DDE7B349CB +:1083100048707047B24810B5417A0124002918BF4F +:10832000002409D190F82C1031B1416A006B8142D0 +:1083300084BF0024FEF7FCFB204610BD70B5A74C9F +:108340000546E088401CE080D4E902016278D5F857 +:108350006061002A1CBF324604F019FAA060864210 +:1083600008D895F80C01012804D0E078002804BF53 +:10837000012070BD002070BD70B50C4640F2E24196 +:1083800000FB01F52046FDF736F9022C08BF97499E +:1083900007D0012C08BF964903D0042C0CBF954987 +:1083A000954908444FF47A7100F2E140B0FBF1F0D6 +:1083B00000F54D7085428CBF281A002070BD2DE954 +:1083C000F04F83B04FF00009044680F8209190F8F8 +:1083D000DE00002807BF94F80C01032803B0BDE8B5 +:1083E000F08FFAF715FCD4F8502101461046FBF740 +:1083F0001DF90028DCBF03B0BDE8F08F628840F2B1 +:108400007123D4F814115A43C1EB4201B0FBF1F0CF +:10841000411CB4F858000144A4F81C11B4F8D4105D +:10842000B4F81C21891A09B20029DCBF03B0BDE8E9 +:10843000F08F012184F82211B4F88010B4F87E2066 +:108440006E4F891A491E084485B2DFF890A10DF1DC +:10845000080B25E09AF800600C2E28BFFFDF37F8E4 +:10846000166094F86C81B8F10C0F28BFFFDF37F865 +:108470001800CDE9009B3044B4F81C2181B20123DF +:108480002046FFF743F8002804BF03B0BDE8F08F93 +:1084900001280FD0022812BFFFDF03B0BDE8F08F24 +:1084A000B4F81C01281A00B20028BCBF03B0BDE814 +:1084B000F08FCFE7B4F81C01BDF808100844A4F809 +:1084C0001C01EDE72DE9F0430422002583B00629C5 +:1084D0007DD2DFE801F0074B03191951044680F8FB +:1084E0000C2107E004463D48C178002918BF84F8F4 +:1084F0000C210CD0FAF798FAA4F85A51B4F85800A5 +:10850000A4F81E0184F8225103B0BDE8F083067878 +:108510000C2E28BFFFDF394F94F80C0137F8166096 +:108520004FF00109032807D00128E3D194F86C81AA +:10853000B8F10C0F0AD308E0C4F80851C4F8005190 +:1085400094F86C81B8F10C0F00D3FFDF37F81800F6 +:10855000CDE90095304481B2B4F8D4200023204600 +:10856000FEF7D4FF002818BFFFDFC3E7032180F820 +:108570000C1103B0BDE8F0830546876AB0F814011A +:10858000294686B2012004F023F9044695F85500E7 +:10859000FDF731F895F85510022908BF134907D0A7 +:1085A000012908BF124903D004290CBF11491249FF +:1085B00008444FF47A7100F2E140B0FBF1F06988B1 +:1085C00040F271225143C0EB4100801B18E02DE0C6 +:1085D00001E000E00BE000E019E000E0D400002042 +:1085E000500C0020537C01000AFAFFFF0436020001 +:1085F000A2240200D0FB0100C0D401008448020084 +:10860000A0F5597601F028FD002818BF1E3EA742AC +:1086100034BF20463846B04228BF344602D2A74273 +:1086200028BF3C466C6203B0BDE8F083FFDF03B0B7 +:10863000BDE8F083F8B5894C0246874F0025616894 +:10864000606A052A48D2DFE802F0032F34373E0083 +:10865000A07A002660B101216846FBF71BFB9DF85C +:10866000000042F210710002B0FBF1F201FB1206B1 +:10867000FDF748FB8119A069F9F7D3FFA0612574C4 +:1086800003206075607A38B9207B04F11001FAF795 +:1086900007FD002808BFFFDF2584FAF7C5F9387900 +:1086A000BDE8F840F3F772BBBDE8F840002100F0E8 +:1086B0006DB8C1F86001F8BDD1F86001BDE8F840BF +:1086C000012100F063B884F82C50FAF7ADF938793D +:1086D000BDE8F840F3F75ABBFFDFF8BD70B55E4C5C +:1086E000A178022906BFE188002970BD2569C5F877 +:1086F000640195F85500FCF772FFD5F86411081A6B +:10870000A1680144A160E1680844E06070BD70B5F3 +:108710000546514890F802C0BCF1020F06BF00693F +:1087200000F5B0744E4C002904BF256070BD4FF4B5 +:108730007A7601290DD002291CBFFFDF70BD1046DB +:10874000FCF768FF00F2E140B0FBF6F0281A206069 +:1087500070BD1846FCF76DFF00F2E140B0FBF6F08B +:10876000281A206070BD3D48007800281CBF0020FA +:10877000704710B50720F8F7B5F880F0010010BD7C +:1087800036480078002818BF012070472DE9F047CF +:10879000324C82B0002584F82C50D4F8188084F82C +:1087A0002810E572814625700127277229466068E6 +:1087B00003F030FB6168C1F85081267B81F85C6171 +:1087C000C1F86091C1F85481B1F80080202E28BF13 +:1087D000FFDF244820F81680646884F80C51DFF825 +:1087E0007880A4F8585198F800600C2E28BFFFDF5D +:1087F000DFF8749039F816A094F86C610C2E28BF3D +:10880000FFDF39F816000023504481B200951A4664 +:1088100020460195FEF77AFE002818BFFFDFC4F856 +:108820000851C4F8005184F80C71A4F81E51A4F842 +:108830001C5184F82251B4F85800401EA4F8580086 +:10884000A4F85A51FAF7F0F898F8040002B0BDE81D +:10885000F047F3F79BBA0000D4000020500C002032 +:10886000740C0020840C00208448020070B5FE4C7B +:1088700021690A88A1F8FC2181F8FA0191F85400D5 +:10888000012808BF012503D0022814BFFFDF0225FD +:10889000206980F8FE5190F85500012808BF012595 +:1088A00003D0022814BFFFDF02252069012180F8D0 +:1088B000FF5180F8F811002180F8A4112079BDE85B +:1088C0007040F3F763BA2DE9F04FE74C83B0A0791D +:1088D00010F0010F04BF03B0BDE8F08FA0690123C1 +:1088E0000521C578206990F86520583003F0B5FE61 +:1088F00068B1A81E0A2806D2DFE800F009090505BC +:10890000090905050909A07840F00800A070A078C1 +:1089100000281CBF03B0BDE8F08FA06920274FF0EE +:10892000020890F80390B9F1000F1CBFB9F1010FD4 +:10893000B9F1160F1ED1206990F8640003F076FE9D +:10894000C0B1216991F864001F2813D0202808D0F5 +:10895000B9F1160F0CBFA77084F8028003B0BDE810 +:10896000F08F262081F86400B9F1160F1CBF2A2071 +:10897000FFF77CFF47F6FE7A012600254FF0280B13 +:10898000B9F10C0F00F049810BDCB9F10C0F80F04C +:108990005884DFE809F068412BD9F6F6F5F4F3F6D0 +:1089A000AAD0B9F1150F00F0518211DCB9F1110F05 +:1089B00000F0BE83B9F1120F00F0C981B9F1130FB5 +:1089C00000F0B881B9F1140F00F0D58100F039BC86 +:1089D000B9F1160F00F06C82B9F1180F00F0CE82D9 +:1089E000B9F1FF0F00F0268400F02BBC20690123B1 +:1089F000194690F86720583003F02FFE002840F009 +:108A00002284A06904F018FB216981F87201072013 +:108A100081F8670000F017BC20690123002190F85D +:108A20006520583003F019FE002800F0BA83A069D1 +:108A300004F0FFFA2169A1F88E01B1F85820801ADC +:108A400000B28245A8BF0028DCBF81F874B081F86D +:108A5000736040F3F88301F5C871A06904F0E4FA8B +:108A60000B2021693DE020690123002190F8652059 +:108A7000583003F0F2FD002800F09383A06904F061 +:108A8000AFFA002800F0DD83A0692269B0F80D106C +:108A9000A2F88E11B2F85830C91A09B28A45A8BF97 +:108AA0000029DCBF82F874B082F8736040F3CB8396 +:108AB000017982F89011B0F80510A2F8921104F033 +:108AC00082FA2169A1F89401A06904F07FFA216972 +:108AD000A1F89601A06904F080FA2169A1F8980133 +:108AE0000D2081F8650000F0AEBB20690123002154 +:108AF00090F86520583003F0B0FD002820690BD0B5 +:108B0000A0F88A5090F88C10491C80F88C10102125 +:108B100080F8651000F097BB90F8652001230521CF +:108B2000583003F09AFD00281CBF0820A07040F0C8 +:108B30008A8300F036BB206990F86510112908BFC0 +:108B4000122140F09C82E3E720690123002190F884 +:108B50006520583003F081FDA0B9206990F86520A8 +:108B6000122A0FD001230521583003F076FD00288A +:108B700018BF082000F0158300F097B9B7E0F6E2BF +:108B800036E05EE3206990F88E1031B9A0F88A5083 +:108B900090F88C10491C80F88C1000F1E801A06955 +:108BA00004F063FA206900F1C001A06904F068FADA +:108BB000206990F8C001002818BFFFDF20690188F4 +:108BC000A0F8C21100F5E271A06904F03CFA206936 +:108BD00000F5E671A06904F03EFA206980F8C061F2 +:108BE000142180F865102079F3F7D0F800F02BBB42 +:108BF000206990F86510172940F0418290F88C1098 +:108C0000491E49B280F88C100029B8BFFFDF1B2035 +:108C1000216981F8650000F016BB206990F86610A4 +:108C200011F0020F09D090F8642001230821583078 +:108C300003F013FD002800F0B482206990F8900042 +:108C400010F0020F18D1A06904F02EFA216981F802 +:108C50009100A069B0F80520A1F89220B0F80700B3 +:108C6000A1F8940002E00000F000002091F89000CC +:108C700040F0020081F89000206990F8901011F007 +:108C8000010F05D0206990F8641006291CD114E06A +:108C900090F8660010F0020F18BFFFDF206990F80F +:108CA000661041F0020180F86610A0F88A5090F832 +:108CB0008C10491C80F88C10E4E780F8645080F830 +:108CC00088502079F3F762F8206990F88C11042914 +:108CD00040F0B98280F88C512079F3F757F8206979 +:108CE00090F86410002940F0AE8200F01EBA2069AE +:108CF00090F8660010F0010F77D16946A06904F082 +:108D0000DAF99DF8000000F02501206980F896103E +:108D10009DF8011001F0410180F89710A0F88A50E9 +:108D200090F88C10491C80F88C1090F8661041F077 +:108D300001011CE020690123092190F864205830CA +:108D400003F08BFC002840F0248200F02ABA20694E +:108D500090F8661011F0040F40F02382A0F88A50BA +:108D600090F88C2041F00401521C80F88C2080F88F +:108D7000661000F068BA206990F8660010F0300FB5 +:108D800033D1A06904F0B4F9002800F05A822769B1 +:108D9000A06904F0A9F938872769A06904F0A0F94F +:108DA00078872769A06904F0A1F9B8872769A069C5 +:108DB00004F098F9F887A07910F0020F03D06069E9 +:108DC000C078142812D0206990F864101C290DD0A6 +:108DD00090F84E1001290CD090F89B11002904BF87 +:108DE00090F89A1100290CD003E05BE0206980F82C +:108DF0004E60206990F8661041F0100180F866100E +:108E00001AE090F8661041F0200180F866100288A0 +:108E1000A0F8E021028FA0F8E221428FA0F8E4211F +:108E2000828F00F5D671A0F8E621C08F888781F87F +:108E300032602079F2F7AAFF2069A0F88A5090F8F2 +:108E40008C10491C80F88C1000F0FDB920690123BA +:108E50000A2190F86420583003F0FFFB10B3A0699A +:108E600004F046F9A8B12669A06904F03DF93087FD +:108E70002669A06904F034F970872669A06904F0B6 +:108E800035F9B0872669A06904F02CF9F08701F064 +:108E9000EDFA206980F8885080F8645001F0B6FA45 +:108EA00000F0D1B9A07840F00100A07000F0CBB97B +:108EB000206901230B2190F86520583003F0CDFB89 +:108EC00010B1A77000F0BFB920690123002190F80C +:108ED0006520583003F0C1FB002800F06281206952 +:108EE00090F864002428ECD0A06904F01CF9002854 +:108EF00000F0A781206990F8961041F0040180F8F5 +:108F00009610A1694A7902F0070280F85120097988 +:108F100001F0070180F8501090F8A531002B04BF34 +:108F200090F8A431002B1CD190F855C000F15403E7 +:108F30008C4502BF1978914280F87D6011D000F510 +:108F4000D67180F8F2610288A0F8F42190F85020E0 +:108F500080F8F62190F8510081F84B002079F2F763 +:108F600015FF2069212180F86510A0F88A5090F83B +:108F70008C10491C80F88C1000F065B9206990F8BD +:108F80006410202914BF0027012790F865102229BA +:108F900008BF00F1650804D0002F18BF00F1640875 +:108FA0006DD090F8961041F0040180F89610A069F9 +:108FB00004F0DBF8F0B3D4F81890484604F0C9F890 +:108FC0000090484604F0C9F8814603F03CFC0100DB +:108FD00018D0206990F854208A4213D090F8A43118 +:108FE00023B190F8A63113EA090F4BD0002F04BF2C +:108FF00090F8513013EA090F01D18A4242D890F813 +:10900000A401B8B1DDF80090484603F01CFC78B12B +:10901000216991F8552082420AD091F8A40120B12B +:1090200091F8A70110EA090F2CD091F8A40108B11A +:109030006A4600E026E0A169206903F013FCE8B36A +:10904000A06904F090F82169A1F88E01B1F85820C8 +:10905000801A00B28245A8BF0028DCBF81F874B036 +:1090600081F8736052DD9DF8000081F890019DF851 +:10907000010081F89101242088F8000046E084F87E +:109080000280E0E0206990F8A40100281CBF1E20A7 +:10909000FFF7ECFBB7B1A0692169C07881F8CA007D +:1090A00006FA00F010F0807F08BFFFDF0A21206978 +:1090B00080F8641090F88800002800E014E008BFF1 +:1090C000FFDF0DE088F80050216991F88C00401E08 +:1090D00040B281F88C000028B8BFFFDF01F07BF9B7 +:1090E000206980F87D50AEE0206990F8A40120B19D +:1090F0000020FFF7BBFB88F80050206900F16501F4 +:1091000080F87D50884508BF80F86550206900F1DF +:109110006501884509D190F88C10491E49B280F844 +:109120008C100029B8BFFFDF8DE080F888508AE0FE +:10913000206990F8961041F0040180F89610A0691B +:1091400004F02FF816287ED1206990F864002028BA +:1091500002D0262805D076E0A06904F026F8FFF7B3 +:1091600085FB206980F8645080F888506BE02069A6 +:1091700090F864200E2A03D1A1690979122902D03E +:109180001C2A1AD10FE001230921583003F065FA97 +:1091900038B1206980F87C5080F8885080F864509D +:1091A00051E0A6704FE0A1690979142904BF80F845 +:1091B000645080F888503FF471AE202A03D1A16931 +:1091C0000979162914D0262A03D1A169097916290B +:1091D0000ED0A1690979172904BF90F86520222AC9 +:1091E00013D0E2691AB1FF2908BF80F886612AE02E +:1091F00080F8645080F8885090F86500212818BFE6 +:109200001A2020D0FFF732FB1DE080F8655090F85F +:109210008C10491E49B280F88C100029B8BFFFDFBE +:10922000206980F87D5090F8A401002818BF002024 +:1092300009D0E7E7E06900281CBF206980F8866153 +:1092400001D101F0C8F82069D0E92A12491C42F185 +:109250000002C0E92A1203B0BDE8F08F70B5FB4EE2 +:1092600005460C46306990F8CB00FE2818BFFFDF9A +:1092700032690020002C82F8CB501CBFA2F88A0073 +:1092800070BDA2F88400012082F8880070BD30B55E +:1092900085B005466846FCF73EFA002808BFFFDFA8 +:1092A000222100980BF003F80321009803F040FE00 +:1092B0000098017821F010010170294603F066FE44 +:1092C000E24C0D2D04BF0621009830D00BDCA5F137 +:1092D00002000B2819D2DFE800F0201863191926C4 +:1092E000187018192C00152D7BD008DC112D2DD0ED +:1092F000122D18BF132D09D0142D30D005E0162DD6 +:1093000046D0172D6BD0FF2D6AD0FFDFFCF716FA81 +:10931000002808BFFFDF05B030BD2069009990F834 +:10932000CC000871F2E72169009891F8CC10017126 +:10933000ECE7E26800981178017191884171090A9F +:1093400081715188C171090A0172DFE70321009818 +:1093500003F025FF0621009803F025FFD6E72069DA +:10936000B0F84410009803F0ABFE2069B0F8461046 +:10937000009803F0A9FE2069B0F84010009803F0AF +:10938000A7FE2069B0F84210009803F0A5FEBDE7E3 +:109390002069009A90F8A611117190F8A7014BE08E +:1093A000206900F1F001009803F06EFE206900F1E1 +:1093B000C401009803F072FEA8E7A549D1E90001B5 +:1093C000CDE90201206902A990F8960000F025007D +:1093D0008DF80800009803F09CFE97E701E019E083 +:1093E0002CE02069B0F84010009803F071FE20696D +:1093F000B0F84210009803F06FFE2069B0F84410F6 +:10940000009803F05DFE2069B0F84610009803F064 +:109410005BFE7BE7206990F8A41139B1009990F8C0 +:10942000A6210A7190F8A70148716FE7009A90F899 +:109430005410117190F85500507167E7206990F849 +:109440008721D0F88811009803F0AEFD5EE770B573 +:109450000C4605464FF4007120460AF04AFF25806D +:1094600070BDF7F7AEBB2DE9F0410D460746072169 +:10947000F7F79EFA040008BFBDE8F08194F8AC014C +:109480000026B8B16E700920287094F8AC0178B14C +:10949000268484F8AC61D4F8AE016860D4F8B201D7 +:1094A000A860B4F8B601A88194F8AC010028EFD107 +:1094B0002E7144E094F8B801002837D094F8B80130 +:1094C0000D2818D00E2818BFFFDF38D12088F7F7F5 +:1094D000A1FB0746F7F74DF8A0B96E700E20287073 +:1094E00094F8BA0128712088E88084F8B861384679 +:1094F000F7F739F823E02088F7F78CFB0746F7F7F2 +:1095000038F810B10020BDE8F0816E700D20287091 +:1095100094F8BA0128712088E88094F8BE01287276 +:1095200084F8B8613846F7F71EF808E094F8F001BF +:1095300040B16E701020287084F8F061AF80012077 +:10954000BDE8F08194F8C00190B16E700A202870D7 +:109550002088A880D4F8C401D4F8C811C5F8060042 +:10956000C5F80A10B4F8CC01E88184F8C061E6E7D8 +:1095700094F8CE0140B16E701A202870B4F8D00172 +:10958000A88084F8CE61DAE794F8EA0180B16E70C1 +:109590001B20287094F8EA010028D0D084F8EA61F2 +:1095A000D4F8EC01686094F8EA010028F6D1C6E727 +:1095B00094F8D2012F1DA0B16E701520287094F878 +:1095C000D201002818BF04F5EA75B8D084F8D2613A +:1095D000294638460AF099FF94F8D2010028F5D1BF +:1095E000ADE794F8DE0150B16E701D20287084F84C +:1095F000DE6104F5F07138460AF087FF9FE794F8C2 +:10960000F20138B11E20287084F8F261D4F8F40118 +:10961000686094E794F8F801002808BFBDE8F0817D +:109620006E701620287094F8F801002887D000BFCB +:1096300084F8F861D4F8FA016860B4F8FE01288172 +:1096400094F8F8010028F3D179E70000F000002039 +:109650009C480200FE4AD0600020D0611062117167 +:109660007047002180F8641080F8651080F8681059 +:1096700090F8DE1011B10221FEF724BF0321FEF79E +:1096800021BF2DE9F047F24C814686B020690D4696 +:109690000088F7F7D1FA070008BFFFDFA07828435A +:1096A000A070A0794FF0000510F0200F20691CBFBA +:1096B000A0F87E5080F8E45004D1B0F87E10491C28 +:1096C000A0F87E102069012690F86A1039B990F848 +:1096D000652001230621583002F0BFFF48B3E0881F +:1096E00010F4006F07D0206990F86A10002918BFA5 +:1096F000A0F876501DD12069B0F87610491C89B2C7 +:10970000A0F87610B0F878208A422CBF531A0023B4 +:10971000B4F808C00CF1050C634598BF80F87C6074 +:10972000914206D3A0F8765080F8F0612079F2F7E4 +:109730002DFBA0794FF0020A10F0600F11D02069C4 +:1097400090F8681011B1032906D00AE080F868602B +:109750000121FEF7B7FE04E080F868A00121FEF7C2 +:10976000B1FE206990F86810012905D1E18811F453 +:10977000807F18BF80F868A04FF00808B9F1000F8B +:1097800040F09981E28812F4007F18BFA0F8F850E9 +:1097900004D1B0F8F810491CA0F8F81012F0080F26 +:1097A00050D0A17800294DD190F8CB00FE2808BFF9 +:1097B000FFDFFE21206980F8CB1090F86510192991 +:1097C00007D0206990F864101F2911D027292AD0CA +:1097D0002FE080F88D5090F88C10491E49B280F827 +:1097E0008C100029B8BFFFDF206980F86550E8E7DA +:1097F00090F8650002F01AFF80B12069262101234C +:1098000080F8641090F865200B21583002F025FF95 +:10981000002804BF2A20FFF729F80AE02169202048 +:1098200081F8640005E080F8856180F8645080F874 +:109830008850206990F86710082904BF84F800A0B8 +:1098400080F8CBA0FFF73FF8A07910F0040F07D005 +:10985000A07828B9206990F86700072808BF26700B +:1098600000F038FCA07910F0100F09D0A07838B9BA +:10987000206990F865100B2904BF0C2180F8651051 +:10988000E07810F0080F11D020690123052190F82D +:109890006520583002F0E1FE28B184F8028020698A +:1098A00080F8B85102E0002001F0F2FAE0690028E7 +:1098B0005BD000950195029503950495206990F879 +:1098C0005500FBF798FE4FF47A7100F5FA70B0FB83 +:1098D000F1FA206990F85500FBF781FE5044ADF88D +:1098E000060020690188ADF80010B0F85810ADF8F6 +:1098F00004104188ADF8021090F8860130B1A069DB +:10990000C11C039103F0FEFA8DF81000206990F855 +:1099100085018DF80800E16968468847206980F86C +:10992000865180F885510399F9B190F88411E1B915 +:1099300090F86410272918D09DF81010039AA1B14F +:109940001378FF2B06D0072B02BF02295178FF297D +:1099500002D00AE01B2908D880F884610399C0F876 +:1099600088119DF8101080F8871100F0CCFD01F0EF +:1099700085FA0028206918BFA0F8D85004D1B0F8A3 +:10998000D810491CA0F8D81001F07BFA40B1216929 +:1099900091F8E40002289CBF401C81F8E40004D840 +:1099A000206990F8E400022806D92069A0F8D85070 +:1099B000A0F8DA5080F8E45020690123002190F8E3 +:1099C0006520583002F049FE20B9206990F8650002 +:1099D0000C285AD120690123002190F864205830C6 +:1099E00002F03BFEB0B320690123002190F867200C +:1099F000583002F032FE68B3206990F868100229EE +:109A000004BF90F8E40000283FD13846F6F781FB08 +:109A100000B3206990F8CB10FE2936D1B0F8D210EF +:109A2000012932D980F8DD60B0F88010B0F87E20CE +:109A30008B1E9A42AFBF0121891A491E89B2B0F824 +:109A4000D82023899A422EBF01229A1A521C02E082 +:109A5000F000002019E038BF92B2914288BF114651 +:109A6000012908BF80F8DD5090F869218AB1B0F86B +:109A7000DA20B0F86A0182422FBF0120801A401C10 +:109A800080B2814288BF014603E02069012180F84D +:109A9000DD502069B0F85820114489B2A0F8D410E4 +:109AA00090F86830002B18BF012B5DD0022B1CBF33 +:109AB000032BFFDF09D0E088C0F340200028206995 +:109AC00018BFA0F8E65059D151E090F86730082B44 +:109AD00021D0B0F87E10B0F8802000278B1C9A426D +:109AE00006D3511A891E0F043F0C1CBF791E8FB27A +:109AF00090F87C1051B190F864200123092158306E +:109B000002F0ABFD002808BF002729D0206990F89B +:109B10006A1089B908E0B0F87E30032B24D3B0F87E +:109B200080101144491C1FE090F865200123062194 +:109B3000583002F092FD78B121690020B1F8782008 +:109B4000B1F876108B1C9A4203D3501A801E18BFAE +:109B5000401EB84238BF87B2002F1CBF781E87B2A4 +:109B60002069B0F8D4103944A0F8D010A3E7B0F8B9 +:109B7000E610B0F8D6201144A0F8E610206990F85D +:109B8000701139B990F8672001231946583002F056 +:109B900064FD38B12069B0F88210B0F8D6201144C5 +:109BA000A0F88210206990F8883033B1B0F88410A2 +:109BB000B0F8D6201144A0F8841090F98C20002A27 +:109BC00006DDB0F88A10B0F8D6C06144A0F88A105B +:109BD0004FF03D0CB9F1000F18BF80F874C049D1A7 +:109BE0002178022911D0012908BF90F872113FD0C5 +:109BF000A17821B380F8736011F0140F18BF1E21F3 +:109C000009D000BF80F8741050E090F8CC100629FD +:109C100018BF16212CE011F0080F18BF80F874C08F +:109C200044D111F0200F18BF2321EBD111F0030F05 +:109C300008BFFFDF2A20216981F8740032E02BB1D0 +:109C4000B0F88410B0F88630994210D2002A05DDB1 +:109C5000B0F88A10B0F88620914208D2B0F882207D +:109C6000B0F880108A4208D390F870212AB12221DE +:109C700080F8741080F8736018E090F868203AB1AA +:109C8000B0F87E208A4228BF80F87480F2D209E0C2 +:109C9000B0F87E10062905D33E2180F8741080F8B4 +:109CA000736003E0206990F8731079B1206980F83F +:109CB000645080F8655080F8685090F8DE100029F4 +:109CC00014BF02210321FEF7FDFB02E00021FEF795 +:109CD000F9FB206980F8DE5006B0BDE8F047FBF7DD +:109CE0004FBDF84902468878CB78184313D108460F +:109CF00000694AB1897911F0080F03D090F8670024 +:109D0000082808D001207047B0F84810028E914210 +:109D100001D8FEF713BB0020704770B5E94C05462B +:109D20000E46E0882843E08015F0020F04D015F0BD +:109D3000010F18BFFFDF666115F0010F4FF0000241 +:109D40004FF001001AD0A661F178062902D00B2944 +:109D50000BD013E0216991F86530172B0ED1002349 +:109D6000C1E9283381F8690008E0216991F865307C +:109D7000112B04BF81F8692081F88E0015F0020FC5 +:109D800018D06169C978052902D00B290BD011E0E0 +:109D9000216991F86520152A0CD10022C1E92A22F7 +:109DA00081F86A0006E0206990F86510102908BF64 +:109DB00080F86A2015F0800F1CBF0820E07070BD8D +:109DC0002DE9F84FBF4C00254FF00108E580A57044 +:109DD000E5702570206168F30709074680F8DE808A +:109DE0000088F6F729FF5FEA000A08BFFFDF206955 +:109DF0000088FBF78DFC20690088FBF7AFFC206929 +:109E0000B0F8D21071B190F8CB10FE290FD190F8B4 +:109E1000701189B190F8672001231946583002F07B +:109E20001CFC88B1206990F8CB00FE2804D0206982 +:109E300090F8CB00FFF72BFA206990F8DF1000298B +:109E400018BF25811BD10FE02069A0F8825090F83F +:109E5000711180F8CC1000210220FFF7FFF9206972 +:109E600080F8DD500220E5E790F8AC1129B9018CAB +:109E70008288914288BF218101D881882181B0F8F0 +:109E8000D610491E8EB2B0F8D8103144A0F8D810C0 +:109E900090F8DC1000291CBFA0F8DA5080F8DC50E4 +:109EA00004D1B0F8DA103144A0F8DA10B0F87E101E +:109EB0003144A0F87E1090F86A1039B990F8652006 +:109EC00001230621583002F0C8FB28B12069B0F800 +:109ED00076103144A0F876102069B0F8D21001292C +:109EE0009CBF491CA0F8D210002E18BF80F8E45087 +:109EF00090F8DD10A1B1B0F8D800218988420FD2C6 +:109F00005046F6F706F958B1206990F8691139B151 +:109F1000B0F8DA10B0F86A01814228BF00F0B4FF4F +:109F2000206980F8DD5090F865100B2918BF0C29C6 +:109F300016D1B0F85820B0F88E31D21A12B2002AD9 +:109F40000EDBD0F89011816090F89411017302211A +:109F500001F060FF206980F8655080F898804AE041 +:109F6000242924D1B0F85810B0F88E21891A09B2EA +:109F700000291CDB90F8A42190F89011002908BF5B +:109F800090F8541080F8541090F89111002908BFEF +:109F900090F8551080F85510002A1CBF0020FEF7DD +:109FA00065FC206980F8655080F87D5023E090F8CA +:109FB0006410242918BF25291DD1B0F85810B0F815 +:109FC0008E21891A09B2002915DB90F89011002919 +:109FD00008BF90F8541080F8541090F8911100299F +:109FE00008BF90F8551080F855100020FEF73EFC91 +:109FF000206980F86450216901F15800B1F8D62039 +:10A0000002F02CF9206990F86911002918BFA0F816 +:10A01000DA502D4800902D4B2D4A3946484600F025 +:10A0200073FE216A00291CBF6078FBF720F82069C5 +:10A030000123052190F86520583002F00EFB00281E +:10A0400008BFBDE8F88FBDE8F84F00F066BC00F02F +:10A05000FBBE1C49C86170471A48C069002818BF78 +:10A0600001207047174A50701162704710B50446BE +:10A07000B0F894214388B0F89611B0F898019A424C +:10A0800001BFA3889942E38898420FD02388A4F89F +:10A09000B031A4F8B221A4F8B411A4F8B60101209B +:10A0A00084F8AC0107480079F1F770FE01212046E1 +:10A0B00001F0B0FE002084F86500032084F86800F9 +:10A0C00010BD0000F000002083960100E39C010019 +:10A0D0001B9D010070B5FE4CA07910F0020F08BF67 +:10A0E00070BDA078002818BF70BD6169F8482722AC +:10A0F000CB780E26002500690D2B78D00BDCA3F160 +:10A1000002030B2B1FD2DFE803F0201E808B9F2F52 +:10A110001E591E73D100152B00F02A810BDC112B68 +:10A1200065D0122B00F0F480132B00F0FF80142B6D +:10A1300000F00E8107E0162B00F03281172B00F0A3 +:10A140003F81FF2B35D0FFDF70BD90F867200123E2 +:10A150001946583002F081FA002818BF70BD082057 +:10A16000216981F8670070BD90F8643009790A2B85 +:10A1700001BF90F8CA308B4280F8645080F8885054 +:10A1800008BF70BD90F8663013F0080F0DD023F0B3 +:10A19000080180F8661090F88C10491E49B280F8CA +:10A1A0008C100029A8BF70BDCFE0FF291CBFFFDFC6 +:10A1B00070BD80F8642080F8845170BD90F866000E +:10A1C00010F0010F08BFFFDF216991F88C00401EDD +:10A1D00040B281F88C000028B8BFFFDF206990F8FA +:10A1E000661021F0010100BF80F8661070BD21E00B +:10A1F00090F86500102818BFFFDF0121206980F862 +:10A200008D10112180F8651070BD90F8650014283C +:10A2100018BFFFDF0121206980F88D101521F1E7BB +:10A2200090F86500152818BFFFDF1720216981F815 +:10A23000650070BD90F86500152818BFFFDF192074 +:10A24000216981F8650070BD90F865001B2818BF72 +:10A25000FFDF206980F88D5090F8B801002818BF02 +:10A26000FFDF206990F88E1049B180F88E50018888 +:10A27000A0F8BC1180F8BA5180F8B8610AE00188F2 +:10A28000A0F8BC1180F8BA51012180F8BE110D214F +:10A2900080F8B8110088F6F7BDFCF6F755F920797B +:10A2A000F1F774FD206980F8655070BD90F88C114D +:10A2B000042915D0206990F8661011F0020F08BF2C +:10A2C00070BD90F88C10491E49B280F88C1000299E +:10A2D000B8BFFFDF206990F8661021F0020183E724 +:10A2E00090F8642001230021583002F0B6F90028CC +:10A2F00008BFFFDF206990F8901011F0020F07BF30 +:10A30000062180F8641080F8885080F88C51D1E7DD +:10A3100090F8642001230021583002F09EF90028B3 +:10A3200008BFFFDF206980F8646070BD90F8661098 +:10A3300021F0040180F8661090F88C10491E49B293 +:10A3400080F88C100029A8BF70BDFFDF70BD00BF72 +:10A3500090F8642001230021583002F07EF9002893 +:10A3600008BFFFDF1C20216981F8640070BD00BFB9 +:10A3700090F8660000F03000102818BFFFDF206959 +:10A3800090F8661021F0100180F8661090F88C109B +:10A39000491E49B280F88C100029A8BF70BDD4E7CF +:10A3A00090F8642001230021583002F056F900286B +:10A3B00008BFFFDF1F20216981F8640070BD00BF66 +:10A3C00090F8650021281CBF0028FFDF22202169AA +:10A3D00081F8650070BD3E49086990F8662012F06A +:10A3E000080F1EBF01208870704742F0080280F8F5 +:10A3F00066208969C97880F8C9100021A0F88A1000 +:10A4000090F88C10491C80F88C10704710B5304CB7 +:10A4100005212069FEF756F8206990F84E100129B1 +:10A4200002BF022180F84E1010BD00F5D6710288DF +:10A43000A0F8D421028EA0F8D621828EA0F8D821CF +:10A44000028FB0F844309A4228BF1A46CA85828FDC +:10A45000B0F84600824238BF10460886012081F8D5 +:10A4600026002079BDE81040F1F790BC184830B4C0 +:10A47000006990F84E30B0F832C0C48EB0F8401089 +:10A48000428F022B28D08A4238BF11460186C28FE4 +:10A49000B0F842108A4238BF11468186028FB0F868 +:10A4A00044108A4238BF11464186828FB0F8461068 +:10A4B0008A4238BF1146C186418E614588BF8C46AD +:10A4C000A0F832C0C18EA14288BF0C46C48601E00C +:10A4D000F000002030BC7047038E9A4228BF1A4615 +:10A4E000C58F838E9D4238BF2B468A4238BF1146A6 +:10A4F0000186B0F842108B4228BF0B4683860021AC +:10A5000080F84E10CAE770B5FE4C206990F8CB1069 +:10A51000FE2906BFA178002970BD90F867200123AD +:10A520001946583002F099F8002818BF70BD20690C +:10A53000002590F8701159B1A0F8825090F871116F +:10A5400080F8CC10BDE8704000210220FEF786BEE6 +:10A5500090F8652001230421583002F07EF80600AF +:10A560000CD0D4F810C09CF86500102861D01428D5 +:10A5700065D015287BD01B287ED0BEE0216991F8DC +:10A58000660010F0010F05D0BDE8704001210920E0 +:10A59000FEF764BE10F0020F0BD001210C20FEF775 +:10A5A0005DFE206990F8901041F0010180F8901054 +:10A5B00070BD10F0040F05D0BDE8704001211320DC +:10A5C000FEF74CBE10F0080F09D091F8C90081F8D1 +:10A5D000CC00BDE8704001210720FEF73FBE10F01F +:10A5E000100F02D091F89B0120B191F8650021284D +:10A5F00073D179E091F89A0188B1B1F89C01A1F882 +:10A600004000B1F89E01A1F84200B1F8A001A1F804 +:10A610004400B1F8A201A1F8460081F89A51FFF771 +:10A6200025FFFFF7F3FEBDE8704001211520FEF77E +:10A6300015BEBDE8704001210B20FEF70FBEF9F7F3 +:10A6400025FB0C2838BF70BD08212069F030F9F7D0 +:10A6500021FB28B120690421C430F9F71BFB00B9A4 +:10A66000FFDFBDE8704001210420FEF7F7BD9CF834 +:10A67000730101280DD000E030E0022818BF70BD42 +:10A680009CF88E00D8B106208CF8CC000121022065 +:10A690001DE09CF8B801002818BF70BD0CF1B00394 +:10A6A00000220CF1E8010CF5BA7001F052FF012113 +:10A6B0000520FEF7D3FD206980F8735170BD9CF82A +:10A6C000960010F0040F14BF11200D200121FEF799 +:10A6D000C5FD206980F8735170BD0EE0BDE8704083 +:10A6E00001210620FEF7BABD91F87D00C0B991F8AE +:10A6F000A40110B191F8A50190B1206901230021B6 +:10A7000090F86420583001F0A8FFC8B120690123F7 +:10A71000042190F86520583001F09FFF30B10FE020 +:10A72000BDE8704001211720FEF798BD206990F820 +:10A730007C0028B1BDE8704000211220FEF78EBDDC +:10A74000206990F864200A2A2BD0002E18BF70BD13 +:10A7500001230021583001F080FF48B1206990F8B2 +:10A760008C11042904BF90F8900010F0030F22D040 +:10A7700020690123002190F86420583001F06DFF1A +:10A7800000287DD0206990F89A1111B190F89B11A2 +:10A79000E9B190F8A411002972D090F8A511E9B39D +:10A7A00092E090F8CA1080F8CC10BDE8704000210B +:10A7B0000720FEF753BD00210C20FEF74FFD206956 +:10A7C00090F8901041F0010180F8901070BDB0F841 +:10A7D0009C11A0F84010B0F89E11A0F84210B0F8FB +:10A7E000A011A0F84410B0F8A211A0F8461080F80B +:10A7F0009A5190F8660010F0200F13D0FFF736FE44 +:10A80000FFF704FE01211520FEF728FD206990F8CE +:10A81000661021F0200141F0100100E008E080F80E +:10A82000661070BDBDE8704000211420FEF716BD13 +:10A8300090F8652001230B21583001F00EFFF8B984 +:10A84000206990F85400012808BF012503D0022890 +:10A8500014BFFFDF0225206990F85500012808BFCA +:10A86000012603D0022814BFFFDF02262069012D34 +:10A8700090F8A61105D0022D08BF022903D00DE0E3 +:10A8800022E001290AD190F8A711012E04D0022E4E +:10A8900008BF02290BD001E0012908D090F86520FB +:10A8A00001230321583001F0D8FE68B903E00020ED +:10A8B000FDF7DCFF08E020690123022190F8652004 +:10A8C000583001F0CAFEB0B120690123002190F890 +:10A8D0006420583001F0C1FE002808BF70BD206917 +:10A8E00090F88401002808BF70BD0021BDE87040C9 +:10A8F000FF20FEF7B3BCBDE8704000211620FEF734 +:10A90000ADBC0000F000002030B5FB4C05462078BF +:10A91000002818BFFFDF657230BDF74901200872BB +:10A9200070472DE9F14FF54F39464E68304696F89D +:10A93000551001F042FF96F8551080B211F00C0F3F +:10A940006FF00D047FD0B0F5747F38BF002506D3BB +:10A950005038C11700EB916004EBA01085B2708EE7 +:10A96000A84238BF0546E648DFF88C93C9F82400B2 +:10A97000786800F15808834609F13400BBF832705A +:10A9800040689BF8551090F86AA0584601F015FFF2 +:10A990009BF8551080B211F00C0F5FD0B0F5747FAA +:10A9A00038BF002406D35038C21700EB926004EB86 +:10A9B000A01084B2A74238BF3C46BAF1000F1CBFBA +:10A9C000201D84B2E0B2F9F709FF98F812000028C0 +:10A9D0004FD008F15801CA4891E80E1000F50274F2 +:10A9E00084E80E10D8F86810C0F82112D8F86C105E +:10A9F000C0F8251200F58170FAF7A6FABF48007872 +:10AA000000280CBF0120002080F00101BD48017624 +:10AA1000D8E91412C0E90412A0F58372D9F8241001 +:10AA2000F9F7B5FD96F85500012808BF002204D0BB +:10AA300002281ABFFFDF00220122E9B20120F9F744 +:10AA4000B4FD1CE0FFE7022919BF04EBD00085B27A +:10AA50006FF00E0101EB900081D17FE7022919BF51 +:10AA600004EBD00084B26FF00E0202EB9000A1D193 +:10AA70009FE7D9F82400FAF767FAF9F7B9FD0098CB +:10AA800050B9012296F8553096211046FAF712F97E +:10AA900000219620FAF7A4FA96F82C00012808BFA6 +:10AAA000FAF730FB022089F80000BDE8F88F2DE9A5 +:10AAB000F04FDFF8488283B0414681464D68A1F1EE +:10AAC0001400009095F85D0005F158060127A1F1EA +:10AAD000340470B3012879D0022878D0032818BF35 +:10AAE000FFDF75D0206A0823017821F0080101708A +:10AAF000B27903EAC202114321F004010170F27934 +:10AB0000042303EA8202114321F01001017096F838 +:10AB100005B0E06AF5F70DFB8246FAF743FEBBF19C +:10AB2000020F7AD0BBF1010F78D0BBF1030F76D0C2 +:10AB30008AE0FFE700F0CAFB0146284601F03BFE31 +:10AB40001FFA80FB00F0C2FB10F00C0F6FF00D013C +:10AB50004FF0000A20D0BBF5747F38BF504607D3B2 +:10AB6000ABF15000C21700EB926001EBA01080B275 +:10AB7000298E814238BF0846ADF80800A5F8480084 +:10AB80000098FAF7EEFD90B1216AA77062694FF460 +:10AB90008060904703202CE0022819BF01EBDB0006 +:10ABA00080B26FF00E0000EB9B00E1D1DFE701AA5D +:10ABB00002A9E06AF5F7F8F9206210B196F83510AD +:10ABC00039B10098FAF7A1FD77718BE713E016E031 +:10ABD00026E09DF8041031B9A0F800A080F802A08A +:10ABE000012102F0A5F9BDF80810206A02F0DFFA91 +:10ABF0000220707176E70098FAF787FD72E7B5F8E2 +:10AC00004800ADF8000001AA6946E06AF5F7CCF902 +:10AC10002062002808BFFFDF64E708E00BE00EE0D9 +:10AC20000098FAF79EFD002808BFFFDF5AE730EAD8 +:10AC30000A0009D106E030EA0A0005D102E0BAF1C3 +:10AC4000000F01D0012100E00021206A027842EAD1 +:10AC500001110170717C00291CBF7179012933D069 +:10AC600006F15801264891E80E1000F5027A8AE8AC +:10AC70000E10B16EC0F82112F16EC0F8251200F569 +:10AC80008170FAF761F998F8000000280CBF0121E3 +:10AC900000211C480176D6E91212C0E90412A0F581 +:10ACA0008371226AF9F773FC95F85400012808BFF4 +:10ACB000002204D002281ABFFFDF00220122FB215C +:10ACC0000020F9F772FC03E0FAF73EF9F9F790FC7F +:10ACD000B9F1000F06D195F85430012296210020D9 +:10ACE000F9F7E8FF6771206A0188E18180782074B4 +:10ACF000277003B0BDE8F08F140100204801002048 +:10AD0000C80C0020D00E00202DE9F0471E46174643 +:10AD100081460C46FE4DDDF82080287828B9002FAA +:10AD20001CBF002EB8F1000F00D1FFDFC5F81C805A +:10AD3000C5E90576C5E90D9400272F72EF712F71D3 +:10AD4000EF706F71AF71AF70AF81F24E04F15808C0 +:10AD50002088F5F771FFE8622088F5F75BFF28632C +:10AD6000F9F759FD94F95700F9F702FE04F11200C2 +:10AD7000FAF7D3F804F10E00F9F704FE3078002852 +:10AD80000CBF03200120FAF7DCF898F81A00F9F755 +:10AD900001FEFAF7D0F83078002804BFFF2094F8BD +:10ADA000544023D098F81250B4F8328094F85510DB +:10ADB000204601F002FD94F8554080B214F00C0FCB +:10ADC0006FF00D012CD0B0F5747F06D35038C21748 +:10ADD00000EB926001EBA01087B24046B84528BF57 +:10ADE0003846002D1CBF001D80B2C0B22146F9F7C5 +:10ADF000F5FC3078F8B1706890F86801002818BF49 +:10AE0000F9F766FD224600210120F9F70CFF706872 +:10AE1000D0F8E000FAF79BF8BDE8F047012080E5A4 +:10AE2000022C19BF01EBD00087B26FF00E0101EBCD +:10AE30009000D2D1D0E7002122460846F9F7F3FE70 +:10AE4000BDE8F047012032E6B24800B50178343859 +:10AE5000007819B1022818BFFFDF00BD012818BF14 +:10AE6000FFDF00BDAA4810B50078022818BFFFDF39 +:10AE7000BDE8104000F080BA00F07EBAA4484079E6 +:10AE80007047A34800797047A14901208871704735 +:10AE90002DE9F04706009F489D4D406800F1580499 +:10AEA000686A90F8019018BF012E03D1296B08F051 +:10AEB00093FE6870687800274FF00108A0B1012860 +:10AEC0003CD0022860D003281CBFFFDFBDE8F0871C +:10AED000012E08BFBDE8F087286BF5F71FFB687AE5 +:10AEE000BDE8F047F0F752BF012E14D0A86A002841 +:10AEF00008BFFFDF6889C21CD5E9091009F058F9BD +:10AF0000A86A686201224946286BF5F783F9022E88 +:10AF100008BFBDE8F087D4E91401401C41F10001ED +:10AF2000C4E91401E079012801D1E77101E084F856 +:10AF30000780687ABDE8F047F0F728BF012E14D0EB +:10AF4000A86A002808BFFFDF6889C21CD5E909107C +:10AF500009F02EF9A86A686200224946286BF5F7C5 +:10AF600059F9022E08BFBDE8F087D4E91410491C36 +:10AF700040F10000C4E91410E07901280CBFE7712A +:10AF800084F80780BDE8F087012E06D0286BF5F71E +:10AF9000C5FA022E08BFBDE8F087D4E91410491C99 +:10AFA00040F10000C4E91410E0790128BFD1BCE7EA +:10AFB0002DE9F041574F3846A7F13404406800F1BD +:10AFC00058052078012818BFFFDFA878012648B16E +:10AFD0000021A970A6706269042090473878002883 +:10AFE00018BF2E71206A0321007831EA000004BFE7 +:10AFF000E878002805D1EE70216AA6706269022007 +:10B0000090470121002000F0D6F918B1BDE8F041C9 +:10B0100000F0B2B9BDE8F041002082E42DE9F14F23 +:10B020003C4E4FF000083046A6F1340540683178B8 +:10B0300000F1580A2878C146022818BFFFDFA88906 +:10B0400040F40070A88171683078FF2091F85410A6 +:10B05000F9F7C4FB009800289AF8120000F0FD8070 +:10B06000F9F7ECFAF9F7DAFA012788B99AF8120039 +:10B0700070B1686A417859B100789AF80710C0F346 +:10B08000C000884204D1EF70BDE8F84F00F074B9F9 +:10B09000686A41786981002908BFC5F8288003D013 +:10B0A000286BF5F771F8A862A88940F02000A88104 +:10B0B00085F804803078706800F1580B044690F8E9 +:10B0C0002C0001281AD1FAF713F85946204601F04E +:10B0D00080FA98B13078002870680CBF00F58A704B +:10B0E00000F5F570218841809BF8081001719BF8EC +:10B0F000091041710770687AF0F748FE686A9AF89B +:10B1000006100078C0F3800088423BD0307803E01E +:10B110001401002048010020706800F1580490F8E4 +:10B120005D0058B3022847D084F8058030780028A5 +:10B130001CBF2079002806D084F80480AF706A69AB +:10B14000414610209047E07890B184F80380FAF7E8 +:10B1500017FB002808BFFFDF0820AF706A690021D5 +:10B160009047D4E91202411C42F10000C4E91210D8 +:10B17000A07901280CBF84F80680A771A88940F443 +:10B180008070A881686A9AF807300178C1F3C0021C +:10B190009A424FD13278726801F0030102F15804EB +:10B1A000012918BF022932D003291CBFE87940F0D9 +:10B1B000040012D0E8713DE0E86AF4F721FF0028AE +:10B1C00008BFFFDFD4E91210491C40F10000C4E9B8 +:10B1D0001210687AF0F7DAFDA6E701F0C1FE90B12F +:10B1E000A770A989384641F40061A981696AAF70E6 +:10B1F0006A699047E079012803D100BF84F807808D +:10B2000018E0E77116E0E87940F01000D2E74078E6 +:10B21000F8B1A98941F40061A981A96A51B1FB285B +:10B22000F1D8287A002808BFB94603D080206A697F +:10B23000002190470120009900F0BDF8B0B1B9F1AC +:10B24000000F1CBF0020FFF723FEBDE8F84F00F001 +:10B2500093B8E0790128D4D1D0E7002818BFF9F7D6 +:10B2600026FAA88940F04000A881E3E7B9F1000F71 +:10B270001CBF0120FFF70CFE0020FFF718FCB9F1FE +:10B28000000F08BFBDE8F88F0220BDE8F84FFFE5CA +:10B2900070B50D4606466848674900784C6850B15D +:10B2A000F9F748FA034694F8542029463046BDE899 +:10B2B0007040FDF72CBAF9F73DFA034694F8542094 +:10B2C00029463046BDE8704005F00ABD5A4802786C +:10B2D0004168406801F1580C91F8643090F85400CE +:10B2E000242B1CBF9CF80DC0BCF1240F13D01F2BC6 +:10B2F00018BF202B24D0BCF1220F18BF7047002AA2 +:10B3000008BF704791F8A62191F85110114011F033 +:10B31000010F27D02EE04AB191F89011002908BF03 +:10B320007047012818BF012924D021E091F8F210BC +:10B33000002908BF7047012818BF01291AD017E05B +:10B34000BCF1220FDBD0002A08BF704791F8A6118C +:10B3500011F0010F0ED111F0020F08BF7047012844 +:10B3600008D005E011F0020F08BF7047012801D096 +:10B3700002207047012070472F4910B54C68F9F73B +:10B3800089FEF9F768FEF9F763FDF9F7CCFDF9F7E7 +:10B390002FF994F82C00012808BFF9F7A9FE274CD3 +:10B3A00000216269A0899047E269E179E0789047DD +:10B3B0000020207010BD70B5204C0546002908BF44 +:10B3C000012D05D12079401CC0B22071012831D84F +:10B3D000A1692846884700282CD0A179184839B19E +:10B3E000012D01BF41780029017811F0100F21D003 +:10B3F000E179F9B910490978002908BF012D05D074 +:10B4000000290CBF01210021294311D10D490978E0 +:10B4100011F0100F04BF007810F0100F0AD0A078C0 +:10B4200040B9A06A20B9608910B111F0100F01D0A5 +:10B43000002070BD012070BD4801002014010020D3 +:10B44000C80C00202201002010B540F2C311F748BB +:10B4500008F02DFFFF220821F54808F020FFF548ED +:10B46000002141704FF46171418010BD2DE9F04120 +:10B470000E46054600F046FBEC4C102816D004EBB7 +:10B48000C00191F84A0110F0010F1CBF0120BDE876 +:10B49000F081607808283CBF012081F84A011CD265 +:10B4A0006078401C60700120BDE8F0816078082859 +:10B4B00013D222780127501C207004EBC208306898 +:10B4C000C8F84401B088A8F84801102A28BFFFDF57 +:10B4D00088F8435188F84A71E2E70020BDE8F0811E +:10B4E000D2480178491E4BB2002BB8BF704770B4E8 +:10B4F0005FF0000500EBC30191F84A1111F0010F54 +:10B500003BD04278D9B2521E427000EBC10282F8A1 +:10B510004A5190F802C00022BCF1000F0BD98418E8 +:10B5200094F803618E4202D1102A26D103E0521C06 +:10B53000D2B29445F3D80278521ED2B202708A4237 +:10B540001BD000EBC20200EBC10CD2F84341CCF897 +:10B550004341D2F84721CCF84721847890F800C0C5 +:10B560000022002C09D9861896F8036166450AD195 +:10B57000102A1CBF024482F80311591E4BB2002B43 +:10B58000B8DA70BC7047521CD2B29442EBD8F4E7E0 +:10B590002DE9F05F1F4690460E46814600F0B2FA54 +:10B5A000A24D0446102830D0A878002100280ED9DA +:10B5B0006A1892F80331A34205D110291CBF12204A +:10B5C000BDE8F09F03E0491CC9B28842F0D80828C2 +:10B5D00034D2102C1CD0AE781022701CA87005EB51 +:10B5E000061909F10300414600F0A2FF09F18300AA +:10B5F0001022394600F09CFFA819002180F8034171 +:10B6000080F83B110846BDE8F09FA878082815D2BD +:10B610002C78CA46601C287005EBC4093068C9F84C +:10B620004401B0884FF0000BA9F84801102C28BF46 +:10B63000FFDF89F843A189F84AB1CCE70720BDE8CC +:10B64000F09F70B479488178491E4BB2002BBCBF83 +:10B6500070BC704703F0FF0C8178491ECAB282703B +:10B6600050FA83F191F8031194453ED000EB021596 +:10B6700000EB0C14D5F80360C4F80360D5F807603C +:10B68000C4F80760D5F80B60C4F80B60D5F80F60FC +:10B69000C4F80F60D5F88360C4F88360D5F887607C +:10B6A000C4F88760D5F88B60C4F88B60D5F88F50EC +:10B6B000C4F88F50851800EB0C0402EB420295F899 +:10B6C00003610CEB4C0C00EB420284F8036100EBCD +:10B6D0004C0CD2F80B61CCF80B61B2F80F21ACF82E +:10B6E0000F2195F83B2184F83B2100EBC10292F831 +:10B6F0004A2112F0010F33D190F802C00022BCF1B0 +:10B70000000F0BD9841894F803518D4202D1102AEE +:10B7100026D103E0521CD2B29445F3D80278521ECF +:10B72000D2B202708A421BD000EBC20200EBC10C05 +:10B73000D2F84341CCF84341D2F84721CCF8472115 +:10B74000847890F800C00022002C09D9851895F85B +:10B75000035165450BD1102A1CBF024482F8031126 +:10B76000591E4BB2002BBFF675AF70BC7047521C10 +:10B77000D2B29442EAD8F3E72E49487070472D4878 +:10B780004078704738B14AF2B811884203D8294945 +:10B790004880012070470020704726484088704745 +:10B7A00010B500F0AFF9102814D0204A014600204F +:10B7B00092F802C0BCF1000F0CD9131893F80331B2 +:10B7C0008B4203D1102818BF10BD03E0401CC0B24B +:10B7D0008445F2D8082010BD14498A78824286BF79 +:10B7E00001EB001083300020704710498A788242B4 +:10B7F00086BF01EB0010C01C002070470B4B93F874 +:10B8000002C084459CBF00207047184490F8030193 +:10B8100003EBC00090F843310B70D0F84411116075 +:10B82000B0F848019080012070470000F80E002019 +:10B830005A01002050010020FE4A114491F80321D2 +:10B84000FD490A7002684A6080880881704710B517 +:10B85000F8F74CFE002804BFFF2010BDBDE81040E3 +:10B86000F8F76ABEF3498A7882429CBF002070478D +:10B87000084490F8030101EBC00090F84A0100F081 +:10B88000010070472DE9F047EA4F0026B0463878AE +:10B89000002886BF4FF0080ADFF8A093BDE8F087C4 +:10B8A00007EBC80505F5A27195F8430100F02AF9E8 +:10B8B000102808BF544610D0B978002400290BD9AD +:10B8C0003A1992F80321824202D1102C05D103E0EB +:10B8D000621CD4B2A142F3D80824B878A04286BF33 +:10B8E00007EB0410C01C002095F84A1111F0010F5D +:10B8F00016D050B1082C04D2391991F83B11012906 +:10B9000003D0102100F0F1FD50B109F80640304697 +:10B91000731C95F8432105F5A271DEB2F9F700F822 +:10B9200008F1010000F0FF0838784045B8D8BDE8BC +:10B93000F0872DE9F041BF4C00263546A07800285D +:10B940008CBFBE4FBDE8F0816119C0B291F8038190 +:10B95000A84286BF04EB0510C01C002091F83B11E3 +:10B96000012903D0102100F0C0FD58B104EBC8003C +:10B97000BD5590F8432100F5A2713046731CDEB22C +:10B98000F8F7CEFF681CC5B2A078A842DCD8BDE8A5 +:10B99000F08110B5F8F7EEFF002804BF082010BDB5 +:10B9A000F8F7ECFFA549085C10BD0A46A24910B59E +:10B9B000497841B19F4B997829B10244D81CF8F7D6 +:10B9C00032FD012010BD002010BD9A4A01EB41015B +:10B9D00002EB41010268C1F80B218088A1F80F0138 +:10B9E00070472DE9F041934D07460024A8780028C0 +:10B9F00098BFBDE8F081C0B2A04213D905EB041096 +:10BA000010F183060ED01021304600F06EFD48B9CB +:10BA100004EB440005EB400000F20B113A463046BF +:10BA2000F9F73DFF601CC4B2A878A042E3D8BDE896 +:10BA3000F08101461022824800F07ABD80487047AC +:10BA400070B57C4D0446A878A04206D905EB0410D9 +:10BA50001021833000F049FD08B1002070BD04EBD7 +:10BA6000440005EB400000F20B1070BD71498A786C +:10BA7000824206D9084490F83B01002804BF012007 +:10BA80007047002070472DE9F0410E4607461546E5 +:10BA90000621304600F029FD664C98B1A17871B1BD +:10BAA00004F59D7011F0010F18BF00F8015FA17837 +:10BAB000490804D0457000F8025F491EFAD1012000 +:10BAC000BDE8F0813846314600F01CF8102816D049 +:10BAD000A3780021002B12D9621892F80321824228 +:10BAE00009D1102918BF082909D0601880F83B51E6 +:10BAF0000120BDE8F081491CC9B28B42ECD800207E +:10BB0000BDE8F0812DE9F0414A4D06460024287831 +:10BB10000F46002812D900BF05EBC40090F843116E +:10BB2000B14206D10622394600F5A27008F014FB96 +:10BB300038B1601CC4B22878A042EDD81020BDE80E +:10BB4000F0812046BDE8F0813A4910B44A7801EB13 +:10BB5000C003521E4A70002283F84A2191F802C0A5 +:10BB6000BCF1000F0DD98B1893F80341844204D126 +:10BB7000102A1CBF10BC704703E0521CD2B294457F +:10BB8000F1D80A78521ED2B20A70824204BF10BCA9 +:10BB9000704701EBC00301EBC202D2F843C1C3F806 +:10BBA00043C1D2F84721C3F847218C7891F800C0EF +:10BBB0000022002C9CBF10BC70478B1893F80331F7 +:10BBC000634506D1102A1CBF114481F8030110BC43 +:10BBD0007047521CD2B29442EFD810BC704770B478 +:10BBE00014490D188A78521ED3B28B7095F8032130 +:10BBF000984247D001EB031C01EB0014DCF8036012 +:10BC0000C4F80360DCF80760C4F80760DCF80B6078 +:10BC1000C4F80B60DCF80F60C4F80F60DCF88360D8 +:10BC2000C4F88360DCF88760C4F88760DCF88B6058 +:10BC300008E00000F80E0020500100205A0100200A +:10BC4000BB100020C4F88B60DCF88FC0C4F88FC034 +:10BC500001EB030C03EB43039CF8034100EB4000B2 +:10BC600001EB430385F8034101EB4000D3F80B419E +:10BC7000C0F80B41B3F80F31A0F80F319CF83B012D +:10BC800085F83B0101EBC20090F84A0110F0010F6A +:10BC90001CBF70BC704700208C78002C0DD90B188D +:10BCA00093F803C1944504D110281CBF70BC7047A1 +:10BCB00003E0401CC0B28442F1D80878401EC0B2F4 +:10BCC0000870904204BF70BC704701EBC20301EBE7 +:10BCD000C000D0F843C1C3F843C1D0F84701C3F84E +:10BCE00047018C780B780020002C9CBF70BC7047FB +:10BCF00001EB000C9CF803C19C4506D110281CBF29 +:10BD0000084480F8032170BC7047401CC0B28442D4 +:10BD1000EED870BC7047000010B50A7B02F01F021D +:10BD20000A73002202768B181B7A03F0010C5B0861 +:10BD300003F00104A4445B0803F00104A4445B087D +:10BD400003F00104A4445B0803F0010464444FEAD7 +:10BD5000530C0CF0010323444FEA5C0C0CF001047B +:10BD6000234403EB5C0300EB020C521C8CF81330F1 +:10BD700090F818C0D2B263440376052AD3D3D8B260 +:10BD8000252888BFFFDF10BD0023C383428401EB59 +:10BD9000C202521EB2FBF1F10184704770B46FF021 +:10BDA0001F02010C02EA90251F23A1F5AA40543876 +:10BDB0001CBFA1F5AA40B0F1550009D0A1F528504B +:10BDC000AA381EBFA1F52A40B0F1AA00012000D177 +:10BDD00000204FF0000C62464FEA0C048CEA01068A +:10BDE000F6431643B6F1FF3F11D005F001064FEAC6 +:10BDF0005C0C4CEAC63C03F0010652086D085B0877 +:10BE0000641C42EAC632162CE8D370BC704770BC82 +:10BE1000002070472DE9F04701270025044603293B +:10BE20000FD04FF4FA4200297CD0012900F006819E +:10BE3000022918BFBDE8F0870146BDE8F047583039 +:10BE40006AE704F158067821304608F052FAB571D5 +:10BE5000F57135737573F573357475717576B576DF +:10BE6000212086F83E00412086F83F00FE2086F81B +:10BE7000730084F82C50258484F8547084F855702D +:10BE8000282084F856001B20208760874FF4A47078 +:10BE9000E087A0871B20208660864FF4A470E08690 +:10BEA000A0861B20A4F84000A4F844004FF4A4701E +:10BEB000A4F84600A4F842001B20A4F84A00A4F805 +:10BEC0004C00A4F8480067734FF448606080A4F801 +:10BED000D050A4F8D250A4F8D450A4F8D650A4F866 +:10BEE000D850A4F8DA5084F8DD5084F8DF50A4F874 +:10BEF000E65084F8E450A4F8F850A4F8FA5084F816 +:10BF00009A5184F89B5184F8A45184F8A55184F87F +:10BF1000695184F8705184F8735184F88C51BDE8EC +:10BF2000F087FFE7A4F8E65084F8DE506088FE4909 +:10BF30000144B1FBF0F1A4F878104BF68031A4F87D +:10BF40007A10E388A4F87E50B4F882C0DB000CFBC2 +:10BF500000FCB3FBF0F39CFBF0FC5B1CA4F882C07C +:10BF60009BB203FB00FC04F15801A4F88030BCF53F +:10BF7000C84FC4BF5B1E0B85B2FBF0F2521CCA85D2 +:10BF800000F5802202F5EE32531EB3FBF0F20A8474 +:10BF9000CB8B03FB00F2B2FBF0F0C883214604F127 +:10BFA0005800FFF7B9FE07F0A5F9E8B3D4F80E1072 +:10BFB0006FF01F02080C02EA91281F26A0F5AA4183 +:10BFC00054391CBFA0F5AA41B1F155010AD0A0F522 +:10BFD0002851AA391EBFA0F52A41B1F1AA014FF09C +:10BFE000010901D14FF00009002211464FEA020C6D +:10BFF00082EA0003DB430B43B3F1FF3F1AD008F0A2 +:10C000000103520842EAC33206F0010349087608E8 +:10C010000CF1010C41EAC3314FEA5808BCF1160F8C +:10C02000E6D3B9F1000F00E000E003D084F86851D6 +:10C03000BDE8F08784F86871BDE8F087A4F8E650A1 +:10C04000B4F89401B4F89831B4F802C004F158017E +:10C05000A4F87E50B4F88240DB0004FB0CF4B3FB80 +:10C06000F0F394FBF0F45B1C4C859BB203FB00F4F3 +:10C070000B85B4F5C84FC4BF5B1E0B85B2FBF0F255 +:10C08000521CCA854A8C00EBC202521EB2FBF0F26F +:10C090000A84CA8B02FB0CF2B2FBF0F0C883BDE845 +:10C0A000F08770B50025044603290DD04FF4FA42FD +:10C0B000002963D001297DD0022918BF70BD014637 +:10C0C000BDE87040583027E604F158067821304624 +:10C0D00008F00FF9B571F57135737573F573357433 +:10C0E00075717576B576212086F83E00412086F878 +:10C0F0003F00FE2086F8730084F82C502584012030 +:10C1000084F8540084F85500282184F856101B2127 +:10C11000218761874FF4A471E187A1871B212186C4 +:10C1200061864FF4A471E186A1861B21A4F840101A +:10C13000A4F844104FF4A471A4F84610A4F84210D7 +:10C140001B21A4F84A10A4F84C10A4F848106073FE +:10C15000A4F8D850202084F8DA0084F8D050C4F82D +:10C16000D45084F8045184F8055184F80E5184F8B1 +:10C170000F5184F8F45084F8005170BD60886A490A +:10C180000144B1FBF0F1A4F878104BF68031A4F82B +:10C190007A10E388A4F87E50B4F882C0DB000CFB70 +:10C1A00000FC9CFBF0FCB3FBF0F304F15801A4F895 +:10C1B00082C000E022E05B1C9BB203FB00FCA4F801 +:10C1C0008030BCF5C84FC4BF5B1E0B85B2FBF0F2DC +:10C1D000521CCA8500F5802202F5EE32531EB3FBD5 +:10C1E000F0F20A84CB8B03FB00F2B2FBF0F0C883C1 +:10C1F000214604F15800BDE870408DE5D4F8F830D0 +:10C20000B4F802C004F158005989DB89A4F87E50C3 +:10C21000B4F88240DB0004FB0CF4B3FBF1F394FBB5 +:10C22000F1F45B1C44859BB203FB01F40385B4F578 +:10C23000C84FC4BF5B1E0385B2FBF1F2521CC2851E +:10C24000428C01EBC202521EB2FBF1F20284C28B9D +:10C2500002FB0CF2B2FBF1F1C18370BD2DE9F003DA +:10C26000047E0CB1252C03D9BDE8F00312207047E1 +:10C27000002A02BF0020BDE8F003704791F80DC00E +:10C280001F260123294D4FF00008BCF1000F77D085 +:10C29000BCF1010F1EBF1F20BDE8F0037047B0F8CE +:10C2A00000C00A7C8F7B91F80F907A404F7C87EA20 +:10C2B000090742EA072282EA0C0C00270CF0FF096A +:10C2C0004FEA1C2C99FAA9F99CFAACFC4FEA1969BF +:10C2D0004FEA1C6C49EA0C2C0CEB0C1C7F1C9444A0 +:10C2E000FFB21FFA8CFC032FE8D38CEA020C0F4F2D +:10C2F0000022ECFB057212096FF0240502FB05C257 +:10C30000D2B201EBD207427602F007053F7A03FA78 +:10C3100005F52F4218BF82767ED104FB0CF2120C79 +:10C32000521CD2B2002403E0FFDB050053E4B36EDD +:10C3300000EB040C9CF813C094453CBFA2EB0C022C +:10C34000D2B212D30D194FF0000C2D7A03FA0CF76C +:10C350003D421CBF521ED2B2002A6AD00CF1010C21 +:10C360000CF0FF0CBCF1080FF0D304F1010C0CF041 +:10C37000FF04052CD7D33046BDE8F0037047FFE734 +:10C3800090F819C00C7E474604FB02C2FA4C4FF0ED +:10C39000000CE2FB054C4FEA1C1C6FF024040CFB64 +:10C3A0000422D2B201EBD204427602F0070C247AC6 +:10C3B00003FA0CFC14EA0C0F1FBF82764046BDE85E +:10C3C000F003704790F818C0B2FBFCF40CFB142289 +:10C3D000521CD2B25FF0000400EB040C9CF813C0B6 +:10C3E00094453CBFA2EB0C02D2B212D30D194FF010 +:10C3F000000C2D7A03FA0CF815EA080F1CBF521E28 +:10C40000D2B27AB10CF1010C0CF0FF0CBCF1080FA8 +:10C41000F0D304F1010C00E00EE00CF0FF04052C59 +:10C42000DAD3A8E70CEBC40181763846BDE8F00307 +:10C4300070470CEBC40181764046BDE8F0037047BD +:10C44000CE4A016812681140CD4A1268114301605A +:10C45000704730B4CB49C94B00244FF0010C0A7827 +:10C46000521CD2B20A70202A08BF0C700D781A68CC +:10C470000CFA05F52A42F2D0097802680CFA01F1AB +:10C480005140016030BC7047017931F01F0113BF8A +:10C49000002000221146704710B4435C491C03F091 +:10C4A000010C5B0803F00104A4445B0803F00104E1 +:10C4B000A4445B0803F00104A4445B0803F00104F6 +:10C4C000A4445B0803F001045B08A44403F00104E6 +:10C4D000A4440CEB53031A44D2B20529DDDB012A34 +:10C4E0008CBF0120002010BC704730B40022A1F1A5 +:10C4F000010CBCF1000F11DD431E11F0010F08BF4C +:10C5000013F8012F5C785FEA6C0C07D013F8025F18 +:10C5100022435C782A43BCF1010CF7D1491E5CBF71 +:10C52000405C0243002A0CBF0120002030BC704751 +:10C53000130008BF704710B401EB030CD41A1CF8A9 +:10C5400001CC5B1E00F804C013F0FF03F4D110BC53 +:10C550007047F0B58DB0164610251C466A46AC46AD +:10C5600000EB0C03A5EB0C0713F8013CD355ACF121 +:10C57000010313F0FF0CF3D115461032102084464E +:10C580000B18ACEB000713F8013C401ED35510F01C +:10C59000FF00F5D1284606F02FFD86B1102005F1E9 +:10C5A000200201461318A1EB000C13F8013C401EB9 +:10C5B00004F80C3010F0FF00F4D10DB0F0BD089875 +:10C5C0002060099860600A98A0600B98E0600DB048 +:10C5D000F0BD38B505460C466846F8F79EFD0028C4 +:10C5E00008BF38BD9DF900202272A07E607294F9C8 +:10C5F0000A100020511A48BF494295F82D308B424D +:10C60000C8BF38BDFF2B08BF38BDE17A491CC9B28D +:10C61000E17295F82E30994203D8A17A7F2918BF8C +:10C6200038BDA2720020E072012038BD0C2818BF6E +:10C630000B2810D00D2818BF1F280CD0202818BF99 +:10C64000212808D0222818BF232804D024281EBF60 +:10C65000262800207047012070470C2963D2DFE8AC +:10C6600001F006090E13161B323C415C484E002AAD +:10C670005BD058E0072A18BF082A56D053E00C2A8E +:10C6800018BF0B2A51D04EE00D2A4ED04BE0A2F13C +:10C690000F000C2849D946E023B1A2F110000B2865 +:10C6A00043D940E0122A18BF112A3ED090F8360034 +:10C6B00020B1122A37D31A2A37D934E0162A32D3B6 +:10C6C0001A2A32D92FE0A2F10F0103292DD990F8AF +:10C6D000360008B31B2A28D925E0002B08BF042AFE +:10C6E00021D122E013B1062A1FD01CE0012A1AD161 +:10C6F0001BE01C2A1CBF1D2A1E2A16D013E01F2A6D +:10C7000018BF202A11D0212A18BF222A0DD0232A8F +:10C710001CBF242A262A08D005E013B10E2A04D013 +:10C7200001E0052A01D000207047012070472DE963 +:10C73000F04187680D4604462046F6F736FC98B16E +:10C7400015B33846A168F6F771FF00281CDD2844B0 +:10C75000401EB0FBF5F606FB05F13846F5F761FF24 +:10C76000A0603046BDE8F081F6F752FA40F233712E +:10C77000F5F757FFA060DFE753E4B36EA44802006B +:10C78000A8480200620100200020BDE8F08190422C +:10C7900028BF704770B50446101B642838BF64205A +:10C7A00025188D4205D8F6F774FF00281CBF2846CF +:10C7B00070BD204670BD808E7047C08E70470844A3 +:10C7C00018449830002A14BF0421002108447047FF +:10C7D00030B491F854300A8E13F00C0F4FF4747C7F +:10C7E0001CBF0CEB821292B21DD08B8E934238BFCD +:10C7F0001A464B8E91F8554014F00C0F1CBF0CEBF1 +:10C8000083139BB217D0C98E994238BF0B460028BC +:10C810000CBF01200020D1189831002818BF042037 +:10C82000084430BC7047022B07BF92003C32D20054 +:10C83000703292B2D9E7022C07BF9B003C33DB0079 +:10C8400070339BB2DFE710F0010F1CBF012070476F +:10C8500010F0020F1CBF0220704710F0040018BF38 +:10C86000082070472DE9F041054617468846012605 +:10C87000084600F06EFC0446404600F06EFC03469D +:10C8800010F0010F18BF012008D113F0020F18BFDC +:10C89000022003D113F0040018BF082014F0010F88 +:10C8A00018BF4FF0010C20D050EA0C0108BF002641 +:10C8B00013F0030F08BF002014F0030F08BF4FF060 +:10C8C000000C95F85410814208BF0020387095F88C +:10C8D0005510614508BF4FF0000C87F801C00028D3 +:10C8E00008BFBCF1000F1CD10DE014F0020F18BFFF +:10C8F0004FF0020CD8D114F0040F14BF4FF0080C05 +:10C900004FF0000CD0E7404600F02DFCB5F8581071 +:10C91000401A00B247F6FE71884201DC002800DCB4 +:10C9200000263046BDE8F08101281CBF0228002007 +:10C93000704718B4CBB2C1F3072CC1B2C0F30720C3 +:10C94000012B05D0022B08BFBCF1020F1BD002E067 +:10C95000BCF1010F17D0012904D0022908BF022819 +:10C9600011D001E001280ED001EA0C0161F30702A9 +:10C9700010EA030060F30F22D0B210F0020F18BFCC +:10C9800002200BD106E0084003EA0C01084060F3E6 +:10C990000702EFE710F0010018BF01208DF800003A +:10C9A000C2F3072010F0020F18BF022003D110F0CD +:10C9B000010018BF01208DF80100BDF8000018BC6F +:10C9C0007047162A10D12A220C2818BF0D280FD024 +:10C9D0004FF0230C1F280DD031B10878012818BF63 +:10C9E000002805D0162805D0002070470120704788 +:10C9F0001A70FBE783F800C0F8E7012902D002298A +:10CA000005D007E0002804BF40F2E240704740F63E +:10CA1000C410704700B5FFDF40F2E24000BD0000E7 +:10CA2000282107F044BC4078704730B505460078AF +:10CA300001F00F0220F00F0010432870092910D2D6 +:10CA4000DFE801F0050705070509050B0D000624C1 +:10CA500009E00C2407E0222405E0012403E00E2471 +:10CA600001E00024FFDF6C7030BD007800F00F00A3 +:10CA700070470A68C0F803208988A0F8071070473B +:10CA8000D0F803200A60B0F80700888070470A6871 +:10CA9000C0F809208988A0F80D107047D0F8092047 +:10CAA0000A60B0F80D00888070470278402322F0B9 +:10CAB000400203EA81111143017070470078C0F30E +:10CAC000801070470278802322F0800203EAC111AF +:10CAD0001143017070470078C0097047027802F076 +:10CAE0000F02072A16BF082AD0F80520D0F8032025 +:10CAF000C1F809200CBFB0F80920B0F80720A1F850 +:10CB00000D200A7822F080020A700078800942EA3B +:10CB1000C0100870704770B514460E4605461F2AAF +:10CB200088BFFFDF2246314605F1090007F040FBD0 +:10CB3000A01D687070BD70B544780E460546062C81 +:10CB400038BFFFDFA01F84B21F2C88BF1F242246DE +:10CB500005F10901304607F02BFB204670BD70B58A +:10CB600014460E4605461F2A88BFFFDF224631467F +:10CB700005F1090007F01CFBA01D687070BD70B5C1 +:10CB800044780E460546062C38BFFFDFA01F84B24E +:10CB90001F2C88BFFFDF224605F10901304607F050 +:10CBA00007FB204670BD0968C0F80F1070470A885F +:10CBB000A0F8132089784175704790F8242001F07F +:10CBC0001F0122F01F02114380F82410704707292B +:10CBD00088BF072190F82420E02322F0E00203EA36 +:10CBE0004111114380F8241070471F3007F096BCA4 +:10CBF00010B5044600F0E3FA002818BF204410BD29 +:10CC0000C17811F03F0F1BBF027912F0010F002213 +:10CC1000012211F03F0F1BBF037913F0020F002315 +:10CC200001231A4402EB4202530011F03F0F1BBFD5 +:10CC3000027912F0080F0022012203EB420311F0E7 +:10CC40003F0F1BBF027912F0040F00220122134490 +:10CC500011F03F0F1BBF027912F0200F00220122BA +:10CC600002EBC20203EB420311F03F0F1BBF02793C +:10CC700012F0100F0022012202EB42021A4411F0BE +:10CC80003F0F1BBF007910F0400F0020012010441F +:10CC900010F0FF0014BF012100210844C0B270470A +:10CCA00070B50278417802F00F02082A4DD2DFE811 +:10CCB00002F004080B4C4C4C0F14881F1F280AD993 +:10CCC00043E00C2907D040E0881F1F2803D93CE02F +:10CCD000881F1F2839D8012070BD4A1E242A34D845 +:10CCE0008446C07800258209032A09D000F03F0459 +:10CCF000601C884204D86046FFF782FFA04201D939 +:10CD0000284670BD9CF803004FF0010610F03F0F5D +:10CD10001EBF1CF10400007810F0100F13D0644601 +:10CD20000421604600F04BFA002818BF14EB000005 +:10CD3000E6D0017801F03F012529E1D28078022177 +:10CD4000B1EB501FDCD3304670BD002070BDC07801 +:10CD5000800970470178002201F00F030121042BA4 +:10CD60000BD0082B1CBF0020704743780E2B04BF4C +:10CD7000C3785FEA931C04D106E04078801F1F2827 +:10CD800000D911460846704713F03F0F1EBF0079C7 +:10CD900010F0010F10F0020FF4D1F2E710B4017897 +:10CDA00001F00F01032920D0052921D14478B0F8E2 +:10CDB0001910B0F81BC0B0F81730827D222C17D1A3 +:10CDC000062915D3B1F5486F98BFBCF5FA7F0FD28D +:10CDD00072B1082A98BF8A420AD28B429CBFB0F82F +:10CDE0001D00B0F5486F03D805E040780C2802D04C +:10CDF00010BC0020704710BC012070472DE9F041A5 +:10CE00001F4614460D00064608BFFFDF2146304688 +:10CE100000F0D5F9040008BFFFDF30193A46294673 +:10CE2000BDE8F04107F0C4B9C07800F03F0070479A +:10CE3000C02202EA8111C27802F03F021143C170A0 +:10CE40007047C9B201F00102C1F340031A4402EB7A +:10CE50004202C1F3800303EB4202C1F3C00302EBC1 +:10CE60004302C1F3001303EB43031A44C1F340131D +:10CE700003EBC30302EB4302C1F380131A4412F025 +:10CE8000FF0202D0521CD2B20171C37802F03F01FE +:10CE900003F0C0031943C170511C417070472DE964 +:10CEA000F0410546C078164600F03F04C4F1240066 +:10CEB0000F46B042B8BFFFDF281932463946001D81 +:10CEC00007F076F9A019401C6870BDE8F0812DE9E3 +:10CED000F04105464478C0780F4600F03F06002C2C +:10CEE00008BFFFDFA01B401E84B21F2C88BF1F2479 +:10CEF0002FB1A819011D2246384607F059F92046DE +:10CF0000BDE8F0814078704700B5027801F0030376 +:10CF100022F003021A430270012914BF02290021E2 +:10CF200004D0032916BFFFDF012100BD417000BD01 +:10CF300000B5027801F0030322F003021A430270E5 +:10CF4000012914BF0229002104D0032916BFFFDFE5 +:10CF5000012100BD417000BD007800F00300704762 +:10CF6000417889B1C0780E2818BF0F2803D0102847 +:10CF700018BF192802D3FB2904D905E0BF4A105C69 +:10CF8000884201D1012070470020704730B501244C +:10CF90000546C17019293CBFB848445C02D3FF293B +:10CFA00018BFFFDF6C7030BD70B515460E460446E5 +:10CFB0001B2A88BFFFDF65702A463146E01CBDE8AA +:10CFC000704007F0F5B8B0F807007047B0F80900F6 +:10CFD0007047C172090A01737047B0F80B007047BF +:10CFE00030B4B0F80720A64DB0F809C0B0F805304D +:10CFF0000179941F2D1998BFBCF5FA7F0ED269B143 +:10D00000082998BF914209D293429FBFB0F80B0004 +:10D01000B0F5486F012030BC98BF7047002030BC8D +:10D020007047001D07F07ABA021D0846114607F046 +:10D0300075BAB0F809007047007970470A68426015 +:10D0400049688160704742680A608068486070473C +:10D050000988818170478089088070470A68C0F814 +:10D060000E204968C0F812107047D0F80E200A60F0 +:10D07000D0F81200486070470968C0F81610704771 +:10D08000D0F81600086070470A68426049688160FD +:10D09000704742680A608068486070470968C160EC +:10D0A0007047C06808607047007970470A6842603E +:10D0B00049688160704742680A60806848607047CC +:10D0C0000171090A417170478171090AC171704784 +:10D0D0000172090A417270478172090AC172704770 +:10D0E00080887047C08870470089704740897047C2 +:10D0F00001891B2924BF4189B1F5A47F07D3818809 +:10D100001B2921BFC088B0F5A47F012070470020F3 +:10D1100070470A68426049688160704742680A60E7 +:10D12000806848607047017911F0070F1BBF407994 +:10D1300010F0070F002001207047017911F0070F50 +:10D140001BBF407910F0070F0020012070470171CC +:10D15000704700797047417170474079704781711D +:10D16000090AC1717047C088704746A282B0D2E9EF +:10D170000012CDE900120179407901F007026946F9 +:10D180001DF80220012A07D800F00700085C0128DA +:10D190009EBF012002B07047002002B070470171AD +:10D1A000704700797047417170474079704730B5DA +:10D1B0000C460546FB2988BFFFDF6C7030BDC37885 +:10D1C000024613F03F0008BF70470520127903F0B4 +:10D1D0003F0312F0010F36D0002914BF0B20704717 +:10D1E00012F0020F32D0012914BF801D704700BF1A +:10D1F00012F0040F2DD0022914BF401C704700BF4D +:10D2000012F0080F28D0032914BF801C704700BFFC +:10D2100012F0100F23D0042914BFC01C704700BFA8 +:10D2200012F0200F1ED005291ABF1230C0B270476D +:10D2300012F0400F19D006291ABF401CC0B2704727 +:10D24000072918D114E00029CAD114E00129CFD14F +:10D2500011E00229D4D10EE00329D9D10BE0042931 +:10D26000DED108E00529E3D105E00629E8D102E096 +:10D27000834288BF7047002070470000AC4802001E +:10D2800086F3FFFF00010102010202032DE9F041D4 +:10D29000FA4D0446284600216A78806801270E4628 +:10D2A00012B1012A1ED006E090F86620002A18BFAD +:10D2B0006F7000D001216A78C2EB421200EB42028B +:10D2C00092F82830194324D0667090F8D90002F102 +:10D2D0002A0170B12A22201D06F06AFF0420207066 +:10D2E00027710DE090F82820002A18BF6E70E1D158 +:10D2F000E1E73C22201D06F05BFF0520207027712E +:10D300006878A968C0EB401001EB400080F8286005 +:10D310001DE090F8A410E9B190F8D900012818BFD9 +:10D32000FFDFA868D0F8A5106160D0F8A910A1604F +:10D33000D0F8AD10E160D0F8B110216190F8B510CF +:10D340002175667013212170277180F8A460012077 +:10D35000BDE8F08190F82210012922D0017801293E +:10D360001CBF0020BDE8F081667014212170811C73 +:10D370002022201D06F01CFF2672A9680E70C048EE +:10D3800082888284D0F8C420527B80F8262080F8DE +:10D390002270D1F8C4000088F3F73CFCF3F7E3F8FF +:10D3A000D5E7667007212170416A616080F82260CC +:10D3B000CDE7B24880680178002914BF80884FF615 +:10D3C000FF7070472DE9F84F4FF000088946064678 +:10D3D0000127CDF80080FFF748FBBDF80010A74DEE +:10D3E00021F06004ADF8004008284FD2DFE800F0DB +:10D3F00004070D4E184E132C44F003000DE044F0CA +:10D400001500ADF80000474641E044F0100000BFB1 +:10D41000ADF800003BE044F0020040F01000F7E7F8 +:10D42000A86890F8E000052818BFFFDF44F01A0054 +:10D43000ADF80000A96891F8E710002914BF40F08A +:10D44000010020F00100E3E7A86890F8E01003294C +:10D450000AD090F8E010062958D090F8E00004288F +:10D4600018BFFFDF5FD012E03046FFF770FC0028E6 +:10D4700018BFFFDF0AD1F07810F03F0F1FBF3079DF +:10D4800010F0020F44F00400ADF800004746BDF86C +:10D4900000000090BDF80000C0F3C00BA868CBEB03 +:10D4A0004B1A00EB4A0090F82800002818BFBDE88E +:10D4B000F88F3046FFF7D9FA80467048806800EB55 +:10D4C0004A0190F8C90001F12A04012808BF01258A +:10D4D00003D0022814BFFFDF0225257300206073EC +:10D4E0006648806890F8E11084F83B10FF21A17332 +:10D4F0007F21E176BDF80010618190F8E0100429E9 +:10D500001CBF90F8E01006293AD044E044F00A012C +:10D51000ADF8001090F8FA00002814BF41F00400A4 +:10D5200021F0040074E73046FFF711FCD8B1012860 +:10D5300004BF44F00100ADF8000014D0022818BF69 +:10D54000FFDFA4D144F00200ADF80000A96891F813 +:10D55000FA10002914BF40F0040020F00400ADF8D8 +:10D560000000474693E7F07810F03F0F1FBF307977 +:10D5700010F0020FBDF8000040F0040087D047E72C +:10D5800090F8E200012808BF012503D0022814BF4B +:10D59000FFDF0225657304F10900384D00902878FB +:10D5A0007F2808BFFFDF2978009801707F2028704E +:10D5B0006FB1B8F1070F04F11C01304603D2FFF739 +:10D5C000BAFA207239E0FFF782FC207204E00020F2 +:10D5D0002072B8F1070F30D3B8F1070F0DD1A8684A +:10D5E00090F8F91001B3D0F8EA10C4F80210B0F8BE +:10D5F000EE10E18090F8F0006070A07A10F0040F57 +:10D600000ED0A86890F8FA10E9B190F8F7102175DB +:10D61000D0F8F110C4F81510B0F8F500A4F819000E +:10D62000B8F1070F38D098E0F07810F03F0F1ABF2C +:10D63000307910F0010FFF20DED0621CA11C3046B3 +:10D6400001F071FDD9E7B8F1070F1CBFB8F1010F68 +:10D65000FFDFB9F1000F08BFFFDF99F80000207568 +:10D66000B8F1010F03D0B8F1070F0BD075E004F14A +:10D6700015013046FFF712FA6FE000006401002048 +:10D68000CC10002001213046FFF7B2FA0168C4F83F +:10D6900015108088A4F81900F07810F03F0F1CBF17 +:10D6A000317911F0080F1AD0A86890F8E020042A08 +:10D6B00006D090F8E000032811D111F0100F0ED021 +:10D6C00003213046FFF794FA407803210009A07344 +:10D6D0003046FFF78DFA0088C0F30B002082F07807 +:10D6E00010F03F0F1CBF307910F0400F13D0FA48F4 +:10D6F000FFF72DFBA96891F8E020032A14D006213A +:10D700003046FFF775FA0078E076A86890F8E010E8 +:10D71000062922D118E0A86890F8FB10002918BF4C +:10D7200090F8F800F0D1F0E791F8C910042914BF7F +:10D7300008290028E3D1F07810F03F0F1CBF3079A2 +:10D7400010F0080FDBD1E0E790F8E9100909A173A8 +:10D75000B0F8E800C0F30B002082A968012001EBBB +:10D760004A0181F82800BBF1000F14BF06200520F4 +:10D77000BDE8F84F03F0F4B82DE9F041D74DAA68A1 +:10D7800092F8D930002B6ED07F27012611B109788D +:10D79000FE2914D0804692F82800002818BFBDE862 +:10D7A000F08102F12A044046FFF75FF900210828C2 +:10D7B00079D2DFE800F0515356787878595CC64C3E +:10D7C00092F8A400002818BFBDE8F08182F8A66096 +:10D7D00092F8DD0018B1F6F76CFE012829D020463A +:10D7E000FFF76CF90146A86880F8A71000F1A801BE +:10D7F0002046FFF745F92046FFF76DF90146A86876 +:10D8000080F8AE1000F1AF012046FFF747F9A86895 +:10D8100000F1B50428787F2808BFFFDF2878207042 +:10D820002F70A86880F8A460BDE8F041052003F0DF +:10D8300097B8F6F781FEA96801F1A802A731FDF7B4 +:10D84000DDFF002808BFFFDFA86890F8A71041F0AF +:10D85000020180F8A710CEE7A17209E0A67221723A +:10D860000CE0032001E021E00220A07200E0FFDFD5 +:10D8700004F10B014046FFF75EF92072621CA11C07 +:10D88000404601F050FC287809347F2808BFFFDFAC +:10D89000287820702F70A86880F82860BDE8F041D3 +:10D8A000052003F05DB82172BDE8F081BDE8F041CC +:10D8B00088E570B5894C0022A06890F8C910104620 +:10D8C00002F0A8FE002831D0F7F735FBA0688449A4 +:10D8D00090F8DF000D5C2846F7F75CF8A06880F848 +:10D8E000E15090F8C910082916BF04290F202520FF +:10D8F000F6F75DFFA068002190F8C9200120F7F736 +:10D9000050F97548F7F720FBA068D0F80001F7F749 +:10D910001EFBA06890F8C91080F8E21090F8C800CB +:10D92000032814BF0228012908D103E0BDE8704094 +:10D9300001F032BC08210020F7F707FCA06890F83E +:10D94000C91080F8E210F7F7DDFBA06890F8DD0061 +:10D9500020B1F6F77AFD4020F7F7A8FBA168032075 +:10D9600081F8E00070BD2DE9F0410F469046054674 +:10D970000321FFF73DF94078584C0209A06890F860 +:10D98000E91062F3071180F8E91003212846FFF738 +:10D990002FF90188A068B0F8E82061F30B02A0F825 +:10D9A000E82080F8E77090F8C910012905D090F8B8 +:10D9B000E000032808BFBDE8F081E8784FF00106D9 +:10D9C00010F03F0F1CBF287910F0400F09D006213E +:10D9D0002846FFF70DF90178A06880F8F81080F864 +:10D9E000FB60A06890F8E01003292AD0E97811F0D4 +:10D9F0003F0F1CBF297911F0010F08D000F1F00290 +:10DA0000911F284601F08FFBA06880F8F960E87844 +:10DA100010F03F0F1ABF287910F0020FBDE8F08117 +:10DA200001212846FFF7E4F8A1680268C1F8F12057 +:10DA30008088A1F8F50081F8F78081F8FA60BDE8E8 +:10DA4000F081022F18BF012FD0D1BDE8F08123490A +:10DA5000896881F80A01704770B5204DA86890F870 +:10DA6000E010022919BF90F8E010012900210C46AE +:10DA70001CBF0C2070BD00BFC1EB411200EB420285 +:10DA8000034682F82840491CC9B20229F4D3047025 +:10DA900080F8224093F8DD0030B1F7F719FBF6F774 +:10DAA000E8FCA86880F8DD40A868012180F8DC4027 +:10DAB00080F8C11080F8C84080F8DF40282180F845 +:10DAC0000B1180F80A41A0F8E34080F8E5400721F7 +:10DAD00080F8C010002070BDD81100206401002023 +:10DAE000D4480200F74810B58068002180F8E010A3 +:10DAF000012180F8E010FFF7AFFF002818BFFFDF1B +:10DB000010BD2DE9F047EF4C07460C26A06890F8B1 +:10DB1000E01001291FBF90F8E00002280C20BDE8AA +:10DB2000F087F6F778FEA06890F90A01F6F720FF73 +:10DB3000A06890F8C91080F8E21090F8C010012594 +:10DB4000002978D090F8C8004FF00009032802D0CF +:10DB5000022805D008E00521DB4801F0ADFB03E019 +:10DB60000321D94801F0A8FBA06890F8D81000293B +:10DB700004BF90F8DB00002843D0F5F749F80646CB +:10DB8000A0683146D0F8D400F5F750FDCF4990FB9E +:10DB9000F1F801FB180041423046F4F742FD01461E +:10DBA000A068C0F8D410D0F8D0104144C0F8D0100C +:10DBB000FDF7F3FD0146A068D0F8D020914220D8AF +:10DBC000C0E9349690F8DB0000281CBF0120FDF767 +:10DBD00008FF0121A06890F8DC20002A1CBF90F803 +:10DBE000D820002A0DD090F8B93000F1BA02012BEC +:10DBF00004D1527902F0C002402A14D0BA30F7F7AB +:10DC000085FEA06890F8B910BA30F6F769FE0F21CA +:10DC10000720F6F781FEA068002690F8E0100129A1 +:10DC200018D112E007E0FDF709FFA1682A46BA31D2 +:10DC3000F7F735FEE5E790F8E010022904BF80F819 +:10DC4000E0500C2006D1BDE8F08780F80451022195 +:10DC500080F8E010A06890F8C10088B1FDF769FE77 +:10DC600003219B48FDF7A1FE0146A06880F8DD1066 +:10DC7000C0F800719748F7F750F93046BDE8F087D3 +:10DC8000FDF700FEECE738B58E4CA06890F8E01088 +:10DC900002291CBF0C2038BD012180F80511A0F815 +:10DCA000081129208DF800006846F5F7F3FF30B120 +:10DCB000A0689DF8001090F80601884205D1A06880 +:10DCC00090F80601401C8DF80000A1689DF8000046 +:10DCD00081F806010220F7F734F97F48F6F752FE83 +:10DCE000A168DFF8F8C1002091F8C03091F8DF207A +:10DCF000521CACFB02546408A4EB8404224481F857 +:10DD0000DF2023FA02F212F0010F03D1401CC0B24F +:10DD10000328EBD3FFF7CDFD002038BD69498968A2 +:10DD200081F8C900002070476649896881F8DA00E7 +:10DD3000704710B5634CA36893F8B830022B14BF3A +:10DD4000032B00280BD100291ABF02290120002033 +:10DD50001146FDF725FD08281CBF012010BDA06855 +:10DD600090F8B800002816BF022800200120BDE866 +:10DD70001040F7F755BD5348806890F8B800002868 +:10DD800016BF022800200120F7F74ABD4D498968D7 +:10DD900081F8B80070474B49896881F8DC0070470A +:10DDA00070B5484CA16891F8B800002816BF022849 +:10DDB0000020012081F8B900BA31F7F71BFDA068F7 +:10DDC00090F8B810022916BF03290121002180F81C +:10DDD000DB1090F8B920002500F1BA03012A04BF36 +:10DDE0005B7913F0C00F0AD000F1BA03012A04D105 +:10DDF0005A7902F0C002402A01D0002200E001223C +:10DE000080F8D820002A04BF002970BDC0F8D05087 +:10DE1000F4F7FEFEA168C1F8D40091F8DB000028F9 +:10DE20001CBF0020FDF7DDFD0026A06890F8DC1087 +:10DE300000291ABF90F8D810002970BD90F8B920B9 +:10DE400000F1BA01012A04D1497901F0C001402949 +:10DE500005D02946BDE87040BA30F7F757BDFDF749 +:10DE6000EDFDA1683246BDE87040BA31F7F717BD45 +:10DE700070B5144D0C4600280CBF01230023A9687F +:10DE800081F8C13081F8CB004FF0080081F8CC0058 +:10DE90000CD1002C1ABF022C012000201146FDF7E6 +:10DEA0007FFCA968082881F8CC0001D0002070BD53 +:10DEB000022C14BF032C1220F8D170BD002818BF0B +:10DEC00011207047640100200012002040420F0022 +:10DED000D8110020D1480200D7480200ABAAAAAA54 +:10DEE0000328FE4A926808BFC2F8C41082F8C8002E +:10DEF0000020704710B5044602F018FF052809D02D +:10DF000002F014FF042805D0F448806880F8D94056 +:10DF1000002010BD0C2010BDF048816891F8C800A9 +:10DF2000032804D0012818BF022807D004E091F884 +:10DF3000CB00012808BF70470020704791F8CA0045 +:10DF4000012814BF03280120F6D1704710B5F7F758 +:10DF5000A1F8F7F780F8F6F77BFFF6F7E4FFDF4C60 +:10DF6000A06890F8DD0038B1F7F7B2F8F6F781FA5B +:10DF7000A168002081F8DD00A068012180F804116B +:10DF8000022180F8E010002010BDD449896881F892 +:10DF9000FC007047017801291CBF122070474278AD +:10DFA0000023032ACD49896808BFC1F8C43081F82D +:10DFB000C820012281F8C920C27881F8B8200279EE +:10DFC000002A16BF022A0123002381F8C13081F8FC +:10DFD000CA20427981F8C020807981F8DA000020D7 +:10DFE0007047BE488068704701F0D6B82DE9F84FF9 +:10DFF0004FF00008B948F7F790F8B84C4FF07F0A97 +:10E00000002808BF84F800A0F7F772F8B448FEF7BC +:10E010002CFDA070A16891F8E220012A18BFFFDF53 +:10E020000AD0A06890F8DD0018B1F7F751F8F6F7BC +:10E0300020FA4046BDE8F88FA94D0026A5F5867761 +:10E04000072836D291F8C10028B9F6F793FC0028CA +:10E0500008BF002600D00126A06890F8DD0080B13E +:10E06000FDF7F5FBA168FF2881F8DE000ED0014620 +:10E07000E81CFDF7E1FBA06890F8DE00FDF7F2FB7D +:10E080000643A06890F8DE00FF2817D1FDF781FC59 +:10E0900087F8DE0097F8C11081B108280ED12878E2 +:10E0A000E91CC0F38010FDF77BFB082818BF002691 +:10E0B00004E002BF91F8D90000280126A0784FF0B3 +:10E0C00000094FF0010B08281BD2DFE800F035AF44 +:10E0D000041A1A1A12F9002E00F06581A06890F84F +:10E0E000C800012818BF022840F05D81F6F7B0FE95 +:10E0F0007AE036B1A06890F8C800022806D001285E +:10E1000072D0F6F7A5FE4FF003088AE700217448A5 +:10E11000FFF732FBA0684FF00808C0F8E790C0F89E +:10E12000EB90C0F8EF90C0F8F390C0F8F79080F84B +:10E13000FB9080F8E79074E74FF00008002E00F0A5 +:10E140003281A26892F8C80002282DD001284BD055 +:10E1500003287FF466AFD2F8C400E978837E994241 +:10E160001BD12979C37E994217D16979037F9942DE +:10E1700013D1A979437F99420FD1E979837F9942DD +:10E180000BD1297AC37F994207D12978437EC1F305 +:10E190008011994208BF012100D0002192F8CB20C4 +:10E1A000012A26D0A9B3FBE000214D48FFF7E4FA8D +:10E1B000A06890F8051129B1491E11F0FF0180F8FF +:10E1C00005117CD1C0F8E790C0F8EB90C0F8EF9053 +:10E1D000C0F8F390C0F8F79080F8FB904FF0080873 +:10E1E00080F8E7B01DE7FFE700213D48FFF7C4FADC +:10E1F00019E0002965D100BF00F11A013848FEF787 +:10E200003FFC3748FEF75AFCA168D1F8C4104876A5 +:10E21000C6E0FFE797F8CC00082850D097F8DE104A +:10E2200081424ED0BFE04FF00308FAE6A06890F8B4 +:10E23000DB1000290CBF4FF0010B4FF0000B4FF02B +:10E240000008297805F10902C90907D0517901F0C0 +:10E25000C001402908BF4FF0010901D04FF000096B +:10E2600090F8C810032906D190F8C110002918BFF2 +:10E2700090F8CC0001D190F8DE00FDF7ADFA5FEA2E +:10E28000000A13D01021FEF730F9002818BF4FF014 +:10E29000010BB9F1000F04BFA06890F8B9A00DD030 +:10E2A00005F109015046F7F7C9FA8046A068B9F1AF +:10E2B000000F90F8B9A018BF4AF0020A02E072E01D +:10E2C0008CE06DE090F8C810032913D0F6F7C0FD7C +:10E2D000DEB3F6F71DFB50EA080003E064010020FE +:10E2E000D811002062D08DF800A06946FD48FFF7E4 +:10E2F00043FA98E7D0F8C400E978827E91421BD1B6 +:10E300002979C27E914217D16979027F914213D156 +:10E31000A979427F91420FD1E979827F91420BD155 +:10E32000297AC27F914207D12978407EC1F38011BA +:10E33000814208BF012500D0002597F8DE0008289B +:10E3400008D097F8CC10884200E02FE008BF4FF0CB +:10E35000010901D04FF00009B8F1000F05D1BBF160 +:10E36000000F04D0F6F7D4FA08B1012000E0002035 +:10E370004EB197F8CB10012903D021B955EA090114 +:10E3800001D0012100E0002108420CD0A06890F8E3 +:10E39000CB10012904BF002DD0F8C4003FF42CAFEE +:10E3A0004FF00A083DE6F6F753FD3CE7A06890F809 +:10E3B000CA00032818BF02287FF435AFB9F1000F57 +:10E3C0003FF431AFB8F1000F7FF42DAFC648694676 +:10E3D00040680090C348FFF7CFF924E7A06890F8A1 +:10E3E000DA0000283FF48DAEF6F732FDA06890F811 +:10E3F000D91000297FF417AFC0F8E790C0F8EB9070 +:10E40000C0F8EF90C0F8F390C0F8F79080F8FB9058 +:10E4100080F8F8A0B348FEF79AFCE8B301287CD056 +:10E4200002287FF400AFA0684FF0030890F8C800FE +:10E43000032814BF0020012036EA00003FF4F1ADAC +:10E44000A84D1820E97811F03F0F3FF4EAAD297983 +:10E4500088437FF4E6AD04212846FEF7C9FB064653 +:10E46000A06890F8E20002F0CCF80146304600F0D7 +:10E47000B5FE00283FF4D5AD002202212846FFF763 +:10E4800072FA2846FEF763FC0146A06880F8E610A1 +:10E490003188A0F8E31000E005E0B17880F8E510DD +:10E4A0004FF00408BDE5002E3FF4BDAEA06890F823 +:10E4B000C810012918BF02297FF4B5AE894DE9784B +:10E4C00011F03F0F1CBF297911F0020F05D011F098 +:10E4D000010F18BF4FF0010901D14FF000094FF0B3 +:10E4E0000008B9F1000F52D028780027C609012191 +:10E4F0002846FEF77DFB36B1407900F0C000402889 +:10E5000008BF012600D00026A06890F8C810032993 +:10E5100008D190F8C110002900E0AEE018BF90F8D3 +:10E52000CC0001D190F8DE00FDF756F95FEA000853 +:10E530000CD01021FDF7D9FF46B101212846FEF786 +:10E5400057FB01464046F7F779F90746A068002EC9 +:10E5500090F8B98018BF48F00208E87810F03F0F33 +:10E560001CBF287910F0020F0ED02846FEF7B3FA30 +:10E57000824601212846FEF73BFB5146F6F7B8F9E3 +:10E58000002818BF012000D1002038435FD0E87870 +:10E5900010F03F0F1EBF297911F0100F11F0080F76 +:10E5A00041D004212846FEF723FB0646A06890F8D8 +:10E5B000E20002F026F80146304600F00FFEA0B15E +:10E5C000424600212846FFF7CEF94648FEF7BFFB3A +:10E5D0000146A06880F8E6103188A0F8E310B17811 +:10E5E00080F8E5104FF004081BE5A06890F8E20001 +:10E5F00001287FF418AEE87810F03F0F1CBF28798F +:10E6000010F0010F3FF40FAEB9F1000F04D100215B +:10E610002846FEF7D7FE06E68DF8008069462846B4 +:10E62000FEF7D0FEFFE510F03F0F1CBF297911F077 +:10E63000100F7FF4F8AD10F03F0F1CBF287910F0D9 +:10E64000010F3FF4F0ADB9F1000FE5D1DFE7A068AD +:10E6500090F8CA00032818BF02287FF4E4AD002E0A +:10E660003FF4E1AD002F7FF4DEAD1F48694600683E +:10E6700000902846FEF7A6FED5E5002E3FF4D3AD68 +:10E68000184D1820E97811F03F0F3FF4CCAD2979EF +:10E6900088437FF4C8AD04212846FEF7A9FA064650 +:10E6A000A06890F8E20001F0ACFF0146304600F0AF +:10E6B00095FD00283FF4B7AD002201212846FFF761 +:10E6C00052F92846FEF743FB0146A06880F8E610A1 +:10E6D0003188A0F8E310B17880F8E5104FF0040815 +:10E6E0009FE40000D8110020C84802002DE9F04145 +:10E6F000FD4CA0680078002818BFFFDF0025A06847 +:10E7000001278570D0F8C4100A8882804A88428325 +:10E710008A888283C988C18380F82050F34990F8A1 +:10E72000DB20A1F59A764AB10A78C2F38013CA1C9D +:10E7300023B1527902F0C002402A33D090F8DC2095 +:10E7400042B111F8032BC2F380121AB1497911F0CA +:10E75000C00F27D00E3005F0CFFEA06890F8DD0086 +:10E7600018B1F5F7A6FE012824D0A068D0F8C4108F +:10E770004A7EC271D1F81A208260C98B81814561BD +:10E780000583A0680770D0F8C42090F80A1182F8B9 +:10E790005710D0F8C4000088F2F73CFABDE8F04109 +:10E7A000F1F7D2BED6F83711C0F80E10B6F83B110B +:10E7B0004182D2E7F5F7C0FEA16801F10802C91D48 +:10E7C000FDF71CF8002808BFFFDFA068C17941F001 +:10E7D0000201C171D6F80F114161B6F8131101831E +:10E7E000CFE72DE9F84FC04C0546FF21A068002770 +:10E7F0004FF0010980F8DE1090F8C800BA460128F1 +:10E8000018BF022802D0032818BFFFDF28004FF0EE +:10E81000040B4FF07F08B54EA6F1280500F04B81A0 +:10E820002846FEF73DFA28B92846FEF793FA002855 +:10E8300000F04181A06890F8E000082880F038815D +:10E84000DFE800F0FEFEFE04080CCF7BFFF7CEFBF6 +:10E8500000F0C5B800F093FD00F0C1B8A448FEF781 +:10E8600004F92071E878717A88421CD12879B17A4C +:10E87000884218D16879F17A884214D1A879317B1D +:10E88000884210D1E879717B88420CD1287AB17B1B +:10E89000884208D128783178C0F38010B0EBD11FBE +:10E8A00008BF012500D00025F6F7D2FA8E48F6F70A +:10E8B00034FC002808BF84F80080F6F719FC2079A2 +:10E8C000042840F04D81002D00F04A81CDF800A0D1 +:10E8D000A2688748694692F8D93053B3064692F841 +:10E8E0006600002840F03C8102F1680582F872B0B1 +:10E8F0006932A91C304600F016FC05F10B013046C8 +:10E90000FEF73DF9C0B228721F2884BF1F2028726D +:10E91000207809357F2808BFFFDF2078287084F829 +:10E920000080A06880F86690062002F019F800F0D8 +:10E9300017B9FEF747FD00F013B903276A48F6F749 +:10E94000ECFB002808BF84F80080F6F7D1FB68488C +:10E95000FEF78BF880466648FEF7F9F9B8F1080F24 +:10E9600008BF00283AD1E978032011F03F0F35D0D5 +:10E970002979884332D100215D48FEF739F9062212 +:10E9800006F1090105F0E8FB40BB5948FEF796F88F +:10E9900080465648FEF79FF880451FD10121544814 +:10E9A000FEF726F90622F11C05F0D6FBB0B9504857 +:10E9B000FEF791F880464D48FEF780F880450DD16E +:10E9C000F6F768FBF6F747FBF6F742FAF6F7ABFA0D +:10E9D0000227FFF78BFE042001F0C2FF38460746EE +:10E9E000B2E0F6F735FA4048F6F797FB002808BF83 +:10E9F00084F80080F6F77CFB3D48FEF736F80746C2 +:10EA00003B48FEF7A4F9072F08BF00284FD1E9784B +:10EA1000012011F03F0F4AD02979884347D10021C6 +:10EA20003348FEF7E5F8062206F1090105F094FBEC +:10EA300000283CD12E48FEF741F805462B4800E05F +:10EA400036E0FEF748F8854231D1A06890F804110D +:10EA500029B3B0F8082190F80611012A05D9520807 +:10EA6000A0F8082108BFA0F80891012914BF0029C7 +:10EA70000D21C943C1EBC10202EB011190F8052140 +:10EA8000D24302EB8203C3EB82121144B0F8082197 +:10EA9000890CB1FBF2F302FB131180F8051180F829 +:10EAA000049169461248CDF800A0FEF78BFC57E0B0 +:10EAB000FFDFBDE8F88FA06890F8E000082843D297 +:10EAC000DFE800F0424242041F2E3F350648F6F7C9 +:10EAD00024FB002808BF84F80080F6F709FBA06833 +:10EAE00090F8DD0050B105E0640100200012002024 +:10EAF000D8110020F6F7ECFAF5F7BBFCF6F7A8F909 +:10EB00002EE0FE48F6F709FB002808BF84F80080D5 +:10EB1000F6F7EEFAA06890F8DD000028EED0E2E704 +:10EB2000F648F6F7FAFA38B984F8008004E0F348BA +:10EB3000F6F7F3FA0028F7D0F6F7DAFAF6F788F9DD +:10EB40000EE000F02FFE0BE00C2F80F01982DFE8C2 +:10EB500007F006FDFC07FBFAFAFA0BF94FBBA8E732 +:10EB6000BDE8F84FFEF7A5BE00220121022001F00A +:10EB700051FD002800F04181E149A1F12800FDF795 +:10EB8000ADFFA068DE4E90F8B9103046FDF78DFF5E +:10EB9000A06800F1BA013046FDF76BFFA06890F85D +:10EBA000DB10C1B190F8C810032906D190F8C1104C +:10EBB000002918BF90F8CC0001D190F8DE00FCF7D6 +:10EBC0003FFF050007D001213046FDF76EFF2946C3 +:10EBD0003046FDF74EFFCA48F6F7B6F90121084660 +:10EBE000F6F7B3FAA168082081F8E000BDE8F88FD5 +:10EBF000A06890F8E21090F8E2100022032001F0E3 +:10EC000009FD00287ED0BF4F0A2087F8E0000120D0 +:10EC100001F0A6FE07F59A71A1F12800FDF75EFF4D +:10EC2000A06807F59A7890F8B9104046FDF73DFFC7 +:10EC3000A06800F1BA014046FDF71BFFA06890F8FC +:10EC4000DB10C9B190F8C810032906D190F8C110A3 +:10EC5000002918BF90F8CC0001D190F8DE00FCF735 +:10EC6000EFFE5FEA000907D001214046FDF71DFFD6 +:10EC700049464046FDF7FDFEA268A149D2F8C4000E +:10EC8000C08AC875000A0876D2F8C400407DB07505 +:10EC90000846F6F759F99A48D7F8C41020230278A5 +:10ECA000497B22F0200203EA411111430170D7F899 +:10ECB000C4002A78417BC2F340121140417397F897 +:10ECC0000B01D7F8C4106FE0A06890F8E21090F83C +:10ECD000E2100022052001F09DFC98B1894D0B2027 +:10ECE00085F8E000022001F03BFE05F59A71A1F1E4 +:10ECF0002800FDF7F3FEA06805F59A7790F8B910A3 +:10ED0000384600E079E0FDF7D0FEA06800F1BA01D6 +:10ED10003846FDF7AEFEA06890F8DB10F9B190F828 +:10ED2000C810032906D190F8C110002918BF90F827 +:10ED3000CC0001D190F8DE00FCF782FE5FEA00080B +:10ED40000DD004E034E01BE18EE085E07FE001219E +:10ED50003846FDF7AAFE41463846FDF78AFEA2680E +:10ED60006749D2F8C400C08AC875000A0876D2F88C +:10ED7000C400407DB0750846F6F7E6F8D5F8C40043 +:10ED800080F80D90A06890F8E230012296210020D2 +:10ED9000F5F790FF5A48017821F020010170A06832 +:10EDA000D5F8C41090F80B0181F85600BDE8F88F33 +:10EDB000A06890F8E21090F8E2100022042001F020 +:10EDC00029FCD0B14E49A1F12800FDF787FEA068CB +:10EDD0004B4E90F8B9103046FDF767FEA06800F181 +:10EDE000BA013046FDF745FEA06890F8DB10E9B1A6 +:10EDF00090F8C810032904D00AE0BDE8F84F00F0ED +:10EE0000CBB990F8C110002918BF90F8CC0001D1FF +:10EE100090F8DE00FCF714FE050007D00121304613 +:10EE2000FDF743FE29463046FDF723FE3448F6F74A +:10EE30008BF8A06890F8E230012296210020F5F7C7 +:10EE400039FFA168092081F8E000BDE8F88FA068CB +:10EE500080F8E090BDE8F88FA068022180F8049166 +:10EE600080F8E010BDE8F88FA56815F8E31F11F0F1 +:10EE7000800F0CBF1E204FF49670B5F80120C2F32E +:10EE80000C0212FB00F6C80908BF4FF01E0906D09D +:10EE9000002806BFFFDF4FF000094FF49679A878ED +:10EEA000400908BF012703D0012814BF002702270B +:10EEB000A06890F8E20001F0A4FBA6EB0008287817 +:10EEC00008EB0906C0F38010002808BF4FF4FA7A57 +:10EED00005D006BFFFDF4FF0000A4FF0320A0948A5 +:10EEE00090F8FC90B9F10C0F28BFFFDF0648074AE5 +:10EEF00030F819000AEB00010AE00000640100206C +:10EF000000120020CC100020DC4802003F420F001D +:10EF100001FB0620511CB0FBF1F000F120094E442A +:10EF2000F6F709F8287800F03F052846F5F732FD96 +:10EF3000A06880F8E15039462520F5F738FC012219 +:10EF4000A8EB09013B461046F5F7B4FEFE48F5F77D +:10EF5000FBFF00213046F6F743F8A06880F8E27026 +:10EF6000F6F7D0F8A06890F8DD0020B1F5F76DFA5B +:10EF70005020F6F79BF8A06880F8E0B0BDE8F88F65 +:10EF8000FFDFBDE8F88FF14810B5806890F8E00029 +:10EF90000C285FD2DFE800F05E5E5E5E5E5E5E5E65 +:10EFA0000613472DE848F5F7CFFFF6F7ABF8002139 +:10EFB0009620F6F715F8E5490520896830E0E24823 +:10EFC000F5F7C2FFE14CA06890F8E23001229621EB +:10EFD0001046F5F76FFEA06890F8E2000021962039 +:10EFE000F5F7FEFFF6F78EF8A168062081F8E0003D +:10EFF00010BDD548F5F7A8FFD44CA06890F8E230D2 +:10F00000012296211046F5F755FEA06890F8E2001F +:10F0100000219620F5F7E4FFF6F774F8A1680720C1 +:10F0200081F8E00010BDF6F735F8F6F714F8F5F7BB +:10F030000FFFF5F778FFC5480121806880F80411BB +:10F04000022180F8E010FFF751FBBDE810400320DB +:10F0500001F086BCFFDF10BD70B5BC4CA06890F815 +:10F06000E0007F25082828BF70BDDFE800F03F3FA3 +:10F070003F172304390AB548F6F74FF830B9257021 +:10F0800004E0B248F6F749F80028F8D0F6F730F86F +:10F09000F5F7DEFEBDE87040FEF70BBCAB48F6F7B7 +:10F0A0003CF8002808BF2570F6F722F8BDE870404C +:10F0B00000F072B8A548F6F730F8002808BF2570B0 +:10F0C000F6F716F8A06890F8DD0018B1F6F700F82A +:10F0D000F5F7CFF9F5F7BCFEBDE87040FEF7E9BBE8 +:10F0E00000F060FBBDE87040FEF7E3BB70BD70B59B +:10F0F000964C06460D46012909D0A06890F8E230EA +:10F1000090F8E2203046BDE8704001F0E9BDF5F727 +:10F1100011FBA16891F8E220034629463046BDE87C +:10F12000704001F0DDBD70B50646884814460D46B6 +:10F13000806890F8DD0018B1F5F7BBF901280ED012 +:10F140003046FDF7BBFC20703046FDF78EFC0728EB +:10F1500013D229463046BDE87040FDF791BCF5F763 +:10F16000EBF92A462146FCF749FB002808BFFFDFE0 +:10F17000207840F00200207070BD3046FDF775FC2D +:10F18000072818BF70BD00213046FDF731FD01682A +:10F1900029608088A88070BD10B5F5F77BFFF5F772 +:10F1A0005AFFF5F755FEF5F7BEFE684CA06890F8DB +:10F1B000DD0038B1F5F78CFFF5F75BF9A1680020A9 +:10F1C00081F8DD00A068012180F80411022180F897 +:10F1D000E010BDE81040002001F0C2BB2DE9F04175 +:10F1E000044680780222B2EB501F26D00D462178CB +:10F1F00011F0800F0CBF1E204FF49670B4F8012060 +:10F20000C2F30C0212FB00F6C80908BF1E2105D08C +:10F21000002806BFFFDF00214FF49671701BA27813 +:10F22000520908BF012703D0012A14BF0027022773 +:10F23000B0F5877F28BFAE4202D20020BDE8F08142 +:10F2400045182078C0F38010002808BF4FF4FA76E4 +:10F2500003D006BFFFDF002632263D4890F8FC4071 +:10F260000C2C28BFFFDF3B483B4A30F81400311814 +:10F2700001FB0520511CB0FBF1F020300544334860 +:10F28000806890F8E200F6F7B6F904463846F6F7DB +:10F29000B2F94FF47A7184423ABF001B00F2E730B2 +:10F2A000201AB0FBF1F034BF42192A1A3946BDE8E2 +:10F2B000F041012001F0AEB970B50D460446FDF7EE +:10F2C000AFFB032D55D0052D18BF70BD052120467D +:10F2D000FDF7ABFB1D4DA868D0F8C40000F10E018E +:10F2E0002046FDF760FCA868D0F8C40000F11201C8 +:10F2F0002046FDF75CFCA868D0F8C410497DA175D4 +:10F30000D0F8C410C98AE175090A2176D0F8C41072 +:10F3100049886176090AA176D0F8C4108988E17617 +:10F32000090A2177D0F8C410C9886177090AA17742 +:10F33000D0F8C40000F108012046FDF756FCA8688B +:10F34000D0F8C400017E09E0D8110020640100203B +:10F35000CC100020DC4802003F420F002046FDF7A1 +:10F360002CFCA86890F8FC102046BDE87040FDF722 +:10F370002EBC2046BDE870400321FDF756BB2DE9A9 +:10F38000F84FFD48F5F7C9FEFB4C002804BF7F206D +:10F390002070F5F7ADFEA06890F8D900002818BFDE +:10F3A000FFDFF648FDF761FBDFF8D083E0704FF038 +:10F3B000000998F803004D4610F03F0F1CBF98F865 +:10F3C000040010F0080F14D0EC48FDF7C0FC70B139 +:10F3D000012802D002280AD00BE098F8030010F0B0 +:10F3E0003F0F1CBF98F8040010F0010F01D04FF040 +:10F3F0000109A06890F8DD0018B1F5F769FEF5F78E +:10F4000038F898F803002E4637464FF0000A10F0FF +:10F410003F0F1CBF98F8040010F0020F43D0A06803 +:10F42000DFF858A3002690F8DB0000280CBF012766 +:10F4300000279AF800000121C5095046FDF7D8FBC6 +:10F4400035B1407900F0C000402808BF012500D048 +:10F450000025A06890F8C810032906D190F8C110C3 +:10F46000002918BF90F8CC0001D190F8DE00FCF71D +:10F47000B3F95FEA000B0FD01021FDF736F8002832 +:10F4800018BF012745B101215046FDF7B1FB0146E8 +:10F490005846F6F7D3F90646A068002D90F8B9A0B3 +:10F4A00018BF4AF0020AE0784FF0030B072875D125 +:10F4B000B248FDF74CFC002800F0F280012803D090 +:10F4C000022800F031819FE0009700270321AB481C +:10F4D000FDF78EFBB9F1000F7ED0A16891F8E7200F +:10F4E000012A79D1427891F8E9301209B2EB131F61 +:10F4F00072D10088B1F8E810C0F30B00C1F30B0122 +:10F50000884269D19D48FDF722FCA16891F8E62068 +:10F51000904261D191F8C800012818BF022802D09A +:10F5200003283CD0B9E0F5F793FC98F8030010F0FD +:10F530003F0F1CBF98F8040010F0020F17D08F4F38 +:10F540003846FDF7C8FA804601213846FDF750FBE2 +:10F550004146F5F7CDF9002818BF012030430BD004 +:10F560008DF800A069468548FDF72CFF14E00021C6 +:10F570008248FDF727FF0FE0A06890F8CA00032833 +:10F5800018BF022808D13DB136B97D486946806868 +:10F5900000907A48FDF716FF03277EE034E0002153 +:10F5A0007648FDF725FBA1680622D1F8C4101A3170 +:10F5B00004F0D2FD50B97148FDF780FAA168D1F886 +:10F5C000C410497E884208BF012500D0002598F864 +:10F5D000030010F03F0F00E05CE01CBF98F804004F +:10F5E00010F0020F01D0CEB127E0A06890F8CB1048 +:10F5F000012901D015B10CE05DB937E090F8DE10BB +:10F6000090F8CC00814204D0F5F722FC5846BDE8C2 +:10F61000F88FA06890F8E2000B273EE0009870B1E8 +:10F62000564E3046FDF757FA074601213046FDF7A2 +:10F63000DFFA3946F5F75CF908B1012200E0002253 +:10F64000A06890F8CB10012907D041B92DB990F8E6 +:10F65000DE3090F8CC00834201D1012000E0002090 +:10F66000024217D0012908BF002DD2D10021434802 +:10F67000FDF7BEFAA1680268D1F8C410C1F81A20DB +:10F680008088C8833D48FDF719FAA168D1F8C410F5 +:10F690004876BEE7F5F7DCFB03273846BDE8F88F70 +:10F6A000F5F7D6FB03213548FDF7A2FAB9F1000FB3 +:10F6B00036D0A16891F8E7206ABB427891F8E9302A +:10F6C0001209B2EB131F2BD10088B1F8E810C0F378 +:10F6D0000B00C1F30B01884222D12848FDF737FB0C +:10F6E000A16891F8E62090421AD191F8C80001284B +:10F6F00018BF022814D198F8030010F03F0F1CBF68 +:10F7000098F8040010F0020F06D08DF800A06946AA +:10F710001A48FDF757FE03E000211848FDF752FE96 +:10F720005846BDE8F88F00BFF5F792FBA06890F847 +:10F73000C80003281CD01148FDF709FBA16891F807 +:10F74000E620904214D198F80320092012F03F0FD0 +:10F750000ED098F8042090430AD1B9F1000F07D0D9 +:10F7600091F8C80002280DD000210448FDF72AFEB8 +:10F770000320BDE8F88F000064010020D8110020AC +:10F78000C848020091F8050128B1401E10F0FF00A2 +:10F7900081F80501ECD1524601212348FEF7E3F838 +:10F7A0000920E6E710B5F5F753FB2048F5F7B5FC5F +:10F7B0001E4C002804BF7F202070F5F799FCA0683C +:10F7C00090F8041119B1002180F8041110BDB0F8AF +:10F7D000082190F80611FF2A0AD24FF6FF7303EAB8 +:10F7E0004202A0F80821FF2A84BFFF22A0F80821C6 +:10F7F000012914BF00290D21C943C1EBC10202EB4D +:10F80000011290F80511C94301EB8103C3EB81118B +:10F810001144B0F80821890CB1FBF2F302FB13117B +:10F8200080F80511CFE70000D81100206401002006 +:10F830002DE9FF4F07460C46488881B040F2E2416F +:10F8400048430090E08A002600FB01FB94F8640026 +:10F8500091460D2818BF0C281FD024281EBF94F8ED +:10F86000650024284FF0000A17D0049818B1012130 +:10F87000204602F0B2FB94F8540094F8558094F8B6 +:10F88000D010054661B101296DD0022952D003295B +:10F8900018BFFFDF67D000F0D5B84FF0010AE4E7EA +:10F8A000B9F1000F08BFFFDFFD4EB068002808BFA8 +:10F8B000FFDF94F85410FB4890F82400FDF79DF802 +:10F8C000009094F85400F5F7A5FE00F2E7314FF4EC +:10F8D0007A79B1FBF9F1F24880680E1894F8540077 +:10F8E000F5F798FE014694F85400022804BFEE484C +:10F8F0004FF47A720DD0012804BFEC484FF4C8626F +:10F9000007D0042807BFEA4840F69802E94840F6C5 +:10F91000E4421044084400F2E731B1FBF9F10098E9 +:10F92000401A00EB0B01DE48406930440844061DD4 +:10F93000012015E0DA48A9F101018068084308BFF9 +:10F94000FFDFDD48B9F1000F006800EB0B0606D0C1 +:10F95000D348806800F22230B04288BFFFDF032026 +:10F9600084F8D0006DE094F86410009E24291EBF36 +:10F9700094F86520242A25294FD1B4F85810B4F8FA +:10F98000F020891A491C09B2002946DB94F8F210CC +:10F99000002942D00D4694F8F310002918BF88467C +:10F9A000022804BFC0494FF47A700DD0012804BF6B +:10F9B000BE494FF4C86007D0042807BFBC4940F6D1 +:10F9C0009800BC4940F6E4400144022D04BFB6480B +:10F9D0004FF47A720DD0012D04BFB4484FF4C862C1 +:10F9E00007D0042D07BFB24840F69802B14840F650 +:10F9F000E4421044814208D9081A00F5FA714FF424 +:10FA00007A70B1FBF0F0064407E0401A00F5FA7195 +:10FA10004FF47A70B1FBF0F0361AB9F1000F10D044 +:10FA2000DFF87C92D9F8080020B9B9F80200002864 +:10FA300018BFFFDFD9F8080000F22230B04288BFBB +:10FA4000FFDF06B9FFDF3146D4F8D400F2F7E9FD55 +:10FA5000C4F8D400B860002038704FF0010987F86E +:10FA60000490204602F0A6FBAAF10101084208BF5B +:10FA700087F8059006D094F8D00001280CBF02202A +:10FA8000032078714046D4F824B0F5F7B4FD014660 +:10FA9000022D04BF84484FF47A720DD0012D04BFAB +:10FAA00082484FF4C86207D0042D07BF804840F653 +:10FAB0009802804840F6E4421044084400F23F6156 +:10FAC0004FF47A70B1FBF0F0584400F5C970F8605B +:10FAD000049830EA0A0004BF05B0BDE8F08F314653 +:10FAE0003846FCF724FE85B2204602F063FBA842AC +:10FAF0000FD8054687F8059006FB05F1D4F8D40029 +:10FB0000F2F78FFDB86031463846FCF710FE284406 +:10FB100085B22946204602F060FAB868C4F8D400DD +:10FB200005B0BDE8F08F2DE9F0430446634885B089 +:10FB30000D4690F80004DFF88891400999F8001408 +:10FB40004909884218BFFFDFDFF85481002708F118 +:10FB50004406082D80F00E81DFE805F0046872721B +:10FB60006DFEFEB6202C28BFFFDF36F814000621FC +:10FB7000F0F71EFF050008BFFFDF202C28BFFFDFC6 +:10FB800036F814002988884218BFFFDF95F8D000A6 +:10FB9000002808BFFFDF284601F02EFFC8F80870D4 +:10FBA000A8F8027029460020C8F81470FCF710FE6F +:10FBB00000F19804686AA04225D995F85500F5F738 +:10FBC0001AFD014695F85400022804BF36484FF448 +:10FBD0007A720DD0012804BF34484FF4C86207D0B0 +:10FBE000042807BF324840F69802324840F6E44203 +:10FBF000104408444FF47A7100F23F60B0FBF1F119 +:10FC0000686A0844071B29460020C8F80C70FCF7F6 +:10FC1000DFFD698840F2E24251439830081AA0F2B1 +:10FC20002230C8F8100005B0BDE8F08305B0BDE88B +:10FC3000F04302F0ADB805B0BDE8F043F5F7A9BA5E +:10FC400099F8140D1F49400991F800144909884298 +:10FC500018BFFFDF202C28BFFFDF36F81400062175 +:10FC6000F0F7A6FE050008BFFFDF202C28BFFFDF4E +:10FC700036F814002988884218BFFFDF00220123CC +:10FC800029466846FFF7D4FD95F8DA006946F3F790 +:10FC900007FA002808BFFFDF05B0BDE8F0830000C9 +:10FCA000281200204412002068360200A22402001C +:10FCB000D0FB010030D301007401002001E000E01E +:10FCC0000BE000E019E000E0202C28BFFFDF36F851 +:10FCD00014000621F0F76CFE050008BFFFDF202CA2 +:10FCE00028BFFFDF36F814002988884218BFFFDFDD +:10FCF00095F8D000042818BFFFDF85F8D07095F87C +:10FD0000DA404FF6FF79202C28BFFFDF26F8149049 +:10FD100095F8DA00F2F75DFF002808BFFFDF20202A +:10FD200085F8DA00D5F8E000002804BFD5F8DC003B +:10FD3000C8F8180008D0D5E9391211448269114475 +:10FD40008161D5E93701C860D5F8DC0000281CBF07 +:10FD5000D5F8E010016100E00CE004D1D5F8E00036 +:10FD6000002818BF8761FE48007805B0BDE8F04361 +:10FD7000ECF70CB8FFDF05B0BDE8F0832DE9F05FCC +:10FD8000F84E07468B46F08B7568401CF083307840 +:10FD90004FF00008002808BFFFDF07D0DFF8C89346 +:10FDA00004282ED0052818BFFFDF5BD05846FEF789 +:10FDB00018F9040008BFFFDF29463069F2F731FC6B +:10FDC000B86087F800800120387194F8C9000228D3 +:10FDD00008BFE64807D0012808BFE54803D004283B +:10FDE0000CBFE448E4484FF47A7100F2E140B0FB04 +:10FDF000F1F0B168FA300844F860307804287DD119 +:10FE000083E0002AD2D0D6F810A0D9F8184034B335 +:10FE1000A146E468002CFBD1B9F1000F1FD099F87E +:10FE20000000002808BFFFDFD9F81410D9F804003B +:10FE300001445046F3F7FAFB002807DA291A491E55 +:10FE400091FBF5F101FB05042A4604E090FBF5F176 +:10FE500001FB15042A46944288BFFFDF00E04446B8 +:10FE60002546A3E7002AA1D0B569002D08BFFFDF12 +:10FE70000024D5F8E420D9F818002346611E58B1B3 +:10FE80008369934228BF994284BF194604460346BA +:10FE9000C0680028F4D104B91C46C5F8E040D0354C +:10FEA000002C04BFC5F80C80C9F8185005D0E068D4 +:10FEB000E560E860002818BF0561D5F81090C5F826 +:10FEC0001880B9F1000F0ED0D9F8180048B1D5F854 +:10FED00014A0504538BFFFDFD9F81800A0EB0A0086 +:10FEE000A861C9F81880002C08BFC6F8208009D086 +:10FEF0002078002808BFFFDF616900E00AE0606841 +:10FF00000844306240F6B83550E7F08B0A2838BF15 +:10FF1000032000D302207871F08B012807D93846DE +:10FF20007168FCF704FC0146F08B0844F083B86864 +:10FF30003061BDE8F09F2DE9F04107468F4884B05D +:10FF40000D4690F80004DFF83882400998F8001454 +:10FF50004909884218BFFFDF01200026082D814C87 +:10FF600080F0BB80DFE805F004718C8C87B9B9A5FF +:10FF700060732073607800281CBF04B0BDE8F08176 +:10FF800079488660466126733846FEF72AF80500F0 +:10FF900008BFFFDF95F8C900022804BF79494FF474 +:10FFA0007A720DD0012804BF71494FF4C86207D09E +:10FFB000042807BF6F4940F69802734940F6E442AF +:10FFC00011444FF47A7201F2E731B1FBF2F1A26809 +:10FFD0008C18F5F704FB024695F8C900082808BFFD +:10FFE000082127D004280CBF0221002322D0022898 +:10FFF0000CBF182128211944042816BF08280F23F4 +:020000040002F8 +:1000000025235B1D082808BF402007D0042808BF0F +:10001000102003D002280CBF0420082013FB00107E +:10002000801A201AFDF76DFD002818BFFFDF04B00D +:10003000BDE8F08101EB410101F12803082814BF5C +:1000400004284FF4A871D6D0D1E7617851B1207B54 +:10005000002808BFFDF77AFF667304B0BDE8F041E1 +:10006000F2F7E2BCA073FDF70EFE002818BFFFDF19 +:1000700004B0BDE8F08104B0BDE8F041F5F789B8FF +:1000800098F8140D4149400991F800144909884233 +:1000900018BFFFDF002239466846FFF76FFE69464A +:1000A0003846F2F7FDFF002808BFFFDF04B0BDE8C7 +:1000B000F0812078052818BFFFDF207F002808BFC7 +:1000C000FFDF26772670207DF2F783FD002808BF2A +:1000D000FFDF267504B0BDE8F081FFDF04B0BDE8A6 +:1000E000F0812DE9F0411F4C0026207804281FBF25 +:1000F000207805280C20BDE8F08101206070607B2D +:100100000025A8B1EFF3108010F0010F72B60CBFFC +:1001100000270127607B00281CBFA07B002805D09A +:10012000FDF714FF6573A573F2F77EFC2FB903E0AA +:10013000207DF3F7C7F800E062B6207DF3F70FFBF0 +:10014000207F28B125772078052818BFFFDF0C26EF +:1001500065702570207DF2F73CFD002818E0000056 +:1001600070010020441200202812002004360200F2 +:10017000A2240200D0FB0100C0D4010001E000E095 +:100180000BE000E06836020030D3010019E000E027 +:1001900008BFFFDF25753046BDE8F0812DE9F04F3F +:1001A000FD4883B00078002818BFFFF79AFF0120B0 +:1001B000DFF8E88388F8000069460620F0F781FB45 +:1001C000002818BFFFDF00274FF6FF7934E00298C0 +:1001D00000281CBF90F8D01000292DD00088484579 +:1001E0001CBFDFF8BCA34FF0200B3BD00621F0F77B +:1001F000DFFB040008BFFFDF94F8DA00F3F7AFFA83 +:1002000084F8D07094F8DA504FF6FF76202D28BF8E +:10021000FFDF2AF8156094F8DA00F2F7DAFC00281C +:1002200008BFFFDF84F8DAB069460620F0F749FB23 +:10023000002818BFFFDF10E06846F0F720FB002819 +:10024000C5D00FE0029800281CBF90F8D0100029FC +:1002500003D000884845C9D104E06846F0F70FFB99 +:100260000028EFD088F80070C8F8187003B000209C +:10027000BDE8F08F10B5CB4C60B101280CBF40F643 +:10028000C410FFDF06D0A06841F66A01884228BF8B +:10029000FFDF10BDA060F6E710B5DFF808C3BE4C65 +:1002A00000238CF80000237063702377237363733B +:1002B000A3732020A3612075A4F11C004370423079 +:1002C00010214FF6FF72428020F8042F491EFAD108 +:1002D000CCF80830DCF8080041F66A01884228BFF3 +:1002E000FFDFFFF75BFF40F6C41101206160F5F707 +:1002F00082F900F2E7314FF47A70B1FBF0F042F28C +:1003000010710844A0606168A1F21731884298BF5B +:100310000146A16010BDF0B59F4C054685B0207820 +:1003200000281EBF0C2005B0F0BD95F8546095F86C +:1003300055006F6AF5F75FF9022E04BF9A494FF432 +:100340007A720DD0012E04BF98494FF4C86207D0CD +:10035000042E07BF964940F69802964940F6E442BB +:10036000114408444FF47A7100F23F60B0FBF1F0A1 +:10037000384400F22230C5F8E400A56195F8D000B9 +:10038000002818BFFFDF0020844948610521217043 +:1003900060702077E0838848F2F7C1FB2075202841 +:1003A00008BFFFDFF2F734FC2061217D012268469F +:1003B000FFF7E4FC207D6946F2F772FE002808BFD3 +:1003C000FFDF002005B0F0BD7348007800281CBF97 +:1003D0000020704710B50620F0F784FA80F0010085 +:1003E00010BD70B56C4C05462078002818BFFFDFA3 +:1003F000287801281CBF112070BD698840F2712245 +:10040000AD88514301206160F5F7F5F800F2E7315E +:100410004FF47A70B1FBF0F040F2712105FB01005E +:10042000A0606168A1F21731884298BF01460020A0 +:10043000A16070BD10B584B008431EBF112004B088 +:1004400010BD554C207800281EBF0C2004B010BDF4 +:100450000020607004212170E0835748F2F75FFBB1 +:100460002075202808BFFFDF4C48806938B101465D +:10047000C0680028FBD111B1F2F7CAFB05E0F2F722 +:10048000C7FB40F6B831F2F7CCF82061217D01229C +:100490006846FFF773FC207D6946F2F701FE0028ED +:1004A00008BFFFDF002004B010BD70B53A4CA16951 +:1004B0000160FFF716FE002300BBA169D1F8E02020 +:1004C0005AB1D1E939C5AC449569AC44C2F818C0F9 +:1004D000D1E9372CCCF80C2005E0DFF8C0C0D1F80A +:1004E000DC20CCF81820D1F8DC20D1F8E010002A6C +:1004F00018BF116102D1002918BF8B61A36170BDC3 +:1005000026494870704770B540F2E24300FB03F59E +:1005100010460C46F5F76FF8022C04BF22494FF441 +:100520007A720DD0012C04BF20494FF4C86207D065 +:10053000042C07BF1E4940F698021E4940F6E442CB +:10054000114408444FF47A7100F23F60B0FBF1F0BF +:1005500000F2223085428CBF281A002070BD70B591 +:100560000D46064601460020FCF732F9044696F88F +:100570005500F5F740F8014696F85400022804BFEC +:10058000094A4FF47A7020D0012804BF074A4FF47B +:10059000C8601AD0042811E044120020281200205C +:1005A0006C1200207001002068360200A2240200B4 +:1005B000D0FB010030D3010037FF010007BFFC4A28 +:1005C00040F69800FB4A40F6E440104408444FF4DB +:1005D0007A7100F23F60B0FBF1F0718840F2712255 +:1005E0005143C0EB4100A0F22230A54234BF214666 +:1005F0002946814203D2A5422CBF2846204670627C +:1006000070BD10B5F4F7EBFFEB498A684968511AE1 +:10061000084410BD2DE9F74FE74A00231826D2F809 +:1006200008B028270BF198044FF004084FF0100988 +:100630004FF0080A4FF4C8724FF4BF754FF0400CEA +:1006400006287CD2DFE800F0034A21472465142005 +:10065000042912D0082909D02A20022911D010FB20 +:100660000A40002328211944441877E010FB0C406D +:100670004FEA0C034FF4A871F5E710FB09402E2355 +:10068000F8E710FB08401821EDE704F5317465E048 +:10069000082904BF4FF4BA6140200CD0042915D0BA +:1006A000022903BF03F15C01324604203A461CBF15 +:1006B00003F1B001082000EBC00000EB400002EBAA +:1006C00040000844204400F19C0447E02A4640F2E0 +:1006D0008E211020EFE704F5B0743FE0082908BF31 +:1006E00040200CD0042904BF2A46102007D002293C +:1006F00007BF03F11802042003F128020820C0EB11 +:10070000C00000EB400002EB4001029858440C1876 +:1007100024E0082904BF4FF4356140200CD004299F +:1007200016D0022903BF324603F1B401042003F5B9 +:10073000B0711CBF3A46082000EB400300E00CE01B +:1007400003EB001010440844204400F19C0405E031 +:100750002A4640F2EE311020EEE7FFDF974880682E +:10076000A0428CBF0120002003B0BDE8F08F10B57F +:10077000914C607828B1D4E90301A268FCF707F82E +:10078000E060D4E9020188429CBF2078002814BFB1 +:100790000020012010BD04222DE9F04F884E894F22 +:1007A000DFF80C82DFF80C9285B04FF47A7A0529D5 +:1007B00080F0D280DFE801F00A2B0331920080F84C +:1007C000D02005B0BDE8F04FF2F72EB904467A48C4 +:1007D0000078002818BF84F8D02004D005B0BDE808 +:1007E000F04FF2F721B90122002321466846FFF7B6 +:1007F0001FF894F8DA006946F2F752FC002808BFA7 +:10080000FFDFB4F85800401CA4F85800E6E70321C5 +:1008100080F8D01005B0BDE8F08F8346408840F2E4 +:10082000E241484368490860DBF8F800594600890E +:10083000ABF81600DBF8F80080798BF81500DBF8D0 +:10084000F8004089ABF80200DBF8F8008089ABF8CB +:100850000400DBF8F800C089ABF806000020DBF8E4 +:100860002850FBF7B5FF04469BF85500F4F7C3FE8C +:100870009BF85410022908BF4FF47A710DD001295A +:1008800004BF3E464FF4C86107D0042907BF46465F +:1008900040F698014E4640F6E4413144084400F2E7 +:1008A0003F60B0FBFAF1BBF8020040F27122504306 +:1008B000C1EB4000A0F22230A54234BF21462946B8 +:1008C000814203D2A5422CBF28462046CBF8240003 +:1008D00002208BF8D00005B0BDE8F08F83460146BA +:1008E000856A0020FBF774FF04469BF85500F4F777 +:1008F00082FE9BF85410022908BF4FF47A710DD084 +:10090000012904BF3E464FF4C86107D0042907BF40 +:10091000464640F698014E4640F6E44131440844CC +:1009200000F23F60B0FBFAF0BBF8021040F2712217 +:100930005143C0EB4100A0F22230A54234BF214612 +:100940002946814203D2A5422CBF28462046CBF837 +:10095000240005B0BDE8F08FFFDF05B0BDE8F08FE3 +:100960002DE9F043DFF864800024144D98F800105E +:1009700085B0072880F0AD81DFE800F0042A2AFC6A +:10098000FCFBFB00EC830846EBF700FA68780028D4 +:1009900040F05E81297D00226846FFF7EFF9287D4F +:1009A0006946F2F77DFB002808BFFFDF00F050B971 +:1009B000D0FB010030D30100281200204412002097 +:1009C00068360200A2240200740100207001002099 +:1009D00002280CBF01260026287DFDF702FB04003B +:1009E00008BFFFDF94F8E2103046FCF706F8DFF8A6 +:1009F000449301462869D9F80820002E024408BF14 +:100A00004FF4FC706ED094F8E20094F8E2000828ED +:100A10001EBF94F8E2000428002000F0B98000BF57 +:100A200094F8E230082B1ABF94F8E230042B4FF40C +:100A3000A87305D094F8E230022B0CBF18232823AA +:100A4000034494F8E200082808BF40200BD094F833 +:100A5000E200042808BF102005D094F8E200022824 +:100A60000CBF04200820C0EBC00C0CEB401003446A +:100A700094F8E20008281EBF94F8E2000428002041 +:100A800079D000BF94F8E2C0BCF1080F1ABF94F807 +:100A9000E2C0BCF1040F4FF4A87C08D094F8E2C087 +:100AA000BCF1020F0CBF4FF0180C4FF0280C84441F +:100AB00094F8E200082808BF40200BD094F8E20028 +:100AC000042808BF102005D094F8E20002280CBFCB +:100AD0000420082000EB400606EB00106044184498 +:100AE00000F59A7010440844061D94F8E200F4F7EB +:100AF00082FD94F8E210022908BF8F490BD094F8C8 +:100B0000E210012908BF8D4905D094F8E2100429AC +:100B10000CBF8B498B4994F8E220022A08BF4FF49E +:100B20007A720ED094F8E220012A08BF4FF4C8620E +:100B300007D094F8E220042A0CBF40F6980240F651 +:100B4000E442114408444FF47A7100F2E730B0FBFC +:100B5000F1F0A969301A40F2E2434A88D03102FB31 +:100B600003F6D9F818208A4208BF00272AD0296A3C +:100B700002E0A8E055E014E0F2F758FD002819DA89 +:100B8000311A4A1E92FBF6F202FB0607314616E0C6 +:100B900094F8E200082818BF022000EB400028303B +:100BA0003EE794F8E200082818BF022000EB40005E +:100BB000283067E790FBF6F202FB160731468F42BA +:100BC00088BFFFDFD8F80800874208D2A86940F242 +:100BD00071224188C1824A4307EB420705E040F297 +:100BE000E240B7FBF0F0A969C88294F8E210A86966 +:100BF00080F8541094F8E21080F8551005214175E2 +:100C0000C08A6FF41C71484307EB400040F6354141 +:100C1000C9F81400B0EB410F28BFFFDF05B0BDE8F5 +:100C2000F08304280CBF01260026EC830846EBF76E +:100C3000ADF80120287785F82460A8692969C0F8F3 +:100C4000D41080F8D0402978052918BFFFDF06D0DE +:100C5000F1F7EAFE6C73AC7305B0BDE8F0830028D1 +:100C600008BFFFDFA86990F8D000002818BFFFDF99 +:100C7000A86990F8DA00202818BFFFDF3248F1F7A2 +:100C80004EFFA9690646202881F8DA000F8828BFA0 +:100C9000FFDF2E4820F81670A86990F8DA002028A7 +:100CA00008BFFFDF002301226846A969FEF7C0FDE7 +:100CB000A869694690F8DA00F2F7F2F9002808BF4F +:100CC000FFDFAC61C4E705B00846BDE8F043EBF7D1 +:100CD0005DB8FFDF05B0BDE8F08316494860704796 +:100CE00070B5144D0446002904BFA86070BD4FF4D0 +:100CF0007A76012910D002291CBFFFDF70BD6888F9 +:100D0000401C68801046F4F785FC00F2E730B0FB29 +:100D1000F6F0201AA86070BD1846F4F78AFC00F2BD +:100D2000E730B0FBF6F0201AA86070BD08480078E4 +:100D3000704700002812002068360200A22402003A +:100D4000D0FB010030D3010027FB01006C12002012 +:100D500044120020F7490C28896881F8CB001ABF9B +:100D6000132818287047002211280FD0072808BF21 +:100D7000704715280AD001281ABF0028022870479A +:100D8000A1F88420012081F888007047A1F88A200A +:100D9000704770B5E74CA1680A88A1F83E2181F838 +:100DA0003C0191F85400012808BF012503D0022816 +:100DB00014BFFFDF0225A06880F8405190F855006D +:100DC000012808BF012503D0022814BFFFDF022538 +:100DD000A068012180F8415180F83A11002180F883 +:100DE0000E11E078BDE87040EAF7D0BFD14A012982 +:100DF00092681BD0002302290FD0032922D030B3E0 +:100E000001282FD0032818BF704792F864001328D8 +:100E10001CBF1628182805D1704792F8CB0000286F +:100E200008BF7047D2F8F8000370704792F8CB0003 +:100E3000012808BF704700BFD2F8FC000178491EA6 +:100E40000170704792F8CB000328EBD17047D2F8BD +:100E5000F800B2F858108288891A09B20029A8BF90 +:100E600003707047B2F85800B2F80211401A00B28D +:100E70000028E1DA70472DE9F041AE4C0026032747 +:100E8000D4F808C0012590B12069C0788CF8CA0058 +:100E900005FA00F010F4000F08BFFFDFA06880F82B +:100EA0006470A0F8846080F88850BDE8F081002369 +:100EB0009CF8652019460CF15800FBF7CEFB002882 +:100EC00004BF6570BDE8F0816078002818BFBDE8F8 +:100ED000F0812069C178A06880F8C91080F8657039 +:100EE000A0F88A6080F88C50BDE8F08170B5914C14 +:100EF00084B0207910F0010F04BF04B070BD2069E8 +:100F000000230521C578A06890F864205830FBF7CD +:100F1000A4FB002818BF062D09D020DC022D1CBF21 +:100F2000042D052D03D0607840F0080060706078D3 +:100F300000281CBF04B070BD2069C078801E162830 +:100F400080F00783DFE800F011FF89A7D52CFFFEB2 +:100F5000FF7FFDD2FFFFFFC5FCFBFAF9F8F50B2D73 +:100F60001CBF0D2D112DDED1E1E7A068002301216A +:100F700090F867205830FBF770FB002840F05C8346 +:100F80002069FCF759F8A16881F8F600072081F87C +:100F90006700002081F88C0081F8880000F04CBBCD +:100FA000A0680921002390F864205830FBF755FB16 +:100FB00018B120690079122812D0A0680A210023F4 +:100FC00090F864205830FBF748FB18B1206900798D +:100FD000142820D020690079162840F02D8324E0C1 +:100FE000A0680125002390F8642009215830FBF700 +:100FF00034FB002808BF657000F01E83607800286D +:1010000040F01A83A16881F87C0081F8880081F89B +:10101000640000F011BBA168002081F86400A1F811 +:10102000840081F8880000F035BAA06890F8641058 +:101030001F2940F00183002180F8641080F8881097 +:101040001A2000F0F7BAA06890F864100F2927D191 +:10105000002180F86910122137E0A06890F8641030 +:1010600013291DD1D0F8F81000884988814218BF93 +:10107000FFDFA068D0F8F80000F126012069FCF736 +:1010800008F8A06800F1C4012069FCF70AF81620EE +:10109000A16800F05BB9A26892F86400162802D03B +:1010A000022000F03BBAD2F8F80002F1B00300F1E0 +:1010B0001E0100220E30FBF74CFAA0680021C0E9A7 +:1010C0002811012180F86910182180F8641000F0BF +:1010D000B3BA2069FCF765F8032840F0AD822069B7 +:1010E000FCF763F801F0D0FB00F0A6BA20690079A4 +:1010F000F8E7A06890F864101A29D1D1002580F88B +:101100008D5080F88850D0F8F810008849888142C6 +:1011100018BFFFDFA068D0F8F8100D70D0F84411A8 +:101120000A78002A18BFFFDF7ED190F88E20DAB14E +:101130000AE03CE27C010020B6E181E125E1F1E03A +:1011400008E12BE09EE0A9E180F88E500288CA8079 +:10115000D0F844110D71D0F844210E211170D0F84F +:1011600044210188518010E00288CA80D0F84411DF +:101170000D71D0F8442101211172D0F844210D21C4 +:101180001170D0F84421018851800088EFF742FDAA +:10119000EFF7DAF9E078EAF7F9FDBEE0A06800239E +:1011A000194690F865205830FBF757FA50B9A068F7 +:1011B0000023082190F864205830FBF74EFA0028ED +:1011C00000F0FA816078002840F03682A06890F83C +:1011D000900010F0020F14D12069FBF765FFA168A1 +:1011E00081F891002069B0F80520A1F89220B0F8AC +:1011F0000700A1F8940091F8900040F0020081F8F7 +:101200009000A06890F8901011F0010F14D190F8A0 +:101210006520002319465830FBF71FFA002808BF45 +:10122000FFDF0121A06800E077E080F8651080F81A +:101230008C100021A0F88A10A06890F86410012991 +:1012400007D1002180F8641080F88810E078EAF770 +:101250009DFDA168D1F8F800098842888A4204BF40 +:101260000178042940F0E88100250570E078EAF76C +:101270008DFDA06890F86410002908BF80F88850A0 +:1012800000F0DAB9A0680023072190F864205830F4 +:10129000FBF7E3F9002800F08F816078002840F028 +:1012A000CB8102A92069FBF739FF9DF808000025D2 +:1012B00000F02501A06880F896109DF8091001F053 +:1012C000410180F8971080F88850D0F8F810008815 +:1012D0004988814218BFFFDFA068D0F8F8100D7070 +:1012E000D0F844110A78002A18BFFFDF15D1028810 +:1012F000CA80D0F844110D71D0F84411029A8A6066 +:10130000039ACA60D0F84421082111700188D0F8EE +:1013100044014180E078EAF739FDA06880F8645024 +:1013200000F08AB9A0680023092190F864205830A1 +:10133000FBF793F9002800F03F816078002840F027 +:101340007B81A16881F87C0081F8880081F86400C5 +:1013500000F072B9A0680023194690F86520583053 +:10136000FBF77BF9002800F027816078002840F027 +:101370006381A0680021A0F88A10012180F88C10F8 +:10138000022180F8651000F057B9A06800231946C3 +:1013900090F865205830FBF760F900287FD020696D +:1013A000FBF7A6FE002879D0A5682069FBF79CFE14 +:1013B0002887A5682069FBF793FE6887A5682069E0 +:1013C000FBF794FEA887A5682069FBF78BFEE887EA +:1013D000A06890F864101C2913BF90F84E100121EA +:1013E00080F84E10012907D090F80511002904BF9C +:1013F00090F80411002903D01E2180F8651017E031 +:101400001D2180F865100288A0F82A21028FA0F81B +:101410002C21428FA0F82E21828F00F58A71A0F82E +:101420003021C08FC88301200875E078EAF7AEFC50 +:10143000A0680021A0F88A10012180F88C10FBE040 +:10144000A06800230A2190F864205830FBF705F9C2 +:1014500018B32069FBF74CFEA8B1A5682069FBF71B +:1014600043FE2887A5682069FBF73AFE6887A568D0 +:101470002069FBF73BFEA887A5682069FBF732FED1 +:10148000E88700F0FEFEA168002081F8880081F85E +:10149000640000BF00F0C6FECEE000E059E06078D6 +:1014A00040F001006070C7E0A0680023194690F882 +:1014B00065205830FBF7D1F878B3A06890F8640045 +:1014C000232812BF2428607840F0200026D06846E8 +:1014D000F4F747F9002808BF002104D0009802A9BA +:1014E000C0788DF80800A06801AB162290F864005F +:1014F000FBF767FAA0B1A0689DF80420162180F8D8 +:10150000EC2080F8ED10192180F86510012180F899 +:101510008C100021A0F88A108EE04DE060708BE006 +:101520002069FBF700FEA0B12269107900F00701E5 +:10153000A06880F85010527902F0070280F851201C +:1015400090F80F31002B04BF90F80E31002B04D01F +:1015500022E00020FFF78FFC6EE090F855C000F10C +:1015600054038C4501BF19789142012180F87D1008 +:1015700012D00288A0F8362190F8502000F58A7128 +:1015800080F8382190F8510081F82500012081F879 +:101590002000E078EAF7FAFBA068212180F86510C6 +:1015A000012180F88C100021A0F88A1044E0A06886 +:1015B00090F864001F2801D00120AFE72069FBF7F5 +:1015C000BCFD88B32069A2680179407901F0070168 +:1015D00061F30705294600F0070060F30F210120A1 +:1015E00082F888000025A2F88450232082F8640045 +:1015F000566DD2F81001FBF79CF9F2B2C1B28A42E3 +:1016000007BFA16881F8F250A26882F8F210C6F311 +:101610000721C0F30720814219BFA16881F8F300B8 +:10162000A06880F8F35007E0FFE70120FFF723FCF4 +:101630005FF01E00FFF7ADFBA068D0E92A12491C3D +:1016400042F10002C0E92A1204B070BD2DE9F04752 +:10165000FE4D04464FF0000768780843687028790B +:1016600010F0200F2846806818BFA0F87E7004D1C3 +:10167000B0F87E10491CA0F87E1090F86A10012680 +:1016800039B990F86420002306215830FAF7E5FFB5 +:1016900058B3A88810F4006F07D0A86890F86A10B3 +:1016A000002918BFA0F876701FD1A868B0F876108E +:1016B000491C89B2A0F87610B0F878208A422CBF75 +:1016C000511A00218288521D8A4228BF80F87C600E +:1016D000B0F87610B0F87820914206D3A0F8767072 +:1016E00080F81A61E878EAF751FB287910F0600F6A +:1016F00008D0A86890F8681021B980F868600121C6 +:10170000FFF749F84FF00808002C56D168780028F8 +:1017100051D1287910F0040F0DD0A86890F864001A +:10172000032808BFFFDFA86890F86710072904BFE7 +:101730002E7080F8677001F0F7F8287910F0080F24 +:1017400019D06878B8B9A868002190F8CB00FFF7E5 +:101750004DFBA86890F8CB00FE2808BFFFDFFE21F4 +:10176000A86880F8CB1090F86710082903D10221EF +:10177000297080F86770FFF7B9FBA87810F0080FA0 +:1017800016D0A8680023052190F864205830FAF795 +:1017900064FF50B185F80180A868D0F8441108783A +:1017A0000D2808BF0020087002E00020F9F770FB48 +:1017B000A86800F0F2FF00F0AEFDA868A14600F1B5 +:1017C000580490F8F40030B9E27B00230121204650 +:1017D000FAF743FF10B1608D401C60853D21B9F1DF +:1017E000000F18D12878022808BF16200ED0012833 +:1017F00004BFA86890F8F60008D06878E8B110F047 +:10180000140F1CBF1E20207702D005E0207703E0D4 +:1018100010F0080F02D02177E67641E010F0030FB8 +:1018200003D02A202077E6763AE010F0200F08BF98 +:10183000FFDF23202077E67632E094F8300028B1ED +:10184000A08D411CA185E18D884213D294F834000B +:1018500028B1608E411C6186E18D88420AD2618D7B +:10186000208D814203D3AA6892F8F42012B9E28D48 +:10187000914203D322202077E67611E0217C31B11A +:10188000E18C814228BF84F81C80C5D206E0E08C40 +:10189000062803D33E202077E67601E0E07EA0B163 +:1018A0002773677327740221A868FEF774FFA8687E +:1018B00090F8CB10012904D1D0F8FC000178491E22 +:1018C0000170E878EAF762FA03E00021A868FEF701 +:1018D00062FFBDE8F047F3F753BF5C4A5178937855 +:1018E000194314D111460128896809D0107910F0E4 +:1018F000040F03D091F86700072808D00120704733 +:10190000B1F84800098E884201D8FEF730BF0020A8 +:10191000704770B54D4C06460D46A0883043A080F8 +:1019200016F0020F04D016F0010F18BFFFDFE560BC +:1019300016F0010F18BF256116F0020F10D0E878DD +:10194000062802D00B2837D00AE0A06890F864106F +:10195000182905D10021C0E92A11012180F86A1057 +:1019600016F0800F1CBF0820A07016F4806F08BF0F +:1019700070BDA268B2F8580091880844801DE978CB +:1019800080B2012908BFA2F8020107D0002904BFD4 +:10199000D2F8F810888001D0182915D0E9782846A7 +:1019A00001291CD009B3182918BF70BDB2F8F01076 +:1019B000BDE87040FBF7D3BBA06890F86410122913 +:1019C00008BF0021CCD1C9E792F8F210002902BF6C +:1019D00092F8F31000290020A2F8F000DEE7B2F838 +:1019E00002114172090AA97270BDD2F8F8108988F3 +:1019F0004173090AA97370BDF0B5144C85B0002677 +:101A0000A060A6806670A670054626700088F3F771 +:101A10007FFEA0680088F3F7A1FEB5F8D800A168A2 +:101A2000401C82B201F15800FAF718FC002818BFD8 +:101A3000FFDF95F8650024280ED1B5F85810B5F8E9 +:101A4000F000081A00B2002802E000007C0100202B +:101A5000A4BF6078002806D095F86400242818BF39 +:101A600025283BD119E0A06890F8F210002908BFA2 +:101A700090F8541080F8541090F8F310002908BF23 +:101A800090F8551080F855100020FFF782F985F87E +:101A90006560A16881F87D6020E0B5F85810B5F860 +:101AA000F000081A00B20028A4BF6078002815D101 +:101AB000A06890F8F210002908BF90F8541080F840 +:101AC000541090F8F310002908BF90F8551080F8D2 +:101AD00055100020FFF75DF985F86460A5F8D8601F +:101AE000A06890F8881039B1B0F88410B0F886205A +:101AF000914224BF05B0F0BD90F88C1039B1B0F818 +:101B00008A10B0F88620914224BF05B0F0BDB0F82D +:101B10008220B0F880108A4224BF05B0F0BD90F852 +:101B200068208AB3B0F87E208A4224BF05B0F0BD99 +:101B300090F8CB70FE2F00F012816846F3F7EBFDB2 +:101B4000002808BFFFDF2221009802F0B0FB03212C +:101B50000098FBF7EDF90098017821F01001017071 +:101B60003946FBF713FA192F71D2DFE807F0271F68 +:101B70001445D6D6D71971D6D7D763D6D6D6D6C9F7 +:101B8000D7D77B94ADD6B600B0F87E10062924BF17 +:101B900005B0F0BDCCE7A168009891F8F51003E01E +:101BA000A168009891F8CC100171B7E0A068D0F856 +:101BB000FC00411C0098FBF734FAAFE0A1680098E4 +:101BC000D1F8F82092790271D1F8F8201289427187 +:101BD000120A8271D1F8F8205289C271120A027277 +:101BE000D1F8F82092894272120A8272D1F8F81064 +:101BF000C989FBF7EEF991E0A068D0F8F800011D63 +:101C00000098FBF71BFAA068D0F8F80000F10C016F +:101C10000098FBF71DFAA068D0F8F80000F11E014B +:101C20000098FBF71BFAA06800F1C0010098FBF7D1 +:101C300023FA73E06269009811780171918841710B +:101C4000090A81715188C171090A017266E064E074 +:101C5000FD49D1E90001CDE9020102A90098FBF795 +:101C600025FA5BE0A068B0F844100098FBF728FA6A +:101C7000A068B0F846100098FBF726FAA068B0F804 +:101C800040100098FBF724FAA068B0F842100098C2 +:101C9000FBF722FA42E0A068B0F840100098FBF78A +:101CA00017FAA068B0F842100098FBF715FAA06880 +:101CB000B0F844100098FBF703FAA068B0F846109B +:101CC0000098FBF701FA29E0A168009891F810212B +:101CD000027191F81111417120E0A06890F8F300B1 +:101CE000FAF722FE01460098FBF735FAA06890F853 +:101CF000F200FAF719FE01460098FBF728FA0DE00A +:101D0000A06890F8ED100098FBF749FAA06890F8E9 +:101D1000EC100098FBF747FA00E0FFDFF3F70EFD49 +:101D2000002808BFFFDF0098C178012903D049B11E +:101D300018290FD013E0A168B1F802114172090A05 +:101D400081720CE0A168D1F8F81089884173090A02 +:101D5000817304E0A168B1F8F010FBF700FABB480A +:101D60000090BB4BBB4A29463046F8F7CDFFA06830 +:101D70000023052190F864205830FAF76EFC002803 +:101D800004BF05B0F0BD05B0BDE8F040F8F7C5BD33 +:101D9000B148806890F8881029B1B0F88410B0F884 +:101DA000862091421AD290F88C1029B1B0F88A108E +:101DB000B0F88620914211D2B0F88220B0F880109D +:101DC0008A420BD290F86820B0F87E0022B1884297 +:101DD00004D200BFF9F738B80628FBD3002001462B +:101DE00034E470B50C46064615464FF4A4712046FF +:101DF00002F07FFA2680002D08BFFFDF2868C4F8B4 +:101E0000F8006868C4F8FC00A868C4F8440170BD14 +:101E1000EEF7D7BE2DE9F0410D4607460621EEF755 +:101E2000C7FD040008BFBDE8F081D4F844110026C6 +:101E3000087858B14A8821888A4207D1092810D0E9 +:101E40000E281DD00D2832D008284CD094F81A0145 +:101E5000002857D06E701020287084F81A61AF8067 +:101E60003EE06E7009202870D4F844014168696032 +:101E70008168A9608089A881D4F8440106702FE0A8 +:101E80000846EEF7C7FE0746EEF773FBB0B96E7073 +:101E90000E202870D4F8440140686860D4F84401EA +:101EA00006703846EEF75FFB0120BDE8F08108467A +:101EB000EEF7B0FE0746EEF75CFB10B10020BDE880 +:101EC000F0816E700D202870D4F84401416869607B +:101ED00000892881D4F8440106703846EEF743FBA8 +:101EE0000120BDE8F0816E7008202870D4F844010C +:101EF00041688268C0686960AA60E860D4F84401FB +:101F00000670EDE794F81C01B0B16E7015202870D2 +:101F100094F81C010028E3D084F81C61D4F81E0159 +:101F20006860D4F82201A860B4F82601A88194F86A +:101F30001C010028F0D1D3E794F8280170B16E702D +:101F40001D20287084F82861D4F82A016860D4F82C +:101F50002E01A860B4F83201A881C1E794F83401D9 +:101F600040B16E701E20287084F83461D4F83601B8 +:101F70006860B5E794F8140180B16E701B2028707A +:101F800094F814010028ABD084F81461D4F8160139 +:101F9000686094F814010028F6D1A1E794F83A019A +:101FA000002808BFBDE8F0816E701620287094F8F4 +:101FB0003A01002894D000BF84F83A61D4F83C017B +:101FC0006860B4F84001288194F83A010028F3D100 +:101FD00086E7214A5061D17070472DE9F0470446E9 +:101FE000481E85B238BFBDE8F08704F10808012615 +:101FF000DFF864904FF0090A5FF00007B4F8D800EA +:10200000401CA4F8D800B4F87E00401CA4F87E0060 +:1020100094F86A0040B994F864200023062104F182 +:102020005800FAF71AFB30B3B4F87600401C80B2BF +:10203000A4F87600B4F8781081422CBF0A1A002266 +:10204000A3885B1D934209E0F44802004D1602008C +:10205000DB180200131902007C01002028BF84F85D +:102060007C60884207D3A4F8767084F81A6199F8E6 +:102070000300E9F78BFE94F8880020B1B4F88400DF +:10208000401CA4F8840094F88C0020B1B4F88A00B5 +:10209000401CA4F88A0094F8F40040B994F8672032 +:1020A0000023012104F15800FAF7D7FA20B1B4F85F +:1020B0008200401CA4F8820094F864000C2802D02E +:1020C0000D2820D067E0B4F85800411CB4F8020194 +:1020D000814260D1D4F8FC00411C404602F01EFA57 +:1020E00002212046F9F7DDFFD4F8FC000078002833 +:1020F00008BFFFDF0121FE20FEF778FE84F8647040 +:1021000084F8986047E0B4F85800411CD4F8F8000F +:10211000808881423FD1D4F844010178002918BF5A +:10212000FFDF22D12188C180D4F8F8004189D4F89A +:1021300044010181D4F8F8008189D4F84401418137 +:10214000D4F8F800C189D4F844018181D4F844015D +:102150000771D4F8440180F800A0D4F84401218824 +:10216000418099F80300E9F711FE01212046F9F7B3 +:1021700098FF03212046FEF70EFBD9F80800D0F89F +:10218000F8000078022818BFFFDF0221FE20FEF7CA +:102190002DFE84F86470B4F85800401C691EA4F841 +:1021A00058008DB2BFF42AAFBDE8F087F84AC2E903 +:1021B0000601704770B50446B0F87E0094F86810C8 +:1021C000002908BFC0F1020503D0B4F88010081A36 +:1021D000051F94F87C0040B194F864200023092185 +:1021E00004F15800FAF739FAA0B1B4F8766094F81F +:1021F0006A0058B994F864200023062104F15800BD +:10220000FAF72BFA002808BF284603D0B4F8780064 +:10221000801B001F8542C8BF0546002DD4BF00208B +:10222000A8B270BD042110B5D94CA068FEF7B3FA6E +:10223000A06890F84E10012902BF022180F84E10CC +:1022400010BD00F58A710288A0F81E21028EA0F848 +:102250002021828EA0F82221028FB0F844309A42C9 +:1022600028BF1A460A82828FB0F84600824238BFE1 +:102270001046488201200872E078BDE81040E9F776 +:1022800085BDC34830B4806890F84E30B0F832C095 +:10229000C48EB0F84010428F022B25D08A4238BF3E +:1022A00011460186C28FB0F842108A4238BF1146EB +:1022B0008186028FB0F844108A4238BF11464186A9 +:1022C000828FB0F846108A4238BF1146C186418ECF +:1022D000614588BF8C46A0F832C0C18EA14288BF3C +:1022E0000C46C48630BC7047038E9A4228BF1A46FB +:1022F000C58F838E9D4238BF2B468A4238BF114618 +:102300000186B0F842108B4228BF0B46838600211D +:1023100080F84E10CDE770B59D4CA06890F8CB10BA +:10232000FE2906BF6178002970BD90F86720002360 +:1023300001215830FAF791F9002818BF70BDA06844 +:1023400090F8F41021B1BDE870400220FEF702BD04 +:1023500090F86420002319465830FAF77EF940B10E +:10236000A06890F87C0020B1BDE870401220FEF714 +:10237000F1BCA068002590F86420122A1FD004DC6C +:10238000032A3FD0112A1FD003E0182A35D0232A70 +:1023900043D0002304215830FAF75FF9002818BF12 +:1023A00070BDD4F808C09CF8650019287CD03BDCCF +:1023B00001286BD0022879D003285DD038E0BDE831 +:1023C00070400B20FEF7C6BCF1F760FC0C2838BF4C +:1023D00070BDA0680821D0F8F8001E30F1F75AFC53 +:1023E00028B1A0680421C030F1F754FC00B9FFDF28 +:1023F000BDE870400320FEF7ADBCBDE8704006208C +:10240000FEF7A8BC90F8CA1080F8CC100720FEF7A1 +:10241000A1FCA06880F8645070BD1820FEF79AFCFB +:10242000A068A0F8845070BD1E2847D021286BD02A +:10243000DCF8F80001260178002973D04088BCF848 +:10244000001088426ED100239CF8642019460CF1DC +:102450005800FAF702F9002864D0A068D0F8F81004 +:10246000097802297ED003297DD004297CD0052952 +:1024700008BF082079D0C7E09CF8C9008CF8CC00D0 +:102480000720FEF767FCA06800F06DB90C20FEF78E +:1024900061FCA068A0F88A5090F8901041F001010A +:1024A00080F8901000F05FB96DE0FFE71320FEF7B1 +:1024B00051FCA068A0F88A5000F055B99CF80501BD +:1024C000002818BF70BD9CF8040188B1BCF8060153 +:1024D000ACF84000BCF80801ACF84200BCF80A01B6 +:1024E000ACF84400BCF80C01ACF846008CF8045180 +:1024F000FFF7C7FEFFF796FE1520FEF72BFCA0683E +:10250000A0F88A5000F02FB99CF87D0058B18CF8E3 +:10251000F2508CF8F3501820FEF71CFCA068A0F8CD +:102520008A5070BD70E09CF80F01002818BF70BD84 +:102530009CF80E01002808BF70BDDCE91416DCF819 +:102540001001FAF7F6F9F2B2C1B28A4207BFA168E8 +:1025500081F8F250A26882F8F210C6F30721C0F3A6 +:10256000072003E016E01BE03BE022E0814219BFB8 +:10257000A16881F8F300A06880F8F3501820BDE846 +:102580007040FEF7E7BB1120FEF7E4FBA068EAE02D +:102590007C01002090F86500FAF748F8A0BB08E03D +:1025A00090F8691041B190F86A00002808BFFFDF79 +:1025B0000A20FEF7CFFB27E0F1F768FB0C2823D3B6 +:1025C000A0680821D0F8F8001E30F1F763FB28B1AD +:1025D000A0680421C030F1F75DFB00B9FFDF0320E4 +:1025E000E7E790F8900010F0030F0DD10C20FEF7F4 +:1025F000B1FBA068A0F8845080F8886090F8901033 +:1026000041F0010180F89010A06890F8CB10FE29ED +:1026100018BF70BD90F86420002319465830FAF7AF +:102620001CF8002808BF70BDA06890F80011E9B33D +:10263000A1690978D1BB90F86500F9F7F7FFA8BB4D +:10264000A068B0F858100A2931D900F10801052214 +:10265000E06901F081FD0028A06804BF80F8005106 +:1026600070BDD0F8FC00017861B1411C0522E06921 +:1026700001F072FD002818BF70BDA068D0F8FC0002 +:10268000007830B9A068E169D0F8FC00401C01F086 +:1026900045FFA068D0F8FC000178491C01700120BA +:1026A000FEF758FBA06880F8005170BDFFE7A068F6 +:1026B00090F8041111B190F8051181B390F80E1142 +:1026C000002908BF70BD90F80F11002918BF70BD18 +:1026D00090F86500F9F7AAFF002818BF70BDA06840 +:1026E00090F85400012808BF012503D0022814BF28 +:1026F000FFDF0225A06890F85500012808BF0126D9 +:1027000003D0022814BFFFDF0226A168012D91F833 +:1027100010012BD0022D08BF022829D033E0FFE79B +:10272000B0F80611A0F84010B0F80811A0F8421057 +:10273000B0F80A11A0F84410B0F80C11A0F8461037 +:1027400080F8045190F865001D2804D0BDE8704061 +:102750001420FEF7FFBAFFF794FDFFF763FD152085 +:10276000FEF7F8FAA06880F8655070BD01280AD11C +:1027700091F81101012E04D0022E08BF022807D0C3 +:1027800001E0012804D0BDE870401620FEF7E2BA4F +:10279000BDE870400020FEF7FCBA70B5044690F822 +:1027A000640000250C2814D00D2818BF70BDB4F8A3 +:1027B0005800D4F8F810401C8988884218BF70BDB2 +:1027C000D4F84401FE4E0178002918BFFFDF45D13F +:1027D00022E0B4F85800B4F80211401C884218BF37 +:1027E00070BDD4F8FC00411C04F1080001F096FE15 +:1027F00002212046F9F755FCD4F8FC0000780028A7 +:1028000008BFFFDF0121FE20FEF7F0FA84F86450D4 +:10281000012084F8980070BD2188C180D4F8F800A8 +:10282000D4F8441140890881D4F8F800D4F8441150 +:1028300080894881D4F8F800D4F84411C08988818F +:10284000D4F844010571D4F8441109200870D4F873 +:10285000441120884880F078E9F798FA0121204651 +:10286000F9F71FFC03212046FDF795FFB068D0F86B +:10287000F8000078022818BFFFDF0221FE20FEF7D3 +:10288000B5FA84F8645070BD70B5CD4CA16891F86C +:102890006420162A11BF132A91F88E20002A62782C +:1028A0001BBF02206070002A70BD81F8C80000259F +:1028B00081F88D5081F88850D1F8F8000988408857 +:1028C000884218BFFFDFA068D0F8F800007803281E +:1028D00018BFFFDF0321FE20FEF788FAA068D0F8BA +:1028E00044110A78002A18BFFFDF19D10288CA8074 +:1028F000D0F8442190F8C8101171D0F844110D722D +:10290000D0F844210D211170D0F844210188518064 +:102910000088EEF77FF9EDF717FEE078E9F736FA71 +:10292000A06880F8645070BD10B5A54C207910F0F7 +:10293000020F08BF10BD6078002818BF10BDE06806 +:10294000C078192880F06981DFE800F05F4F0D8FB3 +:10295000F8F8A6223FF86F83B1F8F8F8F8F7E3E04B +:10296000F9F5F4F8F300A0680023012190F867203E +:102970005830F9F772FE002818BF10BD0821A06872 +:1029800080F86710002180F8881080F88C1010BD46 +:10299000A0680023194690F865205830F9F75DFECD +:1029A00018B1A168002081F88C00A06800231946A6 +:1029B00090F864205830F9F750FE002808BF10BD89 +:1029C0000020A16881F8880010BDA0680023194686 +:1029D00090F864205830F9F740FE002808BFFFDF68 +:1029E0000420A16881F8640010BDA0680023194686 +:1029F00090F864205830F9F730FE002808BFFFDF58 +:102A00000C20A16881F8640010BDA068002319465D +:102A100090F864205830F9F720FE002808BFFFDF47 +:102A20000D20A16881F8640010BDA068002319463C +:102A300090F864205830F9F710FE002808BFFFDF37 +:102A40000121A06880F88D105FF00F0180F86410FC +:102A500010BDA06890F86400122818BFFFDF0121A4 +:102A6000A06880F88E101121F0E7A06800231946B5 +:102A700090F864205830F9F7F0FD28B9A06890F874 +:102A80008E00002808BFFFDF0121A06880F88D10AC +:102A9000132180F8641010BDA06890F86400182815 +:102AA00018BFFFDF1A20A16881F8640010BDA0687C +:102AB000D0F8F81003884A889A4204BF097804299C +:102AC00019D190F86420002319465830F9F7C5FD54 +:102AD000002808BFFFDFA06890F8901011F0020FE7 +:102AE00004BF012180F8641005D0002180F888100F +:102AF000D0F8F8000170A0680023194690F865200E +:102B00005830F9F7AAFD002808BF10BD0020A168C1 +:102B100080E0A0680023194690F864205830F9F747 +:102B20009CFD002808BFFFDF0520A16881F8640034 +:102B300010BD30E01FE012E001E067E06DE0A0684A +:102B40000023194690F864205830F9F786FD0028D4 +:102B500008BFFFDF1C20A16881F86400E8E7A068D7 +:102B60000023194690F865205830F9F776FD0028C3 +:102B700008BFFFDFCAE7A0680023194690F8642069 +:102B80005830F9F76AFD002808BFFFDF1F20A16851 +:102B900081F86400CCE7A06890F8651021291DD069 +:102BA00090F86410232918BFFFDFC1D190F8F2100C +:102BB000002906BF90F8F3100029242102E000004C +:102BC0007C01002018BF80F864107FF4F9AE00216A +:102BD00080F864100846FEF7DCF8F1E690F8F21091 +:102BE000002907BF90F8F3100029242180F8651010 +:102BF0008CD1002180F8651080F87D1090F80E01CE +:102C000000281CBF0020FEF7C4F87FE7A168002061 +:102C100081F8650081F88C008AE7FFDF88E7000013 +:102C200070B58D4C0829207A63D2DFE801F0041AD0 +:102C30005A5A2662625A80B1F1F7EDFD012211461F +:102C40001046F1F7F0FFF2F7FDFC0020A072F1F75B +:102C5000A1FEBDE87040F2F76EB9BDE87040EFF735 +:102C6000E3BED4E90001EFF7DCFC2060A07A401C51 +:102C7000C0B2A07228281CD370BDA07A0025401EC7 +:102C8000C6B2E0683044F2F748FA10B9E1687F2034 +:102C90008855A07A272828BF01252846F2F782FC0C +:102CA000A07A282809D2401CC0B2A072282828BFC8 +:102CB00070BDBDE87040F1F76DBE207A00281CBFE2 +:102CC000012000F085F8F2F7C3F8F2F72CF90120A3 +:102CD000E07262480078E9F759F8BDE87040EFF714 +:102CE000A3BE002808BF70BD0020BDE8704000F002 +:102CF0006FB8FFDF70BD10B5574C207A002804BFB5 +:102D00000C2010BD00202072E072607AF0F7DAFA31 +:102D1000607AF0F724FD607AEFF75BFF00280CBFC4 +:102D20001F20002010BD002270B54B4C06460D46FA +:102D3000207A68B12272E272607AF0F7C3FA607AA0 +:102D4000F0F70DFD607AEFF744FF002808BFFFDFC2 +:102D50004248E560067070BD70B5050007D0A5F566 +:102D6000E8503F494C3881429CBF122070BD3A4C1C +:102D7000E068002804BF092070BD207A00281CBF2D +:102D80000C2070BD3748EFF7CAFE6072202804BFE0 +:102D90001F2070BDEFF73CFF2060002D1CBF2844B2 +:102DA0002060012065602072002000F011F80020F2 +:102DB00070BD2949CA7A002A04BF002070471F222B +:102DC000027000224270CB684360CA7201207047D3 +:102DD0002DE9F04184B00746EFF71AFF1E4D8046FB +:102DE000414668682C6800EB800046002046F0F7FA +:102DF0001DFCB04206DB6868811B4046EFF711FC02 +:102E00000446286040F2337621464046F0F70EFC37 +:102E1000B04204DA31464046EFF703FC0446002096 +:102E20008DF8000040F2E760039004208DF8050063 +:102E3000002F14BF012003208DF80400684602947F +:102E4000F0F7B3F8687A6946F0F72AF9002808BF66 +:102E5000FFDF04B0BDE8F081AC1200209C0100202F +:102E6000B5EB3C00212C02002DE9F0410C46124943 +:102E70000D68114A114908321160A0F12001312971 +:102E800001D301200CE0412810D040CC0C4F94E835 +:102E90000E0007EB8000241F50F8807C3046B847B6 +:102EA00020600548001D0560BDE8F0812046DEF782 +:102EB00097F9F5E706207047100502400100000170 +:102EC000FC48020010B5524800F038FA00B1FFDFAC +:102ED0004F48401C00F032FA002800D0FFDF10BD40 +:102EE0002DE9F14F4B4ED6F800B00127484800F0CD +:102EF0002DFADFF81C8128B95FF0000708F1010006 +:102F000000F03AFA444C00254FF0030901206060BC +:102F1000C4F80051C4F80451009931602060DFF812 +:102F2000FCA018E0DAF80000C00614D50E2000F06E +:102F300064F8EFF3108010F0010072B600D00120A9 +:102F4000C4F80493D4F8001119B9D4F8041101B9E4 +:102F500020BF00B962B6D4F8000118B9D4F8040152 +:102F60000028DFD0D4F804010028CFD137B1C6F84B +:102F700000B008F1010000F0E9F911E008F10100EA +:102F800000F0E4F90028B9D1C4F80893C4F804515A +:102F9000C4F800510E2000F030F81D4800F0ECF9A4 +:102FA0000020BDE8F88F2DE9F0438DB00D460646B0 +:102FB00000240DF110090DF1200817E004EB44077F +:102FC000102255F82710684601F0F2F805EB870744 +:102FD00010224846796801F0EBF86846FFF780FF59 +:102FE00010224146B86801F0E3F8641CB442E5DB06 +:102FF0000DB00020BDE8F08372E700F01F02012150 +:1030000091404009800000F1E020C0F88012704734 +:103010009D01002004E5004000E0004010ED00E0CC +:10302000AA4900200870704770B5A94D01232B6094 +:10303000A84B1C68002CFCD0002407E00E6806603A +:103040001E68002EFCD0001D091D641C9442F5D39F +:103050000020286018680028FCD070BD70B59B4E19 +:1030600004469D4D3078022800D0FFDFAC4200D3EB +:10307000FFDF71699948012903D847F23052944221 +:1030800001DD03224271491C7161291BC160934912 +:103090007078F0F705F8002800D1FFDF70BD70B53B +:1030A0008A4C0D466178884200D0FFDF8A4E082D99 +:1030B0004BD2DFE805F04A041E2D4A4A4A382078F0 +:1030C000022800D0FFDF03202070A078012801D063 +:1030D00020B108E0A06800F0B7FD04E004F10800AA +:1030E00007C8FFF7A1FF05202070BDE87040EFF78B +:1030F0009BBCEFF78DFD01466068F0F797FAB04290 +:1031000002D2616902290BD30320F0F74CFD12E0D3 +:10311000EFF77EFD01466068F0F788FAB042F3D21F +:10312000BDE870409AE7207802280AD0052806D02A +:10313000FFDF04202070BDE8704000F0BDB8022021 +:1031400000E00320F0F72FFDF3E7FFDF70BD70B55F +:103150000546EFF75DFD5D4C60602078012800D0EA +:10316000FFDF5E49012008700020087104208D6097 +:1031700048715948C860022020706078EFF790FFCE +:10318000002800D1FFDF70BD10B5504C207838B951 +:103190000220F0F71EFD18B90320F0F71AFD08B160 +:1031A000112010BD4E48EFF7BAFC6070202804D003 +:1031B000012020700020606110BD032010BD2DE9AA +:1031C000F041144600EB84070E4605463F1F00F011 +:1031D0004EFD4FF080521169484306EB8401091FF0 +:1031E000B14201D2012100E000211CB11269B4EB0F +:1031F000920F02D90920BDE8F0813A4A95420ED3D8 +:10320000AF420CD3854205D2874203D245EA06007D +:10321000800701D01020EEE7964200D309B10F20BD +:10322000E9E7314831490068884205D022463146F5 +:103230002846FFF7F9FE10E0FFF7A6FF0028DAD1D5 +:10324000224800218560C0E9036481704FF4A971B0 +:1032500004FB01F01830FFF77AFF0020CBE770B5D0 +:103260004FF08055044628691E49B1FBF0F08442B6 +:1032700001D20F2070BD00F0FAFCA04201D810204E +:1032800070BD194819490068884204D02869604314 +:1032900000F0DAFC0CE0FFF777FF0028F0D1296995 +:1032A0000A4861438160012181701148FFF74FFF97 +:1032B000002070BD00F024BF10B5044C6078EFF71B +:1032C00088FC00B9FFDF0020207010BDA0010020A5 +:1032D00004E5014000E40140105C0C00BC12002039 +:1032E0009F30020000600200B0000020BEBAFECA9B +:1032F0007C5E01004FF08050D0F83011062903D0D9 +:10330000D0F83011491C07D1D0F83411062905D363 +:10331000D0F83401401C01D00020704701207047D4 +:103320004FF08050D0F83011062905D1D0F8340183 +:10333000062801D30120704700207047002101704A +:10334000084670470146002008707047EFF310816F +:1033500001F0010172B60278012A01D0012200E0D9 +:1033600000220123037001B962B60AB10020704740 +:103370004FF400507047E9E7EFF3108111F0010FAF +:1033800072B64FF00002027000D162B600207047A2 +:10339000F2E700004C4909680160002070474A4983 +:1033A00008600020704701218A0720B1012804D05D +:1033B00042F204007047916700E0D1670020704737 +:1033C00042490120086042F20600704708B5042314 +:1033D0003E4A1907103230B1C1F80433106840F08A +:1033E000010010600BE0106820F001001060C1F8CF +:1033F00008330020C1F8080135480068009000201B +:1034000008BD011F0B2909D8304910310A6822F084 +:103410001E0242EA400008600020704742F20500A8 +:103420007047000100F18040C0F804190020704787 +:10343000000100F18040C0F8081900207047000129 +:1034400000F18040D0F80009086000207047012892 +:1034500001D9072070471F4A52F8200002680A432A +:10346000026000207047012801D907207047194ADF +:1034700052F8200002688A43026000207047012849 +:1034800001D907207047134A52F8200000680860ED +:1034900000207047020010494FF0000003D0012ABD +:1034A00001D0072070470A6070474FF0804100202C +:1034B000C1F808014FF0E020802180F800140121BC +:1034C000C0F80011704700000004004000050040F3 +:1034D00008010040C0490200780500406249634B82 +:1034E0000A6863499A42096801D1C1F31001016079 +:1034F000002070475C495D4B0A685D49091D9A428E +:1035000001D1C0F310000860002070475649574BA6 +:103510000A68574908319A4201D1C0F31000086087 +:103520000020704730B5504B504D1C6842F20803E4 +:10353000AC4202D0142802D203E0112801D318466D +:1035400030BDC3004B481844C0F81015C0F814250E +:10355000002030BD4449454B0A6842F209019A42B5 +:1035600002D0062802D203E0042801D3084670479F +:10357000404A012142F83010002070473A493B4B45 +:103580000A6842F209019A4202D0062802D203E0F8 +:10359000042801D308467047364A012102EBC000D7 +:1035A00041600020704770B52F4A304E314C15688D +:1035B00042F2090304EB8002B54204D0062804D28B +:1035C000C2F8001807E0042801D3184670BDC1F303 +:1035D0001000C2F80008002070BD70B5224A234ECA +:1035E000244C156842F2090304EB8002B54204D072 +:1035F000062804D2D2F8000807E0042801D31846B0 +:1036000070BDD2F80008C0F310000860002070BD43 +:10361000174910B50831184808601120154A0021D3 +:1036200002EBC003C3F81015C3F81415401C14288E +:10363000F6D3002006E0042804D302EB8003C3F88D +:10364000001807E002EB8003D3F80048C4F310042D +:10365000C3F80048401C0628EDD310BD04490648B5 +:103660000831086070470000B0000020BEBAFECAF2 +:1036700000F5014000F001400000FEFF7E4B1B689A +:1036800003B19847BFF34F8F7C4801687C4A01F42F +:10369000E06111430160BFF34F8FFEE710B5EFF318 +:1036A000108010F0010F72B601D0012400E0002458 +:1036B00000F0D9F850B1DDF72DFEEFF776F8F0F70E +:1036C00013FADFF7A2FB6F490020086004B962B665 +:1036D000002010BD70B50C460546EFF3108010F0C9 +:1036E000010F72B601D0012600E0002600F0BBF801 +:1036F00018B106B962B6082070BDDDF787FDDDF7A9 +:103700000DFE0246002043099B0003F1E02300F078 +:103710001F01D3F80031CB40D9071BD0202803D29A +:1037200022FA00F1C90722D141B2002906DA01F0DC +:103730000F0101F1E02191F8141D03E001F1E021F6 +:1037400091F800144909082911D281B101290ED03C +:1037500004290CD0401C6428D5D3DFF72DFB494940 +:10376000494808602046F0F7D9FD60B904E006B981 +:1037700062B641F2010070BD3F4804602DB1284699 +:10378000F0F719FE18B110242CE0404D19E028780C +:10379000022802D94FF4805424E0072400286878D6 +:1037A00001D0F8B908E0E8B120281BD8A878212872 +:1037B00018D8012816D001E0A87898B9E8780B2825 +:1037C00010D83349802081F8140DDDF7A7FD294674 +:1037D000F0F770F9EEF7A8FF00F07CFA2846DDF765 +:1037E0006BFD044606B962B61CB1FFF757FF2046D1 +:1037F00070BD002070BD10B5044600F034F800B173 +:1038000001202070002010BD224908600020704770 +:1038100070B50C4620490D681F49204E08310E60D6 +:10382000102807D011280CD012280FD0132811D03F +:10383000012013E0D4E90001FFF74CFF354620607A +:103840000DE0FFF72BFF0025206008E02068FFF760 +:10385000D2FF03E00F4920680860002020600E4876 +:10386000001D056070BD074807490068884201D106 +:103870000120704700207047B80100200CED00E0E7 +:103880000400FA05B0000020BEBAFECAC849020012 +:103890000BE000E0040000201005024001000001E0 +:1038A00000B5C44910F1080F08BFF82024D014DC7B +:1038B00010F1280F08BFD8201ED010F1140F08BF38 +:1038C000EC2019D010F1100F08BFF02014D010F127 +:1038D0000C0F08BFF4200FD00CE010F1040F08BF4C +:1038E000FC2009D0002818BF032805D0042804BFF5 +:1038F000086000BDFFDF00BD086000BD00B5AE4937 +:10390000012808BF032004D0022816BFFFDF0420CF +:1039100000BD086000BDA949002804BF086820F068 +:10392000010005D0012806BF086840F0010070477B +:103930000860704770B51E460546012924D0022A4A +:1039400004BF9F484FF47A710DD0012A04BF9D48EF +:103950004FF4C86107D0042A07BF9B4840F698017E +:103960009A4840F6E44144181846F1F744FE0444EE +:103970003046F1F75EFE20444FF47A7100F2712078 +:10398000B0FBF1F0281A70BD022A08BF4FF47A701C +:103990000AD0012A08BF4FF4C86005D0042A0CBF22 +:1039A00040F6980040F6E44049F608514418DBE739 +:1039B00070B514460546012908BF49F6CA660DD000 +:1039C000022B08BF824807D0012B08BF7D4803D0D7 +:1039D000042B0CBF7C487F4800F1FA061046F1F733 +:1039E00019FE012C08BF4FF47A710AD0022C08BFCF +:1039F0004FF4FA7105D0042C0CBF4FF4FA614FF468 +:103A0000FA51711A08444FF47A7100F28920B0FB20 +:103A1000F1F0281A801E70BD70B5144606460129C3 +:103A200030D0022B04BF66494FF47A700DD0012BC1 +:103A300004BF64494FF4C86007D0042B07BF624934 +:103A400040F69800614940F6E4400D181046F1F741 +:103A5000E1FD012C08BF4FF47A710AD0022C08BF97 +:103A60004FF4FA7105D0042C0CBF4FF4FA614FF4F7 +:103A7000FA51691A08444FF47A716438B0FBF1F0D6 +:103A8000301A70BD022B08BF4FF47A700AD0012B98 +:103A900008BF4FF4C86005D0042B0CBF40F6980057 +:103AA00040F6E44049F608514518CFE770B5164690 +:103AB0000446012908BF49F6CA650DD0022B08BF8C +:103AC000434807D0012B08BF3E4803D0042B0CBF4E +:103AD0003D48404800F1FA051046F1F78CFD0544D9 +:103AE0003046F1F7A6FD28444FF47A7100F2E14028 +:103AF000B0FBF1F0201A801E70BD2DE9F0410746A1 +:103B00001E460C4615461046082A16BF04284DF6D8 +:103B10008830F1F770FD07EB4701C1EBC71100EBEF +:103B2000C100012C08BF4FF47A710AD0022C08BFE3 +:103B30004FF4FA7105D0042C0CBF4FF4FA614FF426 +:103B4000FA5147182046F1F765FD381A4FF47A719B +:103B500000F60F60B0FBF1F42846F1F740FD204479 +:103B60003044401DBDE8F08170B5054614460E4650 +:103B70000846F1F740FD05EB4502C2EBC512C0EB6C +:103B8000C2053046F1F755FD2D1A2046082C16BF08 +:103B900004284DF68830F1F72EFD28444FF47A7151 +:103BA00000F6B730B0FBF1F52046F1F718FD2844D8 +:103BB000401D70BD0C15004010150040501600400F +:103BC00068360200A2240200D0FB010030D30100BD +:103BD00004360200C0D401002DE9FE430C468046A5 +:103BE000F9F7BAF9074698F80160204601A96A4634 +:103BF000ECF79BFC05000DD0012F02D00320BDE89F +:103C0000FE83204602AA0199ECF7B1FB0298B0F8B6 +:103C100003000AE0022F14D1042E12D3B8F80300D7 +:103C2000BDF80020011D914204D8001D80B2A919E1 +:103C3000814202D14FF00000E1E702D24FF00100D3 +:103C4000DDE74FF00200DAE70B4A022111600B4971 +:103C50000B68002BFCD0084B1B1D1860086800285F +:103C6000FCD00020106008680028FCD070474FF09E +:103C7000805040697047000004E5014000E40140C5 +:103C800002000B464FF00000014620D0012A04D06C +:103C9000022A04D0032A0DD103E0012002E0022011 +:103CA00015E00320072B05D2DFE803F00406080A1D +:103CB0000C0E100007207047012108E0022106E0E9 +:103CC000032104E0042102E0052100E00621EEF7D3 +:103CD00042BF0000F9480521817000210170417048 +:103CE0007047F7490A78012A05D0CA681044C860AD +:103CF0004038EFF768BC8A6810448860F8E700280D +:103D000019D00378EF49F04A13B1012B0ED011E01E +:103D10000379012B00D06BB943790BB1012B09D189 +:103D20008368643B8B4205D2C0680EE00379012BA7 +:103D300002D00BB10020704743790BB1012BF9D1B0 +:103D4000C368643B8B42F5D280689042F2D8012070 +:103D50007047DB4910B501220A700279A2B1002236 +:103D60000A71427992B104224A718268D34C52326C +:103D70008A60C0681434C8606060EEF749FFCF49BC +:103D800020600220887010BD0322E9E70322EBE7E0 +:103D900070B5044609B1012000E00320C84D0021A0 +:103DA0002970217901B100202871607968B104205F +:103DB000C24E6871A168F068EEF733FCA860E06855 +:103DC0005230E8600320B07070BD0320F0E72DE9A9 +:103DD000F04105460226EFF722FB006800B1FFDF45 +:103DE000B64C01273DB12878B0B1012805D0022892 +:103DF00010D0032813D027710CE06868C82807D3B7 +:103E0000EFF747FC20B16868FFF76BFF012603E07E +:103E1000002601E000F05CF93046BDE8F081207832 +:103E20000028F7D16868FFF76AFF0028E3D06868C8 +:103E3000017879B1A078042800D0FFDF01216868FB +:103E4000FFF7A6FF9E49E078EFF72AF90028E1D1B5 +:103E5000FFDFDFE7FFF77DFF6770DBE72DE9F04766 +:103E6000964C8846E178884200D0FFDFDFF84C921C +:103E700000250127924E09F11409B8F1080F75D2F7 +:103E8000DFE808F0040C28527A808D95A07803288A +:103E900002D0022800D0FFDFBDE8F087A078032819 +:103EA00002D0022800D0FFDF0420A0702571207806 +:103EB000002878D1FFF715FF3078012806D0B068C8 +:103EC000E06000F031F92061002060E0E078EEF77A +:103ED000E4FFF5E7A078032802D0022800D0FFDF36 +:103EE000207800286DD1A078032816D0EEF790FE38 +:103EF00001464F46D9F80000EFF798FB00280EDB8B +:103F0000796881420BDB081AF0606D49E078EFF7C1 +:103F1000C7F80028C0D1FFDFBEE7042028E0042056 +:103F2000EFF741FEA570B7E7A078032802D002287A +:103F300000D0FFDF207888BBA078032817D0EEF7E9 +:103F400067FE01464F46D9F80000EFF76FFB0028E7 +:103F5000E5DB79688142E2DB081AF0605849E078D5 +:103F6000EFF79EF8002897D1FFDF95E740E00520A6 +:103F7000EFF719FEA7708FE7A078042800D0FFDFC5 +:103F8000022004E0A078042800D0FFDF0120A1680F +:103F90008847FFF71CFF054630E004E011E0A078F9 +:103FA000042800D0FFDFBDE8F04700F091B8A0780A +:103FB000042804D0617809B1022800D0FFDF2078FE +:103FC00018B1BDE8F04700F08CB8207920B1062088 +:103FD000EFF7E9FD2571CDE7607838B13849E07831 +:103FE000EFF75EF800B9FFDF657055E70720BFE720 +:103FF000FFDF51E73DB1012D03D0FFDF022DF9D1E5 +:104000004AE70420C3E70320C1E770B5050004D0E8 +:104010002A4CA078052806D101E0102070BD0820A8 +:10402000EFF7D7FD08B1112070BD2848EEF777FDF6 +:10403000E070202803D00020A560A07070BD032090 +:1040400070BD1E4810B5017809B1112010BD8178EE +:10405000052906D0012906D029B1012101700020CF +:1040600010BD0F2010BD00F03CF8F8E770B5134C00 +:104070000546A07808B1012809D155B12846FFF7B7 +:104080003EFE40B1287840B1A078012809D00F2029 +:1040900070BD102070BD072070BD2846FFF759FE87 +:1040A00003E000212846FFF773FE0549E078EEF7AC +:1040B000F7FF00B9FFDF002070BD0000BC01002049 +:1040C000CC1200203D860100FF1FA1075D3E0200CB +:1040D0000A4810B5006900F01FF8BDE81040EEF77F +:1040E000A3BC064810B5C078EEF773FD00B9FFDF3A +:1040F0000820EFF758FDBDE81040EBE5BC010020BB +:1041000010B5134C2060201D016011481030026072 +:10411000001D0360002010BD0E490A6848F202131A +:104120009A4302430A6070470A4A116848F2021330 +:1041300001EA0300994311607047054B02465B4258 +:1041400010201344FC2B01D81160002070470000A0 +:1041500000060040C806024040EA010310B59B0774 +:104160000FD1042A0DD310C808C9121F9C42F8D0E1 +:1041700020BA19BA884201D9012010BD4FF0FF3092 +:1041800010BD1AB1D30703D0521C07E0002010BDA8 +:1041900010F8013B11F8014B1B1B07D110F8013B34 +:1041A00011F8014B1B1B01D1921EF1D1184610BD15 +:1041B000032A40F2308010F0030C00F0158011F853 +:1041C000013BBCF1020F624498BF11F801CB00F82B +:1041D000013B38BF11F8013BA2F1040298BF00F87F +:1041E00001CB38BF00F8013B11F0030300F025803C +:1041F000083AC0F0088051F8043B083A51F804CB63 +:10420000A0E80810F5E7121D5CBF51F8043B40F828 +:10421000043BAFF30080D20724BF11F8013B11F833 +:1042200001CB48BF11F8012B24BF00F8013B00F877 +:1042300001CB48BF00F8012B704710B5203AC0F001 +:104240000B80B1E81850203AA0E81850B1E8185097 +:10425000A0E81850BFF4F5AF5FEA027C24BFB1E8D4 +:104260001850A0E8185044BF18C918C0BDE8104045 +:104270005FEA827C24BF51F8043B40F8043B08BF4E +:104280007047D20728BF31F8023B48BF11F8012B15 +:1042900028BF20F8023B48BF00F8012B704702F00E +:1042A000FF0343EA032242EA024200F002B84FF061 +:1042B00000020429C0F0128010F0030C00F01B80F3 +:1042C000CCF1040CBCF1020F18BF00F8012BA8BF01 +:1042D00020F8022BA1EB0C0100F00DB85FEAC17CC5 +:1042E00024BF00F8012B00F8012B48BF00F8012B78 +:1042F00070474FF0000200B51346944696462039A9 +:1043000022BFA0E80C50A0E80C50B1F12001BFF48E +:10431000F7AF090728BFA0E80C5048BF0CC05DF8F4 +:1043200004EB890028BF40F8042B08BF704748BF42 +:1043300020F8022B11F0804F18BF00F8012B7047B6 +:10434000FEDF04207146084219D10699124A9142B3 +:1043500015DC069902394878DF2810D10878FE2844 +:1043600007D0FF280BD14FF001004FF000020B4B9C +:10437000184741F201000099019A084B1847084B71 +:10438000002B02D01B68DB6818474FF0FF307146E6 +:104390004FF00002014B1847006002007D3602001A +:1043A00004000020184819497047FFF7FBFFDCF7AD +:1043B00005FF00BD4FF4805015490968884203D1BC +:1043C000144A13605B68184700BD000020BFFDE77A +:1043D0004FF480500E490968884210D10E4B18687E +:1043E0004FF0FF318842F1D080F308884FF0202150 +:1043F000884204DD0948026803210A430260084834 +:10440000804708488047FFDFE0120020E0120020CC +:104410000000002004000020006002001409004099 +:10442000F5430100B543020004207146084202D062 +:10443000EFF3098101E0EFF3088188690238007821 +:10444000102813DB20280FDB2C280BDB0A4A12680C +:104450000A4B9A4203D1602804DB094A1047022024 +:1044600008607047074A1047074A1047074A126812 +:104470002C32126810470000B0000020BEBAFECAFD +:1044800021130000692E02001138020004000020F0 +:104490000D4B0E4908470E4B0C4908470D4B0B4975 +:1044A00008470D4B094908470C4B084908470C4B76 +:1044B000064908470B4B054908470B4B034908477A +:1044C0000A4B02490847000049BB00000D2F0000BD +:1044D0006D2C0000092B0000972A00000F2D000012 +:1044E0003D13000053280000C1BD0000C9110000A9 +:1044F00000210160017170470021016081807047D7 +:10450000002101604160017270470A684B680260D7 +:104510004360B1F808C0A0F808C070470A6802609C +:104520000B79037170470000B19500003B970000C4 +:1045300099980000BD980000F79800002B990000A2 +:104540005D9900008D990000039A00008996000093 +:10455000A7120000A712000075440000C14400002B +:10456000E5440000794500009546000057470000EB +:1045700089470000714800000349000057490000C6 +:104580003D4A00005D4A0000DF15000003160000F0 +:10459000331500008715000035160000C91600000D +:1045A0005B6000000B620000DF650000F566000044 +:1045B0007F670000FD6700006168000085690000FA +:1045C000556A0000C16A00007F4A0000854A000069 +:1045D0008F4A000085410000F74A00005941000061 +:1045E0007B4C0000B34C0000294D00000F4E000032 +:1045F000254E0000A7120000A7120000A71200001D +:10460000A7120000A7120000A7120000A7120000C6 +:10461000A7120000BF24000045250000612500000E +:104620007D2500000B270000A7250000B125000014 +:10463000F325000015260000F126000033270000B6 +:10464000A7120000A71200005F8300007F83000014 +:1046500081830000C5830000F3830000E184000033 +:104660006F85000083850000D1850000C1860000B1 +:10467000678800009189000073730000A989000019 +:10468000A7120000A7120000C9B4000033B6000052 +:1046900087B60000F3B60000A3B7000001000000D9 +:1046A00000000000100110013A0200001A02000090 +:1046B000F3900000E1900000FFFFFFFF0000FFFF0C +:1046C000C5AC0000253D000065200000BD73000062 +:1046D000598E0000000000000000020000000000F1 +:1046E00000020000000000000001000000000000C7 +:1046F0000B810000EB800000598100004124000084 +:1047000003240000232400002FA800005BA8000061 +:1047100063AA0000515900007981000000000000E8 +:10472000A98100008F2400000000000000000000AC +:104730000000000045A9000000000000E55900004D +:10474000000000004808000048080000D3560000A0 +:10475000D35600005144000071AB00003F760000CA +:10476000771F0000E31D02004F9401001157000065 +:104770001157000073440000D3AB0000C376000063 +:10478000E91F0000111E0200639401007001700116 +:10479000400038005C0024004801000200000300D3 +:1047A000656C746200000000000000000000000062 +:1047B0000000000087000000000000000000000072 +:1047C00000000000BE83605ADB0B376038A5F5AAF5 +:1047D0009183886C010000007911010041200100E3 +:1047E00000000001020603040500000007000000AD +:1047F00000000000060000000A0000003200000077 +:1048000073000000B4000000DD860100DB0C020034 +:10481000CB6C010065AE010059F0010065AE0100EE +:10482000616E01001DB00100E3E701001DB0010051 +:10483000476B0100B1AF010087EF0100B1AF01008C +:10484000C76C010079AE0100E9DF010079AE01001B +:104850005972010091B20100EFF0010091B2010024 +:104860000300000001555555D6BE898E0000C706CD +:10487000C70CC71200006B030F06B3080000B70493 +:10488000A708970CF401FA00960064004B00320070 +:104890001E0014000A000500020001000041000093 +:1048A00000000000AAAED7AB154120100C0802177B +:1048B0000D0101020909010106020918180301018D +:1048C0000909030305000000FE000000FE000000CF +:1048D000FE555555252627D6BE898E00F401FA00CF +:1048E000960064004B0032001E0014000A00050010 +:1048F000020001002541000000000000DD3402003C +:10490000F53402000D350200253502005535020050 +:104910007D350200A7350200DB3502005F32020060 +:10492000BF310200B53202003B4102003D330200BC +:104930004D330200793302009F3C0100A73C010087 +:10494000B93C0100A7330200C133020095330200D5 +:104950009F330200CD33020003340200B52E020063 +:1049600023340200313402003F3402004F3402008D +:10497000673402007F34020095340200B52E020035 +:104980000000000077B90000CDB90000E3B90000D5 +:10499000813C0200E12E0200A72F02000B40020022 +:1049A000434002006D400200493B0100C93E010046 +:1049B000B52E0200B52E0200B52E0200B52E020063 +:1049C0001C0500402005004000100200EC490200D8 +:1049D00008000020D001000044110000244A020019 +:1049E000D801002008110000A0110000011813C810 +:1049F000140250201A0102227C2720FB349B5F8086 +:104A00001280021A10138B091B2048041ACE0401CD +:104A1000200B50A40AAC01300912CB637F010B6854 +:044A2000CC10A00016 +:00000001FF diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/toolchain/armgcc/armgcc_s132_nrf52832_xxaa.ld b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/toolchain/armgcc/armgcc_s132_nrf52832_xxaa.ld new file mode 100644 index 0000000..d1628c3 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/toolchain/armgcc/armgcc_s132_nrf52832_xxaa.ld @@ -0,0 +1,33 @@ +/* Linker script to configure memory regions. */ + +SEARCH_DIR(.) +GROUP(-lgcc -lc -lnosys) + +MEMORY +{ + FLASH (rx) : ORIGIN = 0x26000, LENGTH = 0x5a000 + RAM (rwx) : ORIGIN = 0x200014b8, LENGTH = 0xeb48 +} + +SECTIONS +{ +} + +SECTIONS +{ + . = ALIGN(4); + .mem_section_dummy_ram : + { + } + +} INSERT AFTER .data; + +SECTIONS +{ + .mem_section_dummy_rom : + { + } + +} INSERT AFTER .text + +INCLUDE "nrf_common.ld" diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/toolchain/iar/iar_s132_nrf52832_xxaa.icf b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/toolchain/iar/iar_s132_nrf52832_xxaa.icf new file mode 100644 index 0000000..47cf577 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/components/softdevice/s132/toolchain/iar/iar_s132_nrf52832_xxaa.icf @@ -0,0 +1,36 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x26000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x26000; +define symbol __ICFEDIT_region_ROM_end__ = 0x7ffff; +define symbol __ICFEDIT_region_RAM_start__ = 0x200014b8; +define symbol __ICFEDIT_region_RAM_end__ = 0x2000ffff; +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = ; +define symbol __ICFEDIT_size_heap__ = ; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; +define block RO_END with alignment = 8, size = 0 { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +keep { section .intvec }; +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; +place in ROM_region { readonly, + block RO_END }; +place in RAM_region { readwrite, + block CSTACK, + block HEAP }; + |