| /* |
| * Copyright (C) 2012 - 2014 Andrew Duggan |
| * Copyright (C) 2012 - 2014 Synaptics Inc |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #ifndef _FIRMWAREIMAGE_H_ |
| #define _FIRMWAREIMAGE_H_ |
| |
| #include "rmidevice.h" |
| #include "updateutil.h" |
| |
| #define RMI_IMG_CHECKSUM_OFFSET 0 |
| #define RMI_IMG_IO_OFFSET 0x06 |
| #define RMI_IMG_BOOTLOADER_VERSION_OFFSET 0x07 |
| #define RMI_IMG_IMAGE_SIZE_OFFSET 0x08 |
| #define RMI_IMG_CONFIG_SIZE_OFFSET 0x0C |
| #define RMI_IMG_PACKAGE_ID_OFFSET 0x1A |
| #define RMI_IMG_FW_BUILD_ID_OFFSET 0x50 |
| |
| #define RMI_IMG_PRODUCT_ID_OFFSET 0x10 |
| #define RMI_IMG_PRODUCT_INFO_OFFSET 0x1E |
| |
| #define RMI_IMG_FW_OFFSET 0x100 |
| |
| #define RMI_IMG_LOCKDOWN_V2_OFFSET 0xD0 |
| #define RMI_IMG_LOCKDOWN_V2_SIZE 0x30 |
| |
| #define RMI_IMG_LOCKDOWN_V3_OFFSET 0xC0 |
| #define RMI_IMG_LOCKDOWN_V3_SIZE 0x40 |
| |
| #define RMI_IMG_LOCKDOWN_V5_OFFSET 0xB0 |
| #define RMI_IMG_LOCKDOWN_V5_SIZE 0x50 |
| |
| // Leon add for BL_V7 |
| #define RMI_IMG_V10_CNTR_ADDR_OFFSET 0x0C |
| |
| struct container_descriptor { |
| unsigned char content_checksum[4]; |
| unsigned char container_id[2]; |
| unsigned char minor_version; |
| unsigned char major_version; |
| unsigned char reserved_08; |
| unsigned char reserved_09; |
| unsigned char reserved_0a; |
| unsigned char reserved_0b; |
| unsigned char container_option_flags[4]; |
| unsigned char content_options_length[4]; |
| unsigned char content_options_address[4]; |
| unsigned char content_length[4]; |
| unsigned char content_address[4]; |
| }; |
| |
| enum container_id { |
| TOP_LEVEL_CONTAINER = 0, |
| UI_CONTAINER, |
| UI_CONFIG_CONTAINER, |
| BL_CONTAINER, |
| BL_IMAGE_CONTAINER, |
| BL_CONFIG_CONTAINER, |
| BL_LOCKDOWN_INFO_CONTAINER, |
| PERMANENT_CONFIG_CONTAINER, |
| GUEST_CODE_CONTAINER, |
| BL_PROTOCOL_DESCRIPTOR_CONTAINER, |
| UI_PROTOCOL_DESCRIPTOR_CONTAINER, |
| RMI_SELF_DISCOVERY_CONTAINER, |
| RMI_PAGE_CONTENT_CONTAINER, |
| GENERAL_INFORMATION_CONTAINER, |
| DEVICE_CONFIG_CONTAINER, |
| FLASH_CONFIG_CONTAINER, |
| GUEST_SERIALIZATION_CONTAINER, |
| GLOBAL_PARAMETERS_CONTAINER, |
| CORE_CODE_CONTAINER, |
| CORE_CONFIG_CONTAINER, |
| DISPLAY_CONFIG_CONTAINER, |
| EXTERNAL_TOUCH_AFE_CONFIG_CONTAINER, |
| UTILITY_CONTAINER, |
| UTILITY_PARAMETER_CONTAINER, |
| }; |
| // BL_V7 end |
| |
| class FirmwareImage |
| { |
| public: |
| FirmwareImage() : m_firmwareBuildID(0), m_packageID(0), m_firmwareData(NULL), m_configData(NULL), m_lockdownData(NULL), |
| m_memBlock(NULL) |
| {} |
| int Initialize(const char * filename); |
| int VerifyImageMatchesDevice(unsigned long deviceFirmwareSize, |
| unsigned long deviceConfigSize); |
| unsigned char * GetFirmwareData() { return m_firmwareData; } |
| unsigned char * GetConfigData() { return m_configData; } |
| unsigned char * GetFlashConfigData() { return m_flashConfigData; } |
| unsigned char * GetLockdownData() { return m_lockdownData; } |
| unsigned long GetFirmwareSize() { return m_firmwareSize; } |
| unsigned long GetConfigSize() { return m_configSize; } |
| unsigned long GetFlashConfigSize() { return m_flashConfigSize; } |
| unsigned long GetLockdownSize() { return m_lockdownSize; } |
| unsigned long GetFirmwareID() { return m_firmwareBuildID; } |
| bool HasIO() { return m_io; } |
| ~FirmwareImage(); |
| |
| private: |
| unsigned long Checksum(unsigned short * data, unsigned long len); |
| void PrintHeaderInfo(); |
| void ParseHierarchicalImg(); // BL_V7 |
| |
| private: |
| unsigned long m_checksum; |
| unsigned long m_firmwareSize; |
| unsigned long m_configSize; |
| unsigned long m_flashConfigSize; |
| unsigned long m_lockdownSize; |
| long m_imageSize; |
| unsigned long m_firmwareBuildID; |
| unsigned short m_packageID; |
| unsigned char m_bootloaderVersion; |
| unsigned char m_io; |
| char m_productID[RMI_PRODUCT_ID_LENGTH + 1]; |
| unsigned short m_productInfo; |
| |
| unsigned char * m_firmwareData; |
| unsigned char * m_configData; |
| unsigned char * m_flashConfigData; |
| unsigned char * m_lockdownData; |
| unsigned char * m_memBlock; |
| unsigned long m_cntrAddr; // BL_V7 |
| }; |
| |
| #endif // _FIRMWAREIMAGE_H_ |