2013-01-11 13:08:51 +01:00
/*******************************************************************************
*
* Module Name : utstring - Common functions for strings and characters
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
2015-02-05 15:20:45 +08:00
* Copyright ( C ) 2000 - 2015 , Intel Corp .
2013-01-11 13:08:51 +01:00
* All rights reserved .
*
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions , and the following disclaimer ,
* without modification .
* 2. Redistributions in binary form must reproduce at minimum a disclaimer
* substantially similar to the " NO WARRANTY " disclaimer below
* ( " Disclaimer " ) and any redistribution must be conditioned upon
* including a substantially similar Disclaimer requirement for further
* binary redistribution .
* 3. Neither the names of the above - listed copyright holders nor the names
* of any contributors may be used to endorse or promote products derived
* from this software without specific prior written permission .
*
* Alternatively , this software may be distributed under the terms of the
* GNU General Public License ( " GPL " ) version 2 as published by the Free
* Software Foundation .
*
* NO WARRANTY
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* " AS IS " AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT
* LIMITED TO , THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT
* HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL , EXEMPLARY , OR CONSEQUENTIAL
* DAMAGES ( INCLUDING , BUT NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES ; LOSS OF USE , DATA , OR PROFITS ; OR BUSINESS INTERRUPTION )
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN CONTRACT ,
* STRICT LIABILITY , OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE , EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGES .
*/
# include <acpi/acpi.h>
# include "accommon.h"
# include "acnamesp.h"
# define _COMPONENT ACPI_UTILITIES
ACPI_MODULE_NAME ( " utstring " )
/*******************************************************************************
*
* FUNCTION : acpi_ut_print_string
*
* PARAMETERS : string - Null terminated ASCII string
2013-07-17 09:48:40 +08:00
* max_length - Maximum output length . Used to constrain the
* length of strings during debug output only .
2013-01-11 13:08:51 +01:00
*
* RETURN : None
*
* DESCRIPTION : Dump an ASCII string with support for ACPI - defined escape
* sequences .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2013-07-17 09:48:40 +08:00
void acpi_ut_print_string ( char * string , u16 max_length )
2013-01-11 13:08:51 +01:00
{
u32 i ;
if ( ! string ) {
acpi_os_printf ( " < \" NULL STRING PTR \" > " ) ;
return ;
}
acpi_os_printf ( " \" " ) ;
2014-04-04 12:36:55 +08:00
for ( i = 0 ; ( i < max_length ) & & string [ i ] ; i + + ) {
2013-01-11 13:08:51 +01:00
/* Escape sequences */
switch ( string [ i ] ) {
case 0x07 :
2013-06-08 00:58:14 +00:00
2013-01-11 13:08:51 +01:00
acpi_os_printf ( " \\ a " ) ; /* BELL */
break ;
case 0x08 :
2013-06-08 00:58:14 +00:00
2013-01-11 13:08:51 +01:00
acpi_os_printf ( " \\ b " ) ; /* BACKSPACE */
break ;
case 0x0C :
2013-06-08 00:58:14 +00:00
2013-01-11 13:08:51 +01:00
acpi_os_printf ( " \\ f " ) ; /* FORMFEED */
break ;
case 0x0A :
2013-06-08 00:58:14 +00:00
2013-01-11 13:08:51 +01:00
acpi_os_printf ( " \\ n " ) ; /* LINEFEED */
break ;
case 0x0D :
2013-06-08 00:58:14 +00:00
2013-01-11 13:08:51 +01:00
acpi_os_printf ( " \\ r " ) ; /* CARRIAGE RETURN */
break ;
case 0x09 :
2013-06-08 00:58:14 +00:00
2013-01-11 13:08:51 +01:00
acpi_os_printf ( " \\ t " ) ; /* HORIZONTAL TAB */
break ;
case 0x0B :
2013-06-08 00:58:14 +00:00
2013-01-11 13:08:51 +01:00
acpi_os_printf ( " \\ v " ) ; /* VERTICAL TAB */
break ;
case ' \' ' : /* Single Quote */
case ' \" ' : /* Double Quote */
case ' \\ ' : /* Backslash */
2013-06-08 00:58:14 +00:00
2013-01-11 13:08:51 +01:00
acpi_os_printf ( " \\ %c " , ( int ) string [ i ] ) ;
break ;
default :
/* Check for printable character or hex escape */
2015-07-01 14:45:11 +08:00
if ( isprint ( ( int ) string [ i ] ) ) {
2013-01-11 13:08:51 +01:00
/* This is a normal character */
acpi_os_printf ( " %c " , ( int ) string [ i ] ) ;
} else {
/* All others will be Hex escapes */
acpi_os_printf ( " \\ x%2.2X " , ( s32 ) string [ i ] ) ;
}
break ;
}
}
2015-12-29 13:54:36 +08:00
2013-01-11 13:08:51 +01:00
acpi_os_printf ( " \" " ) ;
if ( i = = max_length & & string [ i ] ) {
acpi_os_printf ( " ... " ) ;
}
}
/*******************************************************************************
*
* FUNCTION : acpi_ut_valid_acpi_char
*
* PARAMETERS : char - The character to be examined
* position - Byte position ( 0 - 3 )
*
* RETURN : TRUE if the character is valid , FALSE otherwise
*
* DESCRIPTION : Check for a valid ACPI character . Must be one of :
* 1 ) Upper case alpha
* 2 ) numeric
* 3 ) underscore
*
* We allow a ' ! ' as the last character because of the ASF ! table
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
u8 acpi_ut_valid_acpi_char ( char character , u32 position )
{
if ( ! ( ( character > = ' A ' & & character < = ' Z ' ) | |
( character > = ' 0 ' & & character < = ' 9 ' ) | | ( character = = ' _ ' ) ) ) {
/* Allow a '!' in the last position */
if ( character = = ' ! ' & & position = = 3 ) {
return ( TRUE ) ;
}
return ( FALSE ) ;
}
return ( TRUE ) ;
}
/*******************************************************************************
*
* FUNCTION : acpi_ut_valid_acpi_name
*
2013-06-08 00:59:44 +00:00
* PARAMETERS : name - The name to be examined . Does not have to
* be NULL terminated string .
2013-01-11 13:08:51 +01:00
*
* RETURN : TRUE if the name is valid , FALSE otherwise
*
* DESCRIPTION : Check for a valid ACPI name . Each character must be one of :
* 1 ) Upper case alpha
* 2 ) numeric
* 3 ) underscore
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2013-06-08 00:59:44 +00:00
u8 acpi_ut_valid_acpi_name ( char * name )
2013-01-11 13:08:51 +01:00
{
u32 i ;
ACPI_FUNCTION_ENTRY ( ) ;
for ( i = 0 ; i < ACPI_NAME_SIZE ; i + + ) {
2013-06-08 00:59:44 +00:00
if ( ! acpi_ut_valid_acpi_char ( name [ i ] , i ) ) {
2013-01-11 13:08:51 +01:00
return ( FALSE ) ;
}
}
return ( TRUE ) ;
}
/*******************************************************************************
*
* FUNCTION : acpi_ut_repair_name
*
* PARAMETERS : name - The ACPI name to be repaired
*
* RETURN : Repaired version of the name
*
* DESCRIPTION : Repair an ACPI name : Change invalid characters to ' * ' and
* return the new name . NOTE : the Name parameter must reside in
* read / write memory , cannot be a const .
*
* An ACPI Name must consist of valid ACPI characters . We will repair the name
* if necessary because we don ' t want to abort because of this , but we want
* all namespace names to be printable . A warning message is appropriate .
*
* This issue came up because there are in fact machines that exhibit
* this problem , and we want to be able to enable ACPI support for them ,
* even though there are a few bad names .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void acpi_ut_repair_name ( char * name )
{
u32 i ;
u8 found_bad_char = FALSE ;
u32 original_name ;
ACPI_FUNCTION_NAME ( ut_repair_name ) ;
ACPI_MOVE_NAME ( & original_name , name ) ;
/* Check each character in the name */
for ( i = 0 ; i < ACPI_NAME_SIZE ; i + + ) {
if ( acpi_ut_valid_acpi_char ( name [ i ] , i ) ) {
continue ;
}
/*
* Replace a bad character with something printable , yet technically
* still invalid . This prevents any collisions with existing " good "
* names in the namespace .
*/
name [ i ] = ' * ' ;
found_bad_char = TRUE ;
}
if ( found_bad_char ) {
/* Report warning only if in strict mode or debug mode */
if ( ! acpi_gbl_enable_interpreter_slack ) {
ACPI_WARNING ( ( AE_INFO ,
" Invalid character(s) in name (0x%.8X), repaired: [%4.4s] " ,
original_name , name ) ) ;
} else {
ACPI_DEBUG_PRINT ( ( ACPI_DB_INFO ,
" Invalid character(s) in name (0x%.8X), repaired: [%4.4s] " ,
original_name , name ) ) ;
}
}
}
# if defined ACPI_ASL_COMPILER || defined ACPI_EXEC_APP
/*******************************************************************************
*
* FUNCTION : ut_convert_backslashes
*
* PARAMETERS : pathname - File pathname string to be converted
*
* RETURN : Modifies the input Pathname
*
* DESCRIPTION : Convert all backslashes ( 0x5C ) to forward slashes ( 0x2F ) within
* the entire input file pathname string .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void ut_convert_backslashes ( char * pathname )
{
if ( ! pathname ) {
return ;
}
while ( * pathname ) {
if ( * pathname = = ' \\ ' ) {
* pathname = ' / ' ;
}
pathname + + ;
}
}
# endif