1 /**************************************************************************/ 2 /* */ 3 /* Copyright (c) Microsoft Corporation. All rights reserved. */ 4 /* */ 5 /* This software is licensed under the Microsoft Software License */ 6 /* Terms for Microsoft Azure RTOS. Full text of the license can be */ 7 /* found in the LICENSE file at https://aka.ms/AzureRTOS_EULA */ 8 /* and in the root directory of this software. */ 9 /* */ 10 /**************************************************************************/ 11 12 13 /**************************************************************************/ 14 /**************************************************************************/ 15 /** */ 16 /** USBX Component */ 17 /** */ 18 /** Pictbridge Application */ 19 /** */ 20 /**************************************************************************/ 21 /**************************************************************************/ 22 23 24 /* Include necessary system files. */ 25 26 #define UX_SOURCE_CODE 27 28 #include "ux_api.h" 29 #include "ux_pictbridge.h" 30 31 32 /**************************************************************************/ 33 /* */ 34 /* FUNCTION RELEASE */ 35 /* */ 36 /* _ux_pictbridge_xml_function_input_notifydevicestatus_errorstatus */ 37 /* PORTABLE C */ 38 /* 6.1 */ 39 /* */ 40 /* */ 41 /* AUTHOR */ 42 /* */ 43 /* Chaoqiong Xiao, Microsoft Corporation */ 44 /* */ 45 /* DESCRIPTION */ 46 /* */ 47 /* This function decodes the errorstatus tag */ 48 /* object */ 49 /* */ 50 /* INPUT */ 51 /* */ 52 /* pictbridge Pictbridge instance */ 53 /* input_variable Pointer to variable */ 54 /* input_string Pointer to string */ 55 /* xml_parameter XML parameter */ 56 /* */ 57 /* OUTPUT */ 58 /* */ 59 /* Completion Status */ 60 /* */ 61 /* CALLS */ 62 /* */ 63 /* */ 64 /* CALLED BY */ 65 /* */ 66 /* _ux_pictbridge_object_parse */ 67 /* */ 68 /* RELEASE HISTORY */ 69 /* */ 70 /* DATE NAME DESCRIPTION */ 71 /* */ 72 /* 05-19-2020 Chaoqiong Xiao Initial Version 6.0 */ 73 /* 09-30-2020 Chaoqiong Xiao Modified comment(s), */ 74 /* resulting in version 6.1 */ 75 /* */ 76 /**************************************************************************/ _ux_pictbridge_xml_function_input_notifydevicestatus_errorstatus(UX_PICTBRIDGE * pictbridge,UCHAR * input_variable,UCHAR * input_string,UCHAR * xml_parameter)77UINT _ux_pictbridge_xml_function_input_notifydevicestatus_errorstatus(UX_PICTBRIDGE *pictbridge, 78 UCHAR *input_variable, UCHAR *input_string, UCHAR *xml_parameter) 79 { 80 81 UINT status; 82 ULONG hexa_element; 83 84 UX_PARAMETER_NOT_USED(input_string); 85 UX_PARAMETER_NOT_USED(input_variable); 86 UX_PARAMETER_NOT_USED(xml_parameter); 87 88 /* Get the error status variable. */ 89 status = _ux_pictbridge_element_to_hexa(xml_parameter, &hexa_element); 90 91 /* Check status. */ 92 if (status == UX_SUCCESS) 93 { 94 95 /* Check the returned value. Must be one of 3 possibilities. */ 96 if (hexa_element == UX_PICTBRIDGE_ERROR_STATUS_NO_ERROR || 97 hexa_element == UX_PICTBRIDGE_ERROR_STATUS_WARNING || 98 hexa_element == UX_PICTBRIDGE_ERROR_STATUS_FATAL) 99 { 100 101 /* Save this value. */ 102 pictbridge -> ux_pictbridge_dpsclient.ux_pictbridge_devinfo_errorstatus = hexa_element; 103 104 /* We are done. */ 105 return(UX_SUCCESS); 106 } 107 } 108 109 /* We get here when we reached an unexpected end of the XML object or a format error. */ 110 return(UX_PICTBRIDGE_ERROR_SCRIPT_SYNTAX_ERROR); 111 112 } 113 114 115