/****************************************************************************** * * Copyright (C) 2002 - 2014 Xilinx, Inc. All rights reserved. * * 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. * * Use of the Software is limited solely to applications: * (a) running on a Xilinx device, or * (b) that interact with a Xilinx device through a bus or interconnect. * * 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 * XILINX CONSORTIUM 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. * * Except as contained in this notice, the name of the Xilinx shall not be used * in advertising or otherwise to promote the sale, use or other dealings in * this Software without prior written authorization from Xilinx. * ******************************************************************************/ /*****************************************************************************/ /** * * @file xversion.c * * This file contains the implementation of the XVersion component. This * component represents a version ID. It is encapsulated within a component * so that it's type and implementation can change without affecting users of * it. * * The version is formatted as X.YYZ where X = 0 - 9, Y = 00 - 99, Z = a - z * X is the major revision, YY is the minor revision, and Z is the * compatability revision. * * Packed versions are also utilized for the configuration ROM such that * memory is minimized. A packed version consumes only 16 bits and is * formatted as follows. * *
* Revision                  Range       Bit Positions
*
* Major Revision            0 - 9       Bits 15 - 12
* Minor Revision            0 - 99      Bits 11 - 5
* Compatability Revision    a - z       Bits 4 - 0
*
* MODIFICATION HISTORY:
*
* Ver   Who    Date   Changes
* ----- ---- -------- -------------------------------------------------------
* 1.00a xd   11/03/04 Improved support for doxygen.
* ******************************************************************************/ /***************************** Include Files *********************************/ #include "xbasic_types.h" #include "xversion.h" /************************** Constant Definitions *****************************/ /* the following constants define the masks and shift values to allow the * revisions to be packed and unpacked, a packed version is packed into a 16 * bit value in the following format, XXXXYYYYYYYZZZZZ, where XXXX is the * major revision, YYYYYYY is the minor revision, and ZZZZZ is the compatability * revision */ #define XVE_MAJOR_SHIFT_VALUE 12 #define XVE_MINOR_ONLY_MASK 0x0FE0 #define XVE_MINOR_SHIFT_VALUE 5 #define XVE_COMP_ONLY_MASK 0x001F /* the following constants define the specific characters of a version string * for each character of the revision, a version string is in the following * format, "X.YYZ" where X is the major revision (0 - 9), YY is the minor * revision (00 - 99), and Z is the compatability revision (a - z) */ #define XVE_MAJOR_CHAR 0 /* major revision 0 - 9 */ #define XVE_MINOR_TENS_CHAR 2 /* minor revision tens 0 - 9 */ #define XVE_MINOR_ONES_CHAR 3 /* minor revision ones 0 - 9 */ #define XVE_COMP_CHAR 4 /* compatability revision a - z */ #define XVE_END_STRING_CHAR 5 /**************************** Type Definitions *******************************/ /***************** Macros (Inline Functions) Definitions *********************/ /************************** Function Prototypes ******************************/ static int IsVersionStringValid(char *StringPtr); /*****************************************************************************/ /** * * Unpacks a packed version into the specified version. Versions are packed * into the configuration ROM to reduce the amount storage. A packed version * is a binary format as oppossed to a non-packed version which is implemented * as a string. * * @param InstancePtr points to the version to unpack the packed version into. * @param PackedVersion contains the packed version to unpack. * * @return None. * * @note None. * ******************************************************************************/ void XVersion_UnPack(XVersion *InstancePtr, u16 PackedVersion) { (void) InstancePtr; (void) PackedVersion; /* not implemented yet since CROM related */ } /*****************************************************************************/ /** * * Packs a version into the specified packed version. Versions are packed into * the configuration ROM to reduce the amount storage. * * @param InstancePtr points to the version to pack. * @param PackedVersionPtr points to the packed version which will receive * the new packed version. * * @return * * A status, XST_SUCCESS, indicating the packing was accomplished * successfully, or an error, XST_INVALID_VERSION, indicating the specified * input version was not valid such that the pack did not occur *

