| /****************************************************************************** |
| * |
| * Author: Xilinx, Inc. |
| * |
| * |
| * This program is free software; you can redistribute it and/or modify it |
| * under the terms of the GNU General Public License as published by the |
| * Free Software Foundation; either version 2 of the License, or (at your |
| * option) any later version. |
| * |
| * |
| * XILINX IS PROVIDING THIS DESIGN, CODE, OR INFORMATION "AS IS" AS A |
| * COURTESY TO YOU. BY PROVIDING THIS DESIGN, CODE, OR INFORMATION AS |
| * ONE POSSIBLE IMPLEMENTATION OF THIS FEATURE, APPLICATION OR STANDARD, |
| * XILINX IS MAKING NO REPRESENTATION THAT THIS IMPLEMENTATION IS FREE |
| * FROM ANY CLAIMS OF INFRINGEMENT, AND YOU ARE RESPONSIBLE FOR OBTAINING |
| * ANY THIRD PARTY RIGHTS YOU MAY REQUIRE FOR YOUR IMPLEMENTATION. |
| * XILINX EXPRESSLY DISCLAIMS ANY WARRANTY WHATSOEVER WITH RESPECT TO |
| * THE ADEQUACY OF THE IMPLEMENTATION, INCLUDING BUT NOT LIMITED TO ANY |
| * WARRANTIES OR REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM |
| * CLAIMS OF INFRINGEMENT, IMPLIED WARRANTIES OF MERCHANTABILITY AND |
| * FITNESS FOR A PARTICULAR PURPOSE. |
| * |
| * |
| * Xilinx hardware products are not intended for use in life support |
| * appliances, devices, or systems. Use in such applications is |
| * expressly prohibited. |
| * |
| * |
| * (c) Copyright 2002-2004 Xilinx Inc. |
| * All rights reserved. |
| * |
| * |
| * You should have received a copy of the GNU General Public License along |
| * with this program; if not, write to the Free Software Foundation, Inc., |
| * 675 Mass Ave, Cambridge, MA 02139, USA. |
| * |
| ******************************************************************************/ |
| /***************************************************************************** |
| * |
| * 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. |
| * |
| * <pre> |
| * 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 |
| </pre> |
| * |
| ******************************************************************************/ |
| |
| /***************************** 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 u32 IsVersionStringValid(s8 * 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) |
| { |
| /* 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 |
| * <br><br> |
| * The packed version pointed to by PackedVersionPtr is modified with the new |
| * packed version if the status indicates success. |
| * |
| * @note |
| * |
| * None. |
| * |
| ******************************************************************************/ |
| XStatus |
| XVersion_Pack(XVersion * InstancePtr, u16 * PackedVersionPtr) |
| { |
| /* not implemented yet since CROM related */ |
| |
| 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. |
| * |
| ******************************************************************************/ |
| u32 |
| XVersion_IsEqual(XVersion * InstancePtr, XVersion * VersionPtr) |
| { |
| u8 *Version1 = (u8 *) InstancePtr; |
| u8 *Version2 = (u8 *) VersionPtr; |
| int 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, s8 * 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. |
| * |
| ******************************************************************************/ |
| XStatus |
| XVersion_FromString(XVersion * InstancePtr, s8 * 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; |
| int 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 u32 |
| IsVersionStringValid(s8 * 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; |
| } |