Home | History | Annotate | Line # | Download | only in utilities
utuuid.c revision 1.1.1.11
      1       1.1  christos /******************************************************************************
      2       1.1  christos  *
      3       1.1  christos  * Module Name: utuuid -- UUID support functions
      4       1.1  christos  *
      5       1.1  christos  *****************************************************************************/
      6       1.1  christos 
      7       1.1  christos /*
      8  1.1.1.11  christos  * Copyright (C) 2000 - 2023, Intel Corp.
      9       1.1  christos  * All rights reserved.
     10       1.1  christos  *
     11       1.1  christos  * Redistribution and use in source and binary forms, with or without
     12       1.1  christos  * modification, are permitted provided that the following conditions
     13       1.1  christos  * are met:
     14       1.1  christos  * 1. Redistributions of source code must retain the above copyright
     15       1.1  christos  *    notice, this list of conditions, and the following disclaimer,
     16       1.1  christos  *    without modification.
     17       1.1  christos  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
     18       1.1  christos  *    substantially similar to the "NO WARRANTY" disclaimer below
     19       1.1  christos  *    ("Disclaimer") and any redistribution must be conditioned upon
     20       1.1  christos  *    including a substantially similar Disclaimer requirement for further
     21       1.1  christos  *    binary redistribution.
     22       1.1  christos  * 3. Neither the names of the above-listed copyright holders nor the names
     23       1.1  christos  *    of any contributors may be used to endorse or promote products derived
     24       1.1  christos  *    from this software without specific prior written permission.
     25       1.1  christos  *
     26       1.1  christos  * Alternatively, this software may be distributed under the terms of the
     27       1.1  christos  * GNU General Public License ("GPL") version 2 as published by the Free
     28       1.1  christos  * Software Foundation.
     29       1.1  christos  *
     30       1.1  christos  * NO WARRANTY
     31       1.1  christos  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     32       1.1  christos  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     33   1.1.1.8  christos  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
     34       1.1  christos  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
     35       1.1  christos  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     36       1.1  christos  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     37       1.1  christos  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     38       1.1  christos  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     39       1.1  christos  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
     40       1.1  christos  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     41       1.1  christos  * POSSIBILITY OF SUCH DAMAGES.
     42       1.1  christos  */
     43       1.1  christos 
     44       1.1  christos #include "acpi.h"
     45       1.1  christos #include "accommon.h"
     46       1.1  christos 
     47       1.1  christos #define _COMPONENT          ACPI_COMPILER
     48       1.1  christos         ACPI_MODULE_NAME    ("utuuid")
     49       1.1  christos 
     50       1.1  christos 
     51   1.1.1.2  christos #if (defined ACPI_ASL_COMPILER || defined ACPI_EXEC_APP || defined ACPI_HELP_APP)
     52       1.1  christos /*
     53       1.1  christos  * UUID support functions.
     54       1.1  christos  *
     55       1.1  christos  * This table is used to convert an input UUID ascii string to a 16 byte
     56       1.1  christos  * buffer and the reverse. The table maps a UUID buffer index 0-15 to
     57       1.1  christos  * the index within the 36-byte UUID string where the associated 2-byte
     58       1.1  christos  * hex value can be found.
     59       1.1  christos  *
     60       1.1  christos  * 36-byte UUID strings are of the form:
     61       1.1  christos  *     aabbccdd-eeff-gghh-iijj-kkllmmnnoopp
     62       1.1  christos  * Where aa-pp are one byte hex numbers, made up of two hex digits
     63       1.1  christos  *
     64       1.1  christos  * Note: This table is basically the inverse of the string-to-offset table
     65       1.1  christos  * found in the ACPI spec in the description of the ToUUID macro.
     66       1.1  christos  */
     67       1.1  christos const UINT8    AcpiGbl_MapToUuidOffset[UUID_BUFFER_LENGTH] =
     68       1.1  christos {
     69       1.1  christos     6,4,2,0,11,9,16,14,19,21,24,26,28,30,32,34
     70       1.1  christos };
     71       1.1  christos 
     72       1.1  christos 
     73       1.1  christos /*******************************************************************************
     74       1.1  christos  *
     75       1.1  christos  * FUNCTION:    AcpiUtConvertStringToUuid
     76       1.1  christos  *
     77       1.1  christos  * PARAMETERS:  InString            - 36-byte formatted UUID string
     78       1.1  christos  *              UuidBuffer          - Where the 16-byte UUID buffer is returned
     79       1.1  christos  *
     80       1.1  christos  * RETURN:      None. Output data is returned in the UuidBuffer
     81       1.1  christos  *
     82       1.1  christos  * DESCRIPTION: Convert a 36-byte formatted UUID string to 16-byte UUID buffer
     83       1.1  christos  *
     84       1.1  christos  ******************************************************************************/
     85       1.1  christos 
     86       1.1  christos void
     87       1.1  christos AcpiUtConvertStringToUuid (
     88       1.1  christos     char                    *InString,
     89       1.1  christos     UINT8                   *UuidBuffer)
     90       1.1  christos {
     91       1.1  christos     UINT32                  i;
     92       1.1  christos 
     93       1.1  christos 
     94       1.1  christos     for (i = 0; i < UUID_BUFFER_LENGTH; i++)
     95       1.1  christos     {
     96   1.1.1.3  christos         UuidBuffer[i] = (AcpiUtAsciiCharToHex (
     97   1.1.1.3  christos             InString[AcpiGbl_MapToUuidOffset[i]]) << 4);
     98       1.1  christos 
     99   1.1.1.3  christos         UuidBuffer[i] |= AcpiUtAsciiCharToHex (
    100   1.1.1.3  christos             InString[AcpiGbl_MapToUuidOffset[i] + 1]);
    101       1.1  christos     }
    102       1.1  christos }
    103   1.1.1.9  christos 
    104   1.1.1.9  christos 
    105   1.1.1.9  christos /*******************************************************************************
    106   1.1.1.9  christos  *
    107   1.1.1.9  christos  * FUNCTION:    AcpiUtConvertUuidToString
    108   1.1.1.9  christos  *
    109   1.1.1.9  christos  * PARAMETERS:  UuidBuffer          - 16-byte UUID buffer
    110   1.1.1.9  christos  *              OutString           - 36-byte formatted UUID string
    111   1.1.1.9  christos  *
    112   1.1.1.9  christos  * RETURN:      Status
    113   1.1.1.9  christos  *
    114   1.1.1.9  christos  * DESCRIPTION: Convert 16-byte UUID buffer to 36-byte formatted UUID string
    115   1.1.1.9  christos  *              OutString must be 37 bytes to include null terminator.
    116   1.1.1.9  christos  *
    117   1.1.1.9  christos  ******************************************************************************/
    118   1.1.1.9  christos 
    119   1.1.1.9  christos ACPI_STATUS
    120   1.1.1.9  christos AcpiUtConvertUuidToString (
    121   1.1.1.9  christos     char                    *UuidBuffer,
    122   1.1.1.9  christos     char                    *OutString)
    123   1.1.1.9  christos {
    124   1.1.1.9  christos     UINT32                  i;
    125   1.1.1.9  christos 
    126   1.1.1.9  christos 
    127   1.1.1.9  christos     if (!UuidBuffer || !OutString)
    128   1.1.1.9  christos     {
    129   1.1.1.9  christos         return (AE_BAD_PARAMETER);
    130   1.1.1.9  christos     }
    131   1.1.1.9  christos 
    132   1.1.1.9  christos     for (i = 0; i < UUID_BUFFER_LENGTH; i++)
    133   1.1.1.9  christos     {
    134   1.1.1.9  christos         OutString[AcpiGbl_MapToUuidOffset[i]] =
    135   1.1.1.9  christos             AcpiUtHexToAsciiChar (UuidBuffer[i], 4);
    136   1.1.1.9  christos 
    137   1.1.1.9  christos         OutString[AcpiGbl_MapToUuidOffset[i] + 1] =
    138   1.1.1.9  christos             AcpiUtHexToAsciiChar (UuidBuffer[i], 0);
    139   1.1.1.9  christos     }
    140   1.1.1.9  christos 
    141   1.1.1.9  christos     /* Insert required hyphens (dashes) */
    142   1.1.1.9  christos 
    143   1.1.1.9  christos     OutString[UUID_HYPHEN1_OFFSET] =
    144   1.1.1.9  christos     OutString[UUID_HYPHEN2_OFFSET] =
    145   1.1.1.9  christos     OutString[UUID_HYPHEN3_OFFSET] =
    146   1.1.1.9  christos     OutString[UUID_HYPHEN4_OFFSET] = '-';
    147   1.1.1.9  christos 
    148   1.1.1.9  christos     OutString[UUID_STRING_LENGTH] = 0; /* Null terminate */
    149   1.1.1.9  christos     return (AE_OK);
    150   1.1.1.9  christos }
    151   1.1.1.2  christos #endif
    152