* The packed version pointed to by PackedVersionPtr is modified with the new * packed version if the status indicates success. * * @note * * None. * ******************************************************************************/ int XVersion_Pack(XVersion *InstancePtr, u16 *PackedVersionPtr) { /* not implemented yet since CROM related */ (void) InstancePtr; (void) PackedVersionPtr; return XST_SUCCESS; } /*****************************************************************************/ /** * * Determines if two versions are equal. * * @param InstancePtr points to the first version to be compared. * @param VersionPtr points to a second version to be compared. * * @return * * TRUE if the versions are equal, FALSE otherwise. * * @note * * None. * ******************************************************************************/ int XVersion_IsEqual(XVersion *InstancePtr, XVersion *VersionPtr) { u8 *Version1 = (u8 *) InstancePtr; u8 *Version2 = (u8 *) VersionPtr; u32 Index; /* assert to verify input arguments */ XASSERT_NONVOID(InstancePtr != NULL); XASSERT_NONVOID(VersionPtr != NULL); /* check each byte of the versions to see if they are the same, * return at any point a byte differs between them */ for (Index = 0; Index < sizeof(XVersion); Index++) { if (Version1[Index] != Version2[Index]) { return FALSE; } } /* No byte was found to be different between the versions, so indicate * the versions are equal */ return TRUE; } /*****************************************************************************/ /** * * Converts a version to a null terminated string. * * @param InstancePtr points to the version to convert. * @param StringPtr points to the string which will be the result of the * conversion. This does not need to point to a null terminated * string as an input, but must point to storage which is an adequate * amount to hold the result string. * * @return * * The null terminated string is inserted at the location pointed to by * StringPtr if the status indicates success. * * @note * * It is necessary for the caller to have already allocated the storage to * contain the string. The amount of memory necessary for the string is * specified in the version header file. * ******************************************************************************/ void XVersion_ToString(XVersion *InstancePtr, char *StringPtr) { /* assert to verify input arguments */ XASSERT_VOID(InstancePtr != NULL); XASSERT_VOID(StringPtr != NULL); /* since version is implemented as a string, just copy the specified * input into the specified output */ XVersion_Copy(InstancePtr, (XVersion *) StringPtr); } /*****************************************************************************/ /** * * Initializes a version from a null terminated string. Since the string may not * be a format which is compatible with the version, an error could occur. * * @param InstancePtr points to the version which is to be initialized. * @param StringPtr points to a null terminated string which will be * converted to a version. The format of the string must match the * version string format which is X.YYX where X = 0 - 9, YY = 00 - 99, * Z = a - z. * * @return * * A status, XST_SUCCESS, indicating the conversion was accomplished * successfully, or XST_INVALID_VERSION indicating the version string format * was not valid. * * @note * * None. * ******************************************************************************/ int XVersion_FromString(XVersion *InstancePtr, char *StringPtr) { /* assert to verify input arguments */ XASSERT_NONVOID(InstancePtr != NULL); XASSERT_NONVOID(StringPtr != NULL); /* if the version string specified is not valid, return an error */ if (!IsVersionStringValid(StringPtr)) { return XST_INVALID_VERSION; } /* copy the specified string into the specified version and indicate the * conversion was successful */ XVersion_Copy((XVersion *) StringPtr, InstancePtr); return XST_SUCCESS; } /*****************************************************************************/ /** * * Copies the contents of a version to another version. * * @param InstancePtr points to the version which is the source of data for * the copy operation. * @param VersionPtr points to another version which is the destination of * the copy operation. * * @return * * None. * * @note * * None. * ******************************************************************************/ void XVersion_Copy(XVersion *InstancePtr, XVersion *VersionPtr) { u8 *Source = (u8 *) InstancePtr; u8 *Destination = (u8 *) VersionPtr; u32 Index; /* assert to verify input arguments */ XASSERT_VOID(InstancePtr != NULL); XASSERT_VOID(VersionPtr != NULL); /* copy each byte of the source version to the destination version */ for (Index = 0; Index < sizeof(XVersion); Index++) { Destination[Index] = Source[Index]; } } /*****************************************************************************/ /** * * Determines if the specified version is valid. * * @param StringPtr points to the string to be validated. * * @return * * TRUE if the version string is a valid format, FALSE otherwise. * * @note * * None. * ******************************************************************************/ static int IsVersionStringValid(char *StringPtr) { /* if the input string is not a valid format, "X.YYZ" where X = 0 - 9, * YY = 00 - 99, and Z = a - z, then indicate it's not valid */ if ((StringPtr[XVE_MAJOR_CHAR] < '0') || (StringPtr[XVE_MAJOR_CHAR] > '9') || (StringPtr[XVE_MINOR_TENS_CHAR] < '0') || (StringPtr[XVE_MINOR_TENS_CHAR] > '9') || (StringPtr[XVE_MINOR_ONES_CHAR] < '0') || (StringPtr[XVE_MINOR_ONES_CHAR] > '9') || (StringPtr[XVE_COMP_CHAR] < 'a') || (StringPtr[XVE_COMP_CHAR] > 'z')) { return FALSE; } return TRUE; }