1 /* 2 * Copyright (c) 2023 Nordic Semiconductor ASA 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 /** 8 * @file 9 * @brief MS OS 2.0 descriptor definitions 10 * 11 */ 12 13 #ifndef ZEPHYR_INCLUDE_USB_MSOS_DESC_H 14 #define ZEPHYR_INCLUDE_USB_MSOS_DESC_H 15 16 #include <stdint.h> 17 18 enum msosv2_descriptor_index { 19 MS_OS_20_DESCRIPTOR_INDEX = 0x07, 20 MS_OS_20_SET_ALT_ENUMERATION = 0x08, 21 }; 22 23 enum msosv2_descriptor_type { 24 MS_OS_20_SET_HEADER_DESCRIPTOR = 0x00, 25 MS_OS_20_SUBSET_HEADER_CONFIGURATION = 0x01, 26 MS_OS_20_SUBSET_HEADER_FUNCTION = 0x02, 27 MS_OS_20_FEATURE_COMPATIBLE_ID = 0x03, 28 MS_OS_20_FEATURE_REG_PROPERTY = 0x04, 29 MS_OS_20_FEATURE_MIN_RESUME_TIME = 0x05, 30 MS_OS_20_FEATURE_MODEL_ID = 0x06, 31 MS_OS_20_FEATURE_CCGP_DEVICE = 0x07, 32 MS_OS_20_FEATURE_VENDOR_REVISION = 0x08 33 }; 34 35 enum msosv2_property_data_type { 36 MS_OS_20_PROPERTY_DATA_RESERVED = 0, 37 MS_OS_20_PROPERTY_DATA_REG_SZ = 1, 38 MS_OS_20_PROPERTY_DATA_REG_EXPAND_SZ = 2, 39 MS_OS_20_PROPERTY_DATA_REG_BINARY = 3, 40 MS_OS_20_PROPERTY_DATA_REG_DWORD_LITTLE_ENDIAN = 4, 41 MS_OS_20_PROPERTY_DATA_REG_DWORD_BIG_ENDIAN = 5, 42 MS_OS_20_PROPERTY_DATA_REG_LINK = 6, 43 MS_OS_20_PROPERTY_DATA_REG_MULTI_SZ = 7 44 }; 45 46 /* Microsoft OS 2.0 descriptor set header */ 47 struct msosv2_descriptor_set_header { 48 uint16_t wLength; 49 uint16_t wDescriptorType; 50 uint32_t dwWindowsVersion; 51 uint16_t wTotalLength; 52 } __packed; 53 54 /* Microsoft OS 2.0 configuration subset header 55 * This header is for composite devices with multiple configurations. 56 */ 57 struct msosv2_configuration_subset_header { 58 uint16_t wLength; 59 uint16_t wDescriptorType; 60 uint8_t bConfigurationValue; 61 uint8_t bReserved; 62 uint16_t wTotalLength; 63 } __packed; 64 65 /* Microsoft OS 2.0 function subset header 66 * Note: This must be used if your device has multiple interfaces and cannot be used otherwise. 67 */ 68 struct msosv2_function_subset_header { 69 uint16_t wLength; 70 uint16_t wDescriptorType; 71 uint8_t bFirstInterface; 72 uint8_t bReserved; 73 uint16_t wSubsetLength; 74 } __packed; 75 76 /* Microsoft OS 2.0 compatible ID descriptor */ 77 struct msosv2_compatible_id { 78 uint16_t wLength; 79 uint16_t wDescriptorType; 80 uint8_t CompatibleID[8]; 81 uint8_t SubCompatibleID[8]; 82 } __packed; 83 84 /* Microsoft OS 2.0 Registry property descriptor: DeviceInterfaceGUIDs */ 85 struct msosv2_guids_property { 86 uint16_t wLength; 87 uint16_t wDescriptorType; 88 uint16_t wPropertyDataType; 89 uint16_t wPropertyNameLength; 90 uint8_t PropertyName[42]; 91 uint16_t wPropertyDataLength; 92 uint8_t bPropertyData[80]; 93 } __packed; 94 95 /* DeviceInterfaceGUIDs */ 96 #define DEVICE_INTERFACE_GUIDS_PROPERTY_NAME \ 97 'D', 0x00, 'e', 0x00, 'v', 0x00, 'i', 0x00, 'c', 0x00, 'e', 0x00, \ 98 'I', 0x00, 'n', 0x00, 't', 0x00, 'e', 0x00, 'r', 0x00, 'f', 0x00, \ 99 'a', 0x00, 'c', 0x00, 'e', 0x00, 'G', 0x00, 'U', 0x00, 'I', 0x00, \ 100 'D', 0x00, 's', 0x00, 0x00, 0x00 101 102 /* Microsoft OS 2.0 minimum USB resume time descriptor */ 103 struct msosv2_resume_time { 104 uint16_t wLength; 105 uint16_t wDescriptorType; 106 uint8_t bResumeRecoveryTime; 107 uint8_t bResumeSignalingTime; 108 } __packed; 109 110 /* Microsoft OS 2.0 model ID descriptor */ 111 struct msosv2_model_id { 112 uint16_t wLength; 113 uint16_t wDescriptorType; 114 uint8_t ModelID[16]; 115 } __packed; 116 117 /* Microsoft OS 2.0 CCGP device descriptor */ 118 struct msosv2_ccgp_device { 119 uint16_t wLength; 120 uint16_t wDescriptorType; 121 } __packed; 122 123 /* Microsoft OS 2.0 vendor revision descriptor */ 124 struct msosv2_vendor_revision { 125 uint16_t wLength; 126 uint16_t wDescriptorType; 127 uint16_t VendorRevision; 128 } __packed; 129 130 131 #endif /* ZEPHYR_INCLUDE_USB_MSOS_DESC_H */ 132