| /* |
| * The MIT License (MIT) |
| * |
| * Copyright (c) 2025 Ennebi Elettronica (https://ennebielettronica.com) |
| * |
| * Permission is hereby granted, free of charge, to any person obtaining a copy |
| * of this software and associated documentation files (the "Software"), to deal |
| * in the Software without restriction, including without limitation the rights |
| * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
| * copies of the Software, and to permit persons to whom the Software is |
| * furnished to do so, subject to the following conditions: |
| * |
| * The above copyright notice and this permission notice shall be included in |
| * all copies or substantial portions of the Software. |
| * |
| * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
| * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
| * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
| * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
| * THE SOFTWARE. |
| * |
| * This file is part of the TinyUSB stack. |
| */ |
| |
| #ifndef _TUSB_MTP_H_ |
| #define _TUSB_MTP_H_ |
| |
| #include <stdint.h> |
| #include <stdbool.h> |
| #include <time.h> |
| #include "tusb_option.h" |
| |
| #if (CFG_TUD_ENABLED && CFG_TUD_MTP) |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| #define TU_ARRAY_LEN(a) (sizeof(a)/sizeof(a[0])) |
| #define STORAGE_ID(physical_id, logical_id) ( (((uint32_t)physical_id & 0xFFFF) << 16) | ((uint32_t)logical_id & 0x0000FFFF) ) |
| typedef uint16_t wchar16_t; |
| |
| //--------------------------------------------------------------------+ |
| // Media Transfer Protocol Class Constant |
| //--------------------------------------------------------------------+ |
| |
| // Media Transfer Protocol Subclass |
| typedef enum { |
| MTP_SUBCLASS_STILL_IMAGE = 1 |
| } mtp_subclass_type_t; |
| |
| // MTP Protocol. |
| typedef enum { |
| MTP_PROTOCOL_PIMA_15470 = 1, ///< Picture Transfer Protocol (PIMA 15470) |
| } mtp_protocol_type_t; |
| |
| // PTP/MTP protocol phases |
| typedef enum { |
| MTP_PHASE_IDLE = 0, |
| MTP_PHASE_COMMAND, |
| MTP_PHASE_DATA, |
| MTP_PHASE_DATA_IN, |
| MTP_PHASE_DATA_OUT, |
| MTP_PHASE_RESPONSE, |
| MTP_PHASE_RESPONSE_QUEUED, |
| MTP_PHASE_ERROR, |
| MTP_PHASE_NONE, |
| } mtp_phase_type_t; |
| |
| // PTP/MTP Class requests, PIMA 15740-2000: D.5.2 |
| typedef enum |
| { |
| MTP_REQ_CANCEL = 0x64, |
| MTP_REQ_GET_EXT_EVENT_DATA = 0x65, |
| MTP_REQ_RESET = 0x66, |
| MTP_REQ_GET_DEVICE_STATUS = 0x67, |
| } mtp_class_request_t; |
| |
| // PTP/MTP Container type |
| typedef enum |
| { |
| MTP_CONTAINER_TYPE_UNDEFINED = 0, |
| MTP_CONTAINER_TYPE_COMMAND_BLOCK = 1, |
| MTP_CONTAINER_TYPE_DATA_BLOCK = 2, |
| MTP_CONTAINER_TYPE_RESPONSE_BLOCK = 3, |
| MTP_CONTAINER_TYPE_EVENT_BLOCK = 4, |
| } mtp_container_type_t; |
| |
| // MTP 1.1 Appendix A: Object formats |
| typedef enum |
| { |
| // ---- Base formats ---- |
| MTP_OBJ_FORMAT_UNDEFINED = 0x3000u, // Undefined object |
| MTP_OBJ_FORMAT_ASSOCIATION = 0x3001u, // Association (for example, a folder) |
| MTP_OBJ_FORMAT_SCRIPT = 0x3002u, // Device model-specific script |
| MTP_OBJ_FORMAT_EXECUTABLE = 0x3003u, // Device model-specific binary executable |
| MTP_OBJ_FORMAT_TEXT = 0x3004u, // Text file |
| MTP_OBJ_FORMAT_HTML = 0x3005u, // Hypertext Markup Language file (text) |
| MTP_OBJ_FORMAT_DPOF = 0x3006u, // Digital Print Order Format file (text) |
| MTP_OBJ_FORMAT_AIFF = 0x3007u, // Audio clip (AIFF) |
| MTP_OBJ_FORMAT_WAV = 0x3008u, // Audio clip (WAV) |
| MTP_OBJ_FORMAT_MP3 = 0x3009u, // MPEG-1 Layer III audio (ISO/IEC 13818-3) |
| MTP_OBJ_FORMAT_AVI = 0x300Au, // Video clip (AVI) |
| MTP_OBJ_FORMAT_MPEG = 0x300Bu, // Video clip (MPEG) |
| MTP_OBJ_FORMAT_ASF = 0x300Cu, // Microsoft Advanced Streaming Format (video) |
| |
| // ---- Image formats ---- |
| MTP_OBJ_FORMAT_UNDEFINED_IMAGE = 0x3800u, // Undefined image object |
| MTP_OBJ_FORMAT_EXIF_JPEG = 0x3801u, // Exchangeable Image Format, JEIDA standard |
| MTP_OBJ_FORMAT_TIFF_EP = 0x3802u, // Tag Image File Format for Electronic Photography |
| MTP_OBJ_FORMAT_FLASHPIX = 0x3803u, // Structured Storage Image Format (FlashPix) |
| MTP_OBJ_FORMAT_BMP = 0x3804u, // Microsoft Windows Bitmap file |
| MTP_OBJ_FORMAT_CIFF = 0x3805u, // Canon Camera Image File Format |
| MTP_OBJ_FORMAT_UNDEFINED_3806 = 0x3806u, // Reserved / Undefined |
| MTP_OBJ_FORMAT_GIF = 0x3807u, // Graphics Interchange Format |
| MTP_OBJ_FORMAT_JFIF = 0x3808u, // JPEG File Interchange Format |
| MTP_OBJ_FORMAT_CD = 0x3809u, // PhotoCD Image Pac |
| MTP_OBJ_FORMAT_PICT = 0x380Au, // Quickdraw Image Format |
| MTP_OBJ_FORMAT_PNG = 0x380Bu, // Portable Network Graphics |
| MTP_OBJ_FORMAT_UNDEFINED_380C = 0x380Cu, // Reserved / Undefined |
| MTP_OBJ_FORMAT_TIFF = 0x380Du, // Tag Image File Format (baseline) |
| MTP_OBJ_FORMAT_TIFF_IT = 0x380Eu, // Tag Image File Format for IT (graphic arts) |
| MTP_OBJ_FORMAT_JP2 = 0x380Fu, // JPEG2000 Baseline File Format |
| MTP_OBJ_FORMAT_JPX = 0x3810u, // JPEG2000 Extended File Format |
| |
| // ---- Firmware & misc ---- |
| MTP_OBJ_FORMAT_UNDEFINED_FIRMWARE = 0xB802u, // Undefined Firmware |
| MTP_OBJ_FORMAT_WBMP = 0xB803u, // Wireless Application Protocol Bitmap Format (.wbmp) |
| MTP_OBJ_FORMAT_WINDOWS_IMAGE = 0xB881u, // Windows Image Format |
| MTP_OBJ_FORMAT_JPEGXR = 0xB804u, // JPEG XR (.hdp, .jxr, .wdp) |
| |
| // ---- Audio formats ---- |
| MTP_OBJ_FORMAT_UNDEFINED_AUDIO = 0xB900u, // Undefined audio object |
| MTP_OBJ_FORMAT_WMA = 0xB901u, // Windows Media Audio |
| MTP_OBJ_FORMAT_OGG = 0xB902u, // OGG container |
| MTP_OBJ_FORMAT_AAC = 0xB903u, // Advanced Audio Coding (.aac) |
| MTP_OBJ_FORMAT_AUDIBLE = 0xB904u, // Audible format |
| MTP_OBJ_FORMAT_FLAC = 0xB906u, // Free Lossless Audio Codec |
| MTP_OBJ_FORMAT_QCELP = 0xB907u, // Qualcomm Code Excited Linear Prediction (.qcp) |
| MTP_OBJ_FORMAT_AMR = 0xB908u, // Adaptive Multi-Rate audio (.amr) |
| |
| // ---- Video formats ---- |
| MTP_OBJ_FORMAT_UNDEFINED_VIDEO = 0xB980u, // Undefined video object |
| MTP_OBJ_FORMAT_WMV = 0xB981u, // Windows Media Video |
| MTP_OBJ_FORMAT_MP4 = 0xB982u, // MP4 Container (ISO 14496-1) |
| MTP_OBJ_FORMAT_MP2 = 0xB983u, // MPEG-1 Layer II audio |
| MTP_OBJ_FORMAT_3GP = 0xB984u, // 3GP Container |
| MTP_OBJ_FORMAT_3G2 = 0xB985u, // 3GPP2 Container |
| MTP_OBJ_FORMAT_AVCHD = 0xB986u, // AVCHD (MPEG-4 AVC + Dolby Digital) |
| MTP_OBJ_FORMAT_ATSC_TS = 0xB987u, // ATSC-compliant MPEG-2 Transport Stream |
| MTP_OBJ_FORMAT_DVB_TS = 0xB988u, // DVB-compliant MPEG-2 Transport Stream |
| |
| // ---- Collections ---- |
| MTP_OBJ_FORMAT_UNDEFINED_COLLECTION = 0xBA00u, // Undefined collection |
| MTP_OBJ_FORMAT_ABSTRACT_MULTIMEDIA_ALBUM = 0xBA01u, // Abstract Multimedia Album |
| MTP_OBJ_FORMAT_ABSTRACT_IMAGE_ALBUM = 0xBA02u, // Abstract Image Album |
| MTP_OBJ_FORMAT_ABSTRACT_AUDIO_ALBUM = 0xBA03u, // Abstract Audio Album |
| MTP_OBJ_FORMAT_ABSTRACT_VIDEO_ALBUM = 0xBA04u, // Abstract Video Album |
| MTP_OBJ_FORMAT_ABSTRACT_AV_PLAYLIST = 0xBA05u, // Abstract Audio & Video Playlist |
| MTP_OBJ_FORMAT_ABSTRACT_CONTACT_GROUP = 0xBA06u, // Abstract Contact Group |
| MTP_OBJ_FORMAT_ABSTRACT_MESSAGE_FOLDER = 0xBA07u, // Abstract Message Folder |
| MTP_OBJ_FORMAT_ABSTRACT_CHAPTERED_PRODUCTION = 0xBA08u, // Abstract Chaptered Production |
| MTP_OBJ_FORMAT_ABSTRACT_AUDIO_PLAYLIST = 0xBA09u, // Abstract Audio Playlist |
| MTP_OBJ_FORMAT_ABSTRACT_VIDEO_PLAYLIST = 0xBA0Au, // Abstract Video Playlist |
| MTP_OBJ_FORMAT_ABSTRACT_MEDIACAST = 0xBA0Bu, // Abstract Mediacast (RSS enclosure) |
| |
| // ---- Playlist formats ---- |
| MTP_OBJ_FORMAT_WPL_PLAYLIST = 0xBA10u, // Windows Media Player Playlist (.wpl) |
| MTP_OBJ_FORMAT_M3U_PLAYLIST = 0xBA11u, // M3U Playlist |
| MTP_OBJ_FORMAT_MPL_PLAYLIST = 0xBA12u, // MPL Playlist |
| MTP_OBJ_FORMAT_ASX_PLAYLIST = 0xBA13u, // ASX Playlist |
| MTP_OBJ_FORMAT_PLS_PLAYLIST = 0xBA14u, // PLS Playlist |
| |
| // ---- Document formats ---- |
| MTP_OBJ_FORMAT_UNDEFINED_DOC = 0xBA80u, // Undefined Document |
| MTP_OBJ_FORMAT_ABSTRACT_DOC = 0xBA81u, // Abstract Document |
| MTP_OBJ_FORMAT_XML_DOC = 0xBA82u, // XML Document |
| MTP_OBJ_FORMAT_DOC = 0xBA83u, // Microsoft Word Document |
| MTP_OBJ_FORMAT_MHT_DOC = 0xBA84u, // MHT Compiled HTML Document |
| MTP_OBJ_FORMAT_XLS = 0xBA85u, // Microsoft Excel Spreadsheet |
| MTP_OBJ_FORMAT_PPT = 0xBA86u, // Microsoft PowerPoint Presentation |
| |
| // ---- Messaging ---- |
| MTP_OBJ_FORMAT_UNDEFINED_MSG = 0xBB00u, // Undefined Message |
| MTP_OBJ_FORMAT_ABSTRACT_MSG = 0xBB01u, // Abstract Message |
| |
| // ---- Bookmarks ---- |
| MTP_OBJ_FORMAT_UNDEFINED_BOOKMARK = 0xBB10u, // Undefined Bookmark |
| MTP_OBJ_FORMAT_ABSTRACT_BOOKMARK = 0xBB11u, // Abstract Bookmark |
| |
| // ---- Appointments ---- |
| MTP_OBJ_FORMAT_UNDEFINED_APPT = 0xBB20u, // Undefined Appointment |
| MTP_OBJ_FORMAT_ABSTRACT_APPT = 0xBB21u, // Abstract Appointment |
| MTP_OBJ_FORMAT_VCALENDAR1 = 0xBB22u, // vCalendar 1.0 |
| |
| // ---- Tasks ---- |
| MTP_OBJ_FORMAT_UNDEFINED_TASK = 0xBB40u, // Undefined Task |
| MTP_OBJ_FORMAT_ABSTRACT_TASK = 0xBB41u, // Abstract Task |
| MTP_OBJ_FORMAT_ICALENDAR = 0xBB42u, // iCalendar |
| |
| // ---- Notes ---- |
| MTP_OBJ_FORMAT_UNDEFINED_NOTE = 0xBB60u, // Undefined Note |
| MTP_OBJ_FORMAT_ABSTRACT_NOTE = 0xBB61u, // Abstract Note |
| |
| // ---- Contacts ---- |
| MTP_OBJ_FORMAT_UNDEFINED_CONTACT= 0xBB80u, // Undefined Contact |
| MTP_OBJ_FORMAT_ABSTRACT_CONTACT = 0xBB81u, // Abstract Contact |
| MTP_OBJ_FORMAT_VCARD2 = 0xBB82u, // vCard 2.1 |
| MTP_OBJ_FORMAT_VCARD3 = 0xBB83u, // vCard 3.0 |
| } mtp_object_formats_t; |
| |
| // MTP 1.1 Appendix B: Object Properties |
| typedef enum { |
| MTP_OBJ_PROP_STORAGE_ID = 0xDC01u, // StorageID |
| MTP_OBJ_PROP_OBJECT_FORMAT = 0xDC02u, // Object Format |
| MTP_OBJ_PROP_PROTECTION_STATUS = 0xDC03u, // Protection Status |
| MTP_OBJ_PROP_OBJECT_SIZE = 0xDC04u, // Object Size |
| MTP_OBJ_PROP_ASSOCIATION_TYPE = 0xDC05u, // Association Type |
| MTP_OBJ_PROP_ASSOCIATION_DESC = 0xDC06u, // Association Description |
| MTP_OBJ_PROP_OBJECT_FILE_NAME = 0xDC07u, // Object File Name |
| MTP_OBJ_PROP_DATE_CREATED = 0xDC08u, // Date Created |
| MTP_OBJ_PROP_DATE_MODIFIED = 0xDC09u, // Date Modified |
| MTP_OBJ_PROP_KEYWORDS = 0xDC0Au, // Keywords |
| MTP_OBJ_PROP_PARENT_OBJECT = 0xDC0Bu, // Parent Object |
| MTP_OBJ_PROP_ALLOWED_FOLDER_CONTENTS = 0xDC0Cu, // Allowed Folder Contents |
| MTP_OBJ_PROP_HIDDEN = 0xDC0Du, // Hidden |
| MTP_OBJ_PROP_SYSTEM_OBJECT = 0xDC0Eu, // System Object |
| // 0xDC0F-0xDC40 is reserved |
| |
| MTP_OBJ_PROP_PERSISTENT_UID = 0xDC41u, // Persistent Unique Object Identifier |
| MTP_OBJ_PROP_SYNC_ID = 0xDC42u, // SyncID |
| MTP_OBJ_PROP_PROPERTY_BAG = 0xDC43u, // Property Bag |
| MTP_OBJ_PROP_NAME = 0xDC44u, // Name |
| MTP_OBJ_PROP_CREATED_BY = 0xDC45u, // Created By |
| MTP_OBJ_PROP_ARTIST = 0xDC46u, // Artist |
| MTP_OBJ_PROP_DATE_AUTHORED = 0xDC47u, // Date Authored |
| MTP_OBJ_PROP_DESCRIPTION = 0xDC48u, // Description |
| MTP_OBJ_PROP_URL_REFERENCE = 0xDC49u, // URL Reference |
| MTP_OBJ_PROP_LANGUAGE_LOCALE = 0xDC4Au, // Language-Locale |
| MTP_OBJ_PROP_COPYRIGHT_INFO = 0xDC4Bu, // Copyright Information |
| MTP_OBJ_PROP_SOURCE = 0xDC4Cu, // Source |
| MTP_OBJ_PROP_ORIGIN_LOCATION = 0xDC4Du, // Origin Location |
| MTP_OBJ_PROP_DATE_ADDED = 0xDC4Eu, // Date Added |
| MTP_OBJ_PROP_NON_CONSUMABLE = 0xDC4Fu, // Non-Consumable |
| MTP_OBJ_PROP_CORRUPT_UNPLAYABLE = 0xDC50u, // Corrupt/Unplayable |
| MTP_OBJ_PROP_PRODUCER_SERIAL_NUMBER = 0xDC51u, // ProducerSerialNumber |
| // 0xDC52-0xDC80 is reserved |
| |
| MTP_OBJ_PROP_REP_SAMPLE_FORMAT = 0xDC81u, // Representative Sample Format |
| MTP_OBJ_PROP_REP_SAMPLE_SIZE = 0xDC82u, // Representative Sample Size |
| MTP_OBJ_PROP_REP_SAMPLE_HEIGHT = 0xDC83u, // Representative Sample Height |
| MTP_OBJ_PROP_REP_SAMPLE_WIDTH = 0xDC84u, // Representative Sample Width |
| MTP_OBJ_PROP_REP_SAMPLE_DURATION = 0xDC85u, // Representative Sample Duration |
| MTP_OBJ_PROP_REP_SAMPLE_DATA = 0xDC86u, // Representative Sample Data |
| MTP_OBJ_PROP_WIDTH = 0xDC87u, // Width |
| MTP_OBJ_PROP_HEIGHT = 0xDC88u, // Height |
| MTP_OBJ_PROP_DURATION = 0xDC89u, // Duration |
| MTP_OBJ_PROP_RATING = 0xDC8Au, // Rating |
| MTP_OBJ_PROP_TRACK = 0xDC8Bu, // Track |
| MTP_OBJ_PROP_GENRE = 0xDC8Cu, // Genre |
| MTP_OBJ_PROP_CREDITS = 0xDC8Du, // Credits |
| MTP_OBJ_PROP_LYRICS = 0xDC8Eu, // Lyrics |
| MTP_OBJ_PROP_SUBSCRIPTION_CONTENT_ID = 0xDC8Fu, // Subscription Content ID |
| MTP_OBJ_PROP_PRODUCED_BY = 0xDC90u, // Produced By |
| MTP_OBJ_PROP_USE_COUNT = 0xDC91u, // Use Count |
| MTP_OBJ_PROP_SKIP_COUNT = 0xDC92u, // Skip Count |
| MTP_OBJ_PROP_LAST_ACCESSED = 0xDC93u, // Last Accessed |
| MTP_OBJ_PROP_PARENTAL_RATING = 0xDC94u, // Parental Rating |
| MTP_OBJ_PROP_META_GENRE = 0xDC95u, // Meta Genre |
| MTP_OBJ_PROP_COMPOSER = 0xDC96u, // Composer |
| MTP_OBJ_PROP_EFFECTIVE_RATING = 0xDC97u, // Effective Rating |
| MTP_OBJ_PROP_SUBTITLE = 0xDC98u, // Subtitle |
| MTP_OBJ_PROP_ORIGINAL_RELEASE_DATE = 0xDC99u, // Original Release Date |
| MTP_OBJ_PROP_ALBUM_NAME = 0xDC9Au, // Album Name |
| MTP_OBJ_PROP_ALBUM_ARTIST = 0xDC9Bu, // Album Artist |
| MTP_OBJ_PROP_MOOD = 0xDC9Cu, // Mood |
| MTP_OBJ_PROP_DRM_STATUS = 0xDC9Du, // DRM Status |
| MTP_OBJ_PROP_SUB_DESCRIPTION = 0xDC9Eu, // Sub Description |
| // 0xDC9F-0xDCD0 is reserved |
| |
| MTP_OBJ_PROP_IS_CROPPED = 0xDCD1u, // Is Cropped |
| MTP_OBJ_PROP_IS_COLOUR_CORRECTED = 0xDCD2u, // Is Colour Corrected |
| MTP_OBJ_PROP_IMAGE_BIT_DEPTH = 0xDCD3u, // Image Bit Depth |
| MTP_OBJ_PROP_FNUMBER = 0xDCD4u, // Fnumber (aperture ×100) |
| MTP_OBJ_PROP_EXPOSURE_TIME = 0xDCD5u, // Exposure Time (sec ×10,000) |
| MTP_OBJ_PROP_EXPOSURE_INDEX = 0xDCD6u, // Exposure Index (ISO) |
| // 0xDCD7-0xDCDF is reserved |
| |
| MTP_OBJ_PROP_DISPLAY_NAME = 0xDCE0u, // Display Name |
| MTP_OBJ_PROP_BODY_TEXT = 0xDCE1u, // Body Text |
| MTP_OBJ_PROP_SUBJECT = 0xDCE2u, // Subject |
| MTP_OBJ_PROP_PRIORITY = 0xDCE3u, // Priority |
| // 0xDCE4-0xDCFF is reserved |
| |
| MTP_OBJ_PROP_GIVEN_NAME = 0xDD00u, // Given Name |
| MTP_OBJ_PROP_MIDDLE_NAMES = 0xDD01u, // Middle Names |
| MTP_OBJ_PROP_FAMILY_NAME = 0xDD02u, // Family Name |
| MTP_OBJ_PROP_PREFIX = 0xDD03u, // Prefix |
| MTP_OBJ_PROP_SUFFIX = 0xDD04u, // Suffix |
| MTP_OBJ_PROP_PHONETIC_GIVEN_NAME = 0xDD05u, // Phonetic Given Name |
| MTP_OBJ_PROP_PHONETIC_FAMILY_NAME = 0xDD06u, // Phonetic Family Name |
| MTP_OBJ_PROP_EMAIL_PRIMARY = 0xDD07u, // Email Primary |
| MTP_OBJ_PROP_EMAIL_PERSONAL_1 = 0xDD08u, // Email Personal 1 |
| MTP_OBJ_PROP_EMAIL_PERSONAL_2 = 0xDD09u, // Email Personal 2 |
| MTP_OBJ_PROP_EMAIL_BUSINESS_1 = 0xDD0Au, // Email Business 1 |
| MTP_OBJ_PROP_EMAIL_BUSINESS_2 = 0xDD0Bu, // Email Business 2 |
| MTP_OBJ_PROP_EMAIL_OTHERS = 0xDD0Cu, // Email Others |
| MTP_OBJ_PROP_PHONE_PRIMARY = 0xDD0Du, // Phone Number Primary |
| MTP_OBJ_PROP_PHONE_PERSONAL_1 = 0xDD0Eu, // Phone Number Personal |
| MTP_OBJ_PROP_PHONE_PERSONAL_2 = 0xDD0Fu, // Phone Number Personal 2 |
| MTP_OBJ_PROP_PHONE_BUSINESS_1 = 0xDD10u, // Phone Number Business |
| MTP_OBJ_PROP_PHONE_BUSINESS_2 = 0xDD11u, // Phone Number Business 2 |
| MTP_OBJ_PROP_PHONE_MOBILE_1 = 0xDD12u, // Phone Number Mobile |
| MTP_OBJ_PROP_PHONE_MOBILE_2 = 0xDD13u, // Phone Number Mobile 2 |
| MTP_OBJ_PROP_FAX_PRIMARY = 0xDD14u, // Fax Number Primary |
| MTP_OBJ_PROP_FAX_PERSONAL = 0xDD15u, // Fax Number Personal |
| MTP_OBJ_PROP_FAX_BUSINESS = 0xDD16u, // Fax Number Business |
| MTP_OBJ_PROP_PAGER_NUMBER = 0xDD17u, // Pager Number |
| MTP_OBJ_PROP_PHONE_OTHERS = 0xDD18u, // Phone Number Others |
| MTP_OBJ_PROP_WEB_PRIMARY = 0xDD19u, // Primary Web Address |
| MTP_OBJ_PROP_WEB_PERSONAL = 0xDD1Au, // Personal Web Address |
| MTP_OBJ_PROP_WEB_BUSINESS = 0xDD1Bu, // Business Web Address |
| MTP_OBJ_PROP_IM_ADDRESS_1 = 0xDD1Cu, // Instant Messenger Address |
| MTP_OBJ_PROP_IM_ADDRESS_2 = 0xDD1Du, // Instant Messenger Address 2 |
| MTP_OBJ_PROP_IM_ADDRESS_3 = 0xDD1Eu, // Instant Messenger Address 3 |
| MTP_OBJ_PROP_ADDR_PERSONAL_FULL = 0xDD1Fu, // Postal Address Personal Full |
| MTP_OBJ_PROP_ADDR_PERSONAL_LINE1 = 0xDD20u, // Postal Address Personal Line 1 |
| MTP_OBJ_PROP_ADDR_PERSONAL_LINE2 = 0xDD21u, // Postal Address Personal Line 2 |
| MTP_OBJ_PROP_ADDR_PERSONAL_CITY = 0xDD22u, // Postal Address Personal City |
| MTP_OBJ_PROP_ADDR_PERSONAL_REGION = 0xDD23u, // Postal Address Personal Region |
| MTP_OBJ_PROP_ADDR_PERSONAL_POSTAL_CODE = 0xDD24u, // Postal Address Personal Postal Code |
| MTP_OBJ_PROP_ADDR_PERSONAL_COUNTRY = 0xDD25u, // Postal Address Personal Country |
| MTP_OBJ_PROP_ADDR_BUSINESS_FULL = 0xDD26u, // Postal Address Business Full |
| MTP_OBJ_PROP_ADDR_BUSINESS_LINE1 = 0xDD27u, // Postal Address Business Line 1 |
| MTP_OBJ_PROP_ADDR_BUSINESS_LINE2 = 0xDD28u, // Postal Address Business Line 2 |
| MTP_OBJ_PROP_ADDR_BUSINESS_CITY = 0xDD29u, // Postal Address Business City |
| MTP_OBJ_PROP_ADDR_BUSINESS_REGION = 0xDD2Au, // Postal Address Business Region |
| MTP_OBJ_PROP_ADDR_BUSINESS_POSTAL_CODE = 0xDD2Bu, // Postal Address Business Postal Code |
| MTP_OBJ_PROP_ADDR_BUSINESS_COUNTRY = 0xDD2Cu, // Postal Address Business Country |
| MTP_OBJ_PROP_ADDR_OTHER_FULL = 0xDD2Du, // Postal Address Other Full |
| MTP_OBJ_PROP_ADDR_OTHER_LINE1 = 0xDD2Eu, // Postal Address Other Line 1 |
| MTP_OBJ_PROP_ADDR_OTHER_LINE2 = 0xDD2Fu, // Postal Address Other Line 2 |
| MTP_OBJ_PROP_ADDR_OTHER_CITY = 0xDD30u, // Postal Address Other City |
| MTP_OBJ_PROP_ADDR_OTHER_REGION = 0xDD31u, // Postal Address Other Region |
| MTP_OBJ_PROP_ADDR_OTHER_POSTAL_CODE = 0xDD32u, // Postal Address Other Postal Code |
| MTP_OBJ_PROP_ADDR_OTHER_COUNTRY = 0xDD33u, // Postal Address Other Country |
| MTP_OBJ_PROP_ORGANIZATION_NAME = 0xDD34u, // Organization Name |
| MTP_OBJ_PROP_PHONETIC_ORG_NAME = 0xDD35u, // Phonetic Organization Name |
| MTP_OBJ_PROP_ROLE = 0xDD36u, // Role |
| MTP_OBJ_PROP_BIRTHDATE = 0xDD37u, // Birthdate |
| // 0xDD38-0xDD3F is reserved |
| |
| MTP_OBJ_PROP_MESSAGE_TO = 0xDD40u, // Message To |
| MTP_OBJ_PROP_MESSAGE_CC = 0xDD41u, // Message CC |
| MTP_OBJ_PROP_MESSAGE_BCC = 0xDD42u, // Message BCC |
| MTP_OBJ_PROP_MESSAGE_READ = 0xDD43u, // Message Read |
| MTP_OBJ_PROP_MESSAGE_RECEIVED_TIME = 0xDD44u, // Message Received Time |
| MTP_OBJ_PROP_MESSAGE_SENDER = 0xDD45u, // Message Sender |
| // 0xDD46-0xDD4F is reserved |
| |
| MTP_OBJ_PROP_ACTIVITY_BEGIN_TIME = 0xDD50u, // Activity Begin Time |
| MTP_OBJ_PROP_ACTIVITY_END_TIME = 0xDD51u, // Activity End Time |
| MTP_OBJ_PROP_ACTIVITY_LOCATION = 0xDD52u, // Activity Location |
| // 0xDD53 is reserved |
| MTP_OBJ_PROP_ACTIVITY_REQUIRED_ATTENDEES= 0xDD54u, // Activity Required Attendees |
| MTP_OBJ_PROP_ACTIVITY_OPTIONAL_ATTENDEES= 0xDD55u, // Activity Optional Attendees |
| MTP_OBJ_PROP_ACTIVITY_RESOURCES = 0xDD56u, // Activity Resources |
| MTP_OBJ_PROP_ACTIVITY_ACCEPTED = 0xDD57u, // Activity Accepted |
| MTP_OBJ_PROP_ACTIVITY_TENTATIVE = 0xDD58u, // Activity Tentative |
| MTP_OBJ_PROP_ACTIVITY_DECLINED = 0xDD59u, // Activity Declined |
| MTP_OBJ_PROP_ACTIVITY_REMINDER_TIME = 0xDD5Au, // Activity Reminder Time |
| MTP_OBJ_PROP_ACTIVITY_OWNER = 0xDD5Bu, // Activity Owner |
| MTP_OBJ_PROP_ACTIVITY_STATUS = 0xDD5Cu, // Activity Status |
| MTP_OBJ_PROP_OWNER = 0xDD5Du, // Owner |
| MTP_OBJ_PROP_EDITOR = 0xDD5Eu, // Editor |
| MTP_OBJ_PROP_WEBMASTER = 0xDD5Fu, // Webmaster |
| |
| MTP_OBJ_PROP_URL_SOURCE = 0xDD60u, // URL Source |
| MTP_OBJ_PROP_URL_DESTINATION = 0xDD61u, // URL Destination |
| MTP_OBJ_PROP_TIME_BOOKMARK = 0xDD62u, // Time Bookmark |
| MTP_OBJ_PROP_OBJECT_BOOKMARK = 0xDD63u, // Object Bookmark |
| MTP_OBJ_PROP_BYTE_BOOKMARK = 0xDD64u, // Byte Bookmark |
| // 0xDD65-0xDD6F is reserved |
| |
| MTP_OBJ_PROP_LAST_BUILD_DATE = 0xDD70u, // Last Build Date |
| MTP_OBJ_PROP_TIME_TO_LIVE = 0xDD71u, // Time to Live (minutes) |
| MTP_OBJ_PROP_MEDIA_GUID = 0xDD72u, // Media GUID |
| // 0xDD73-0xDDFF is reserved |
| |
| // media encoding |
| MTP_OBJ_PROP_TOTAL_BITRATE = 0xDE91u, // Total BitRate |
| MTP_OBJ_PROP_BITRATE_TYPE = 0xDE92u, // Bitrate Type |
| MTP_OBJ_PROP_SAMPLE_RATE = 0xDE93u, // Sample Rate |
| MTP_OBJ_PROP_NUM_CHANNELS = 0xDE94u, // Number Of Channels |
| MTP_OBJ_PROP_AUDIO_BITDEPTH = 0xDE95u, // Audio BitDepth |
| // 0xDE96 is reserved |
| MTP_OBJ_PROP_SCAN_TYPE = 0xDE97u, // Scan Type |
| // 0xDE98 is reserved |
| MTP_OBJ_PROP_AUDIO_WAVE_CODEC = 0xDE99u, // Audio WAVE Codec |
| MTP_OBJ_PROP_AUDIO_BITRATE = 0xDE9Au, // Audio BitRate |
| MTP_OBJ_PROP_VIDEO_FOURCC_CODEC = 0xDE9Bu, // Video FourCC Codec |
| MTP_OBJ_PROP_VIDEO_BITRATE = 0xDE9Cu, // Video BitRate |
| MTP_OBJ_PROP_FRAMES_PER_KSEC = 0xDE9Du, // Frames Per Thousand Seconds |
| MTP_OBJ_PROP_KEYFRAME_DISTANCE = 0xDE9Eu, // KeyFrame Distance (ms) |
| MTP_OBJ_PROP_BUFFER_SIZE = 0xDE9Fu, // Buffer Size |
| MTP_OBJ_PROP_ENCODING_QUALITY = 0xDEA0u, // Encoding Quality |
| MTP_OBJ_PROP_ENCODING_PROFILE = 0xDEA1u // Encoding Profile |
| } mtp_object_properties_t; |
| |
| |
| // MTP 1.1 Appendeix C: Device Properties |
| typedef enum { |
| MTP_DEV_PROP_UNDEFINED = 0x5000u, |
| MTP_DEV_PROP_BATTERY_LEVEL = 0x5001u, |
| MTP_DEV_PROP_FUNCTIONAL_MODE = 0x5002u, |
| MTP_DEV_PROP_IMAGE_SIZE = 0x5003u, |
| MTP_DEV_PROP_COMPRESSION_SETTING = 0x5004u, |
| MTP_DEV_PROP_WHITE_BALANCE = 0x5005u, |
| MTP_DEV_PROP_RGB_GAIN = 0x5006u, |
| MTP_DEV_PROP_F_NUMBER = 0x5007u, |
| MTP_DEV_PROP_FOCAL_LENGTH = 0x5008u, |
| MTP_DEV_PROP_FOCUS_DISTANCE = 0x5009u, |
| MTP_DEV_PROP_FOCUS_MODE = 0x500Au, |
| MTP_DEV_PROP_EXPOSURE_METERING_MODE = 0x500Bu, |
| MTP_DEV_PROP_FLASH_MODE = 0x500Cu, |
| MTP_DEV_PROP_EXPOSURE_TIME = 0x500Du, |
| MTP_DEV_PROP_EXPOSURE_PROGRAM_MODE = 0x500Eu, |
| MTP_DEV_PROP_EXPOSURE_INDEX = 0x500Fu, |
| MTP_DEV_PROP_EXPOSURE_BIAS_COMPENSATION = 0x5010u, |
| MTP_DEV_PROP_DATE_TIME = 0x5011u, |
| MTP_DEV_PROP_CAPTURE_DELAY = 0x5012u, |
| MTP_DEV_PROP_STILL_CAPTURE_MODE = 0x5013u, |
| MTP_DEV_PROP_CONTRAST = 0x5014u, |
| MTP_DEV_PROP_SHARPNESS = 0x5015u, |
| MTP_DEV_PROP_DIGITAL_ZOOM = 0x5016u, |
| MTP_DEV_PROP_EFFECT_MODE = 0x5017u, |
| MTP_DEV_PROP_BURST_NUMBER = 0x5018u, |
| MTP_DEV_PROP_BURST_INTERVAL = 0x5019u, |
| MTP_DEV_PROP_TIMELAPSE_NUMBER = 0x501Au, |
| MTP_DEV_PROP_TIMELAPSE_INTERVAL = 0x501Bu, |
| MTP_DEV_PROP_FOCUS_METERING_MODE = 0x501Cu, |
| MTP_DEV_PROP_UPLOAD_URL = 0x501Du, |
| MTP_DEV_PROP_ARTIST = 0x501Eu, |
| MTP_DEV_PROP_COPYRIGHT_INFO = 0x501Fu, |
| MTP_DEV_PROP_SYNCHRONIZTION_PARTNER = 0xD401, |
| MTP_DEV_PROP_DEVICE_FRIENDLY_NAME = 0xD402u, |
| MTP_DEV_PROP_VOLUME = 0xD403u, |
| MTP_DEV_PROP_SUPPORTED_FORMATS_ORDERED = 0xD404u, |
| MTP_DEV_PROP_DEVICE_ICON = 0xD405u, |
| MTP_DEV_PROP_SECTION_INITIATOR_VERSION_INFO = 0xD406u, |
| MTP_DEV_PROP_PERCEIVED_DEVICE_TYPE = 0xD407u, |
| MTP_DEV_PROP_PLAYBACK_RATE = 0xD410u, |
| MTP_DEV_PROP_PLAYBACK_OBJECT = 0xD411u, |
| MTP_DEV_PROP_PLAYBACK_CONTAINER_INDEX = 0xD412u, |
| } mtp_event_properties_t; |
| |
| // MTP 1.1 Appendix D: Operations |
| typedef enum { |
| MTP_OP_UNDEFINED = 0x1000u, |
| MTP_OP_GET_DEVICE_INFO = 0x1001u, |
| MTP_OP_OPEN_SESSION = 0x1002u, |
| MTP_OP_CLOSE_SESSION = 0x1003u, |
| MTP_OP_GET_STORAGE_IDS = 0x1004u, |
| MTP_OP_GET_STORAGE_INFO = 0x1005u, |
| MTP_OP_GET_NUM_OBJECTS = 0x1006u, |
| MTP_OP_GET_OBJECT_HANDLES = 0x1007u, |
| MTP_OP_GET_OBJECT_INFO = 0x1008u, |
| MTP_OP_GET_OBJECT = 0x1009u, |
| MTP_OP_GET_THUMB = 0x100Au, |
| MTP_OP_DELETE_OBJECT = 0x100Bu, |
| MTP_OP_SEND_OBJECT_INFO = 0x100Cu, |
| MTP_OP_SEND_OBJECT = 0x100Du, |
| MTP_OP_INITIAL_CAPTURE = 0x100Eu, |
| MTP_OP_FORMAT_STORE = 0x100Fu, |
| MTP_OP_RESET_DEVICE = 0x1010u, |
| MTP_OP_SELF_TEST = 0x1011u, |
| MTP_OP_SET_OBJECT_PROTECTION = 0x1012u, |
| MTP_OP_POWER_DOWN = 0x1013u, |
| MTP_OP_GET_DEVICE_PROP_DESC = 0x1014u, |
| MTP_OP_GET_DEVICE_PROP_VALUE = 0x1015u, |
| MTP_OP_SET_DEVICE_PROP_VALUE = 0x1016u, |
| MTP_OP_RESET_DEVICE_PROP_VALUE = 0x1017u, |
| MTP_OP_TERMINATE_OPEN_CAPTURE = 0x1018u, |
| MTP_OP_MOVE_OBJECT = 0x1019u, |
| MTP_OP_COPY_OBJECT = 0x101Au, |
| MTP_OP_GET_PARTIAL_OBJECT = 0x101Bu, |
| MTP_OP_INITIATE_OPEN_CAPTURE = 0x101Bu, |
| MTP_OP_GET_OBJECT_PROPS_SUPPORTED = 0x9801u, |
| MTP_OP_GET_OBJECT_PROP_DESC = 0x9802u, |
| MTP_OP_GET_OBJECT_PROP_VALUE = 0x9803u, |
| MTP_OP_SET_OBJECT_PROP_VALUE = 0x9804u, |
| MTP_OP_GET_OBJECT_PROPLIST = 0x9805u, |
| MTP_OP_GET_OBJECT_PROP_REFERENCES = 0x9810u, |
| |
| MTP_OP_GET_SERVICE_IDS = 0x9301u, |
| MTP_OP_GET_SERVICE_INFO = 0x9302u, |
| MTP_OP_GET_SERVICE_CAPABILITIES = 0x9303u, |
| MTP_OP_GET_SERVICE_PROP_DESC = 0x9304u, |
| |
| // Appendix E: Enhanced Operations |
| MTP_OP_GET_OBJECT_PROP_LIST = 0x9805u, |
| MTP_OP_SET_OBJECT_PROP_LIST = 0x9806u, |
| MTP_OP_GET_INTERDEPENDENT_PROP_DESC = 0x9807u, |
| MTP_OP_SEND_OBJECT_PROP_LIST = 0x9808u, |
| } mtp_operation_code_t; |
| |
| // Appendix F: Responses |
| typedef enum { |
| MTP_RESP_UNDEFINED = 0x2000u, |
| MTP_RESP_OK = 0x2001u, |
| MTP_RESP_GENERAL_ERROR = 0x2002u, |
| MTP_RESP_SESSION_NOT_OPEN = 0x2003u, |
| MTP_RESP_INVALID_TRANSACTION_ID = 0x2004u, |
| MTP_RESP_OPERATION_NOT_SUPPORTED = 0x2005u, |
| MTP_RESP_PARAMETER_NOT_SUPPORTED = 0x2006u, |
| MTP_RESP_INCOMPLETE_TRANSFER = 0x2007u, |
| MTP_RESP_INVALID_STORAGE_ID = 0x2008u, |
| MTP_RESP_INVALID_OBJECT_HANDLE = 0x2009u, |
| MTP_RESP_DEVICE_PROP_NOT_SUPPORTED = 0x200Au, |
| MTP_RESP_INVALID_OBJECT_FORMAT_CODE = 0x200Bu, |
| MTP_RESP_STORE_FULL = 0x200Cu, |
| MTP_RESP_OBJECT_WRITE_PROTECTED = 0x200Du, |
| MPT_RESC_STORE_READ_ONLY = 0x200Eu, |
| MTP_RESP_ACCESS_DENIED = 0x200Fu, |
| MTP_RESP_NO_THUMBNAIL_PRESENT = 0x2010u, |
| MTP_RESP_SELF_TEST_FAILED = 0x2011u, |
| MTP_RESP_PARTIAL_DELETION = 0x2012u, |
| MTP_RESP_STORE_NOT_AVAILABLE = 0x2013u, |
| MTP_RESP_SPECIFICATION_BY_FORMAT_UNSUPPORTED = 0x2014u, |
| MTP_RESP_NO_VALID_OBJECTINFO = 0x2015u, |
| MTP_RESP_INVALID_CODE_FORMAT = 0x2016u, |
| MTP_RESP_UNKNOWN_VENDOR_CODE = 0x2017u, |
| MTP_RESP_CAPTURE_ALREADY_TERMINATED = 0x2018u, |
| MTP_RESP_DEVICE_BUSY = 0x2019u, |
| MTP_RESP_INVALID_PARENT_OBJECT = 0x201Au, |
| MTP_RESP_INVALID_DEVICE_PROP_FORMAT = 0x201Bu, |
| MTP_RESP_INVALID_DEVICE_PROP_VALUE = 0x201Cu, |
| MTP_RESP_INVALID_PARAMETER = 0x201Du, |
| MTP_RESP_SESSION_ALREADY_OPEN = 0x201Eu, |
| MTP_RESP_TRANSACTION_CANCELLED = 0x201Fu, |
| MTP_RESP_SPEC_OF_DESTINATION_UNSUPPORTED = 0x2020u, |
| |
| MTP_RESP_INVALID_OBJECT_PROP_CODE = 0xA801u, |
| MTP_RESP_INVALID_OBJECT_PROP_FORMAT = 0xA802u, |
| MTP_RESP_INVALID_OBJECT_PROP_VALUE = 0xA803u, |
| MTP_RESP_INVALID_OBJECT_REFERENCE = 0xA804u, |
| MTP_RESP_GROUP_NOT_SUPPORTED = 0xA805u, |
| MTP_RESP_INVALID_DATASET = 0xA806u, |
| MTP_RESP_SPEC_BY_GROUP_UNSUPPORTED = 0xA807u, |
| MTP_RESP_SPEC_BY_DEPTH_UNSUPPORTED = 0xA808u, |
| MTP_RESP_OBJECT_TOO_LARGE = 0xA809u, |
| MTP_RESP_OBJECT_PROP_NOT_SUPPORTED = 0xA80Au, |
| } mtp_response_t; |
| |
| // Appendix G: Events |
| typedef enum { |
| MTP_EVENT_UNDEFINED = 0x4000, |
| MTP_EVENT_CANCEL_TRANSACTION = 0x4001, |
| MTP_EVENT_OBJECT_ADDED = 0x4002, |
| MTP_EVENT_OBJECT_REMOVED = 0x4003, |
| MTP_EVENT_STORE_ADDED = 0x4004, |
| MTP_EVENT_STORE_REMOVED = 0x4005, |
| MTP_EVENT_DEVICE_PROP_CHANGED = 0x4006, |
| MTP_EVENT_OBJECT_INFO_CHANGED = 0x4007, |
| MTP_EVENT_DEVICE_INFO_CHANGED = 0x4008, |
| MTP_EVENT_REQUEST_OBJECT_TRANSFER = 0x4009, |
| MTP_EVENT_STORE_FULL = 0x400Au, |
| MTP_EVENT_DEVICE_RESET = 0x400Bu, |
| MTP_EVENT_STORAGE_INFO_CHANGED = 0x400Cu, |
| MTP_EVENT_CAPTURE_COMPLETE = 0x400Du, |
| MTP_EVENT_UNREPORTED_STATUS = 0x400Eu, |
| MTP_EVENT_OBJECT_PROP_CHANGED = 0xC801u, |
| MTP_EVENT_OBJECT_PROP_DESC_CHANGED = 0xC802u, |
| MTP_EVENT_OBJECT_REFERENCES_CHANGED = 0xC803u, |
| } mtp_event_code_t; |
| |
| // Predefined Object handles |
| typedef enum |
| { |
| MTP_OBJH_ROOT = 0x0000, |
| } mtp_object_handles_t; |
| |
| // Datatypes |
| typedef enum |
| { |
| MTP_TYPE_UNDEFINED = 0x0000u, |
| MTP_TYPE_INT8 = 0x0001u, |
| MTP_TYPE_UINT8 = 0x0002u, |
| MTP_TYPE_INT16 = 0x0003u, |
| MTP_TYPE_UINT16 = 0x0004u, |
| MTP_TYPE_INT32 = 0x0005u, |
| MTP_TYPE_UINT32 = 0x0006u, |
| MTP_TYPE_INT64 = 0x0007u, |
| MTP_TYPE_UINT64 = 0x0008u, |
| MTP_TYPE_STR = 0xFFFFu, |
| } mtp_datatypes_t; |
| |
| // Get/Set |
| typedef enum |
| { |
| MTP_MODE_GET = 0x00u, |
| MTP_MODE_GET_SET = 0x01u, |
| } mtp_mode_get_set_t; |
| |
| typedef enum { |
| MTP_STORAGE_TYPE_UNDEFINED = 0x0000u, |
| MTP_STORAGE_TYPE_FIXED_ROM = 0x0001u, |
| MTP_STORAGE_TYPE_REMOVABLE_ROM = 0x0002u, |
| MTP_STORAGE_TYPE_FIXED_RAM = 0x0003u, |
| MTP_STORAGE_TYPE_REMOVABLE_RAM = 0x0004u, |
| } mtp_storage_type_t; |
| |
| typedef enum { |
| MTP_FILESYSTEM_TYPE_UNDEFINED = 0x0000u, |
| MTP_FILESYSTEM_TYPE_GENERIC_FLAT = 0x0001u, |
| MTP_FILESYSTEM_TYPE_GENERIC_HIERARCHICAL = 0x0002u, |
| MTP_FILESYSTEM_TYPE_DCF = 0x0003u, |
| } mtp_filesystem_type_t; |
| |
| typedef enum { |
| MTP_ACCESS_CAPABILITY_READ_WRITE = 0x0000u, |
| MTP_ACCESS_CAPABILITY_READ_ONLY_WITHOUT_OBJECT_DELETION = 0x0001u, |
| MTP_ACCESS_CAPABILITY_READ_ONLY_WITH_OBJECT_DELETION = 0x0002u, |
| } mtp_access_capability_t; |
| |
| typedef enum { |
| MTP_PROTECTION_STATUS_NO_PROTECTION = 0x0000u, |
| MTP_PROTECTION_STATUS_READ_ONLY = 0x0001u, |
| MTP_PROTECTION_STATUS_READ_ONLY_DATA = 0x8002u, |
| MTP_PROTECTION_NON_TRANSFERABLE_DATA = 0x8003u, |
| } mtp_protection_status_t; |
| |
| typedef enum { |
| MTP_ASSOCIATION_UNDEFINED = 0x0000u, |
| MTP_ASSOCIATION_GENERIC_FOLDER = 0x0001u, |
| MTP_ASSOCIATION_GENERIC_ALBUM = 0x0002u, |
| MTP_ASSOCIATION_TIME_SEQUENCE = 0x0003u, |
| MTP_ASSOCIATION_HORIZONTAL_PANORAMIC = 0x0004u, |
| MTP_ASSOCIATION_VERTICAL_PANORAMIC = 0x0005u, |
| MTP_ASSOCIATION_2D_PANORAMIC = 0x0006u, |
| } mtp_association_t; |
| |
| |
| tu_static const uint16_t mtp_operations_supported[] = { |
| MTP_OP_GET_DEVICE_INFO, |
| MTP_OP_OPEN_SESSION, |
| MTP_OP_CLOSE_SESSION, |
| MTP_OP_GET_STORAGE_IDS, |
| MTP_OP_GET_STORAGE_INFO, |
| MTP_OP_GET_NUM_OBJECTS, |
| MTP_OP_GET_OBJECT_HANDLES, |
| MTP_OP_GET_OBJECT_INFO, |
| MTP_OP_GET_OBJECT, |
| MTP_OP_DELETE_OBJECT, |
| MTP_OP_SEND_OBJECT_INFO, |
| MTP_OP_SEND_OBJECT, |
| MTP_OP_FORMAT_STORE, |
| MTP_OP_RESET_DEVICE, |
| MTP_OP_GET_DEVICE_PROP_DESC, |
| MTP_OP_GET_DEVICE_PROP_VALUE, |
| MTP_OP_SET_DEVICE_PROP_VALUE, |
| }; |
| |
| tu_static const uint16_t mtp_events_supported[] = { |
| MTP_EVENT_OBJECT_ADDED, |
| }; |
| |
| tu_static const uint16_t mtp_device_properties_supported[] = { |
| MTP_DEV_PROP_DEVICE_FRIENDLY_NAME, |
| }; |
| |
| tu_static const uint16_t mtp_capture_formats[] = { |
| MTP_OBJ_FORMAT_UNDEFINED, |
| MTP_OBJ_FORMAT_ASSOCIATION, |
| MTP_OBJ_FORMAT_TEXT, |
| }; |
| |
| tu_static const uint16_t mtp_playback_formats[] = { |
| MTP_OBJ_FORMAT_UNDEFINED, |
| MTP_OBJ_FORMAT_ASSOCIATION, |
| MTP_OBJ_FORMAT_TEXT, |
| }; |
| |
| //--------------------------------------------------------------------+ |
| // Data structures |
| //--------------------------------------------------------------------+ |
| |
| #define MTP_CONTAINER_HEADER_LENGTH 12 |
| #define MTP_MAX_PACKET_SIZE 512 |
| |
| typedef struct TU_ATTR_PACKED { |
| uint32_t len; |
| uint16_t type; |
| uint16_t code; |
| uint32_t transaction_id; |
| } mtp_container_header_t; |
| TU_VERIFY_STATIC(sizeof(mtp_container_header_t) == 12, "size is not correct"); |
| |
| // PTP/MTP Generic container |
| typedef struct TU_ATTR_PACKED { |
| uint32_t len; |
| uint16_t type; |
| uint16_t code; |
| uint32_t transaction_id; |
| uint32_t data[MTP_MAX_PACKET_SIZE / sizeof(uint32_t)]; |
| } mtp_generic_container_t; |
| |
| // DeviceInfo Dataset |
| #define MTP_EXTENSIONS "microsoft.com: 1.0; " |
| typedef struct TU_ATTR_PACKED { |
| uint16_t standard_version; |
| uint32_t mtp_vendor_extension_id; |
| uint16_t mtp_version; |
| uint8_t mtp_extensions_len; |
| wchar16_t mtp_extensions[TU_ARRAY_LEN(MTP_EXTENSIONS)] TU_ATTR_PACKED; |
| |
| uint16_t functional_mode; |
| /* Operations supported */ |
| uint32_t operations_supported_len; |
| uint16_t operations_supported[TU_ARRAY_LEN(mtp_operations_supported)] TU_ATTR_PACKED; |
| /* Events supported */ |
| uint32_t events_supported_len; |
| uint16_t events_supported[TU_ARRAY_LEN(mtp_events_supported)] TU_ATTR_PACKED; |
| /* Device properties supported */ |
| uint32_t device_properties_supported_len; |
| uint16_t device_properties_supported[TU_ARRAY_LEN(mtp_device_properties_supported)] TU_ATTR_PACKED; |
| /* Capture formats */ |
| uint32_t capture_formats_len; |
| uint16_t capture_formats[TU_ARRAY_LEN(mtp_capture_formats)] TU_ATTR_PACKED; |
| /* Playback formats */ |
| uint32_t playback_formats_len; |
| uint16_t playback_formats[TU_ARRAY_LEN(mtp_playback_formats)] TU_ATTR_PACKED; |
| } mtp_device_info_t; |
| // The following fields will be dynamically added to the struct at runtime: |
| // - wstring manufacturer |
| // - wstring model |
| // - wstring device_version |
| // - wstring serial_number |
| |
| |
| #define MTP_STRING_DEF(name, string) \ |
| uint8_t name##_len; \ |
| wchar16_t name[TU_ARRAY_LEN(string)]; |
| |
| #define MTP_ARRAY_DEF(name, array) \ |
| uint16_t name##_len; \ |
| typeof(name) name[TU_ARRAY_LEN(array)]; |
| |
| // StorageInfo dataset |
| typedef struct TU_ATTR_PACKED { |
| uint16_t storage_type; |
| uint16_t filesystem_type; |
| uint16_t access_capability; |
| uint64_t max_capacity_in_bytes; |
| uint64_t free_space_in_bytes; |
| uint32_t free_space_in_objects; |
| } mtp_storage_info_t; |
| // The following fields will be dynamically added to the struct at runtime: |
| // - wstring storage_description |
| // - wstring volume_identifier |
| |
| // ObjectInfo Dataset |
| typedef struct TU_ATTR_PACKED { |
| uint32_t storage_id; |
| uint16_t object_format; |
| uint16_t protection_status; |
| uint32_t object_compressed_size; |
| uint16_t thumb_format; // unused |
| uint32_t thumb_compressed_size; // unused |
| uint32_t thumb_pix_width; // unused |
| uint32_t thumb_pix_height; // unused |
| uint32_t image_pix_width; // unused |
| uint32_t image_pix_height; // unused |
| uint32_t image_bit_depth; // unused |
| uint32_t parent_object; // 0: root |
| uint16_t association_type; |
| uint32_t association_description; // not used |
| uint32_t sequence_number; // not used |
| } mtp_object_info_t; |
| // The following fields will be dynamically added to the struct at runtime: |
| // - wstring filename; |
| // - datetime_wstring date_created; |
| // - datetime_wstring date_modified; |
| // - wstring keywords; |
| |
| // Storage IDs |
| typedef struct TU_ATTR_PACKED { |
| uint32_t storage_ids_len; |
| uint32_t storage_ids[CFG_MTP_STORAGE_ID_COUNT]; |
| } mtp_storage_ids_t; |
| |
| // DevicePropDesc Dataset |
| typedef struct TU_ATTR_PACKED { |
| uint16_t device_property_code; |
| uint16_t datatype; |
| uint8_t get_set; |
| } mtp_device_prop_desc_t; |
| // The following fields will be dynamically added to the struct at runtime: |
| // - wstring factory_def_value; |
| // - wstring current_value_len; |
| // - uint8_t form_flag; |
| |
| typedef struct TU_ATTR_PACKED { |
| uint16_t wLength; |
| uint16_t code; |
| } mtp_device_status_res_t; |
| |
| typedef struct TU_ATTR_PACKED { |
| uint32_t object_handle; |
| uint32_t storage_id; |
| uint32_t parent_object_handle; |
| } mtp_basic_object_info_t; |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| #endif /* CFG_TUD_ENABLED && CFG_TUD_MTP */ |
| |
| #endif /* _TUSB_MTP_H_ */ |