mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 10:08:21 +01:00 
			
		
		
		
	As discussed on the list, move "arch/ppc" to "arch/powerpc" to better match the Linux directory structure. Please note that this patch also changes the "ppc" target in MAKEALL to "powerpc" to match this new infrastructure. But "ppc" is kept as an alias for now, to not break compatibility with scripts using this name. Signed-off-by: Stefan Roese <sr@denx.de> Acked-by: Wolfgang Denk <wd@denx.de> Acked-by: Detlev Zundel <dzu@denx.de> Acked-by: Kim Phillips <kim.phillips@freescale.com> Cc: Peter Tyser <ptyser@xes-inc.com> Cc: Anatolij Gustschin <agust@denx.de>
		
			
				
	
	
		
			213 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			213 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*	Copyright Motorola, Inc. 1993, 1994
 | |
| 	ALL RIGHTS RESERVED
 | |
| 
 | |
| 	You are hereby granted a copyright license to use, modify, and
 | |
| 	distribute the SOFTWARE so long as this entire notice is retained
 | |
| 	without alteration in any modified and/or redistributed versions,
 | |
| 	and that such modified versions are clearly identified as such.
 | |
| 	No licenses are granted by implication, estoppel or otherwise under
 | |
| 	any patents or trademarks of Motorola, Inc.
 | |
| 
 | |
| 	The SOFTWARE is provided on an "AS IS" basis and without warranty.
 | |
| 	To the maximum extent permitted by applicable law, MOTOROLA DISCLAIMS
 | |
| 	ALL WARRANTIES WHETHER EXPRESS OR IMPLIED, INCLUDING IMPLIED
 | |
| 	WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR
 | |
| 	PURPOSE AND ANY WARRANTY AGAINST INFRINGEMENT WITH
 | |
| 	REGARD TO THE SOFTWARE (INCLUDING ANY MODIFIED VERSIONS
 | |
| 	THEREOF) AND ANY ACCOMPANYING WRITTEN MATERIALS.
 | |
| 
 | |
| 	To the maximum extent permitted by applicable law, IN NO EVENT SHALL
 | |
| 	MOTOROLA BE LIABLE FOR ANY DAMAGES WHATSOEVER
 | |
| 	(INCLUDING WITHOUT LIMITATION, DAMAGES FOR LOSS OF
 | |
| 	BUSINESS PROFITS, BUSINESS INTERRUPTION, LOSS OF BUSINESS
 | |
| 	INFORMATION, OR OTHER PECUNIARY LOSS) ARISING OF THE USE OR
 | |
| 	INABILITY TO USE THE SOFTWARE.   Motorola assumes no responsibility
 | |
| 	for the maintenance and support of the SOFTWARE.
 | |
| 
 | |
| */
 | |
| 
 | |
| 
 | |
| #include "config.h"
 | |
| 
 | |
| /*
 | |
| 	 1         2         3         4         5         6         7         8
 | |
| 01234567890123456789012345678901234567890123456789012345678901234567890123456789
 | |
| */
 | |
| /* List define statements here */
 | |
| 
 | |
| /* These are for all the toolboxes and functions to use. These will help
 | |
| to standardize the error handling in the current project */
 | |
| 
 | |
| 				/* this is the "data type" for the error
 | |
| 				messages in the system */
 | |
| #define STATUS unsigned int
 | |
| 
 | |
| 				/* this is a success status code */
 | |
| #define SUCCESS 1
 | |
| 
 | |
| 				/* likewise this is failure */
 | |
| #define FAILURE 0
 | |
| 
 | |
| #define NUM_ERRORS 47
 | |
| 
 | |
| /* This first section of "defines" are for error codes ONLY.  The called
 | |
|    routine will return one of these error codes to the caller.  If the final
 | |
|    returned code is "VALID", then everything is a-okay.  However, if one
 | |
|    of the functions returns a non-valid status, that error code should be
 | |
|    propogated back to all the callers.  At the end, the last caller will
 | |
|    call an error_processing function, and send in the status which was
 | |
|    returned.  It's up to the error_processing function to determine which
 | |
|    error occured (as indicated by the status), and print an appropriate
 | |
|    message back to the user.
 | |
| */
 | |
| /*----------------------------------------------------------------------*/
 | |
| /* these are specifically for the parser routines			*/
 | |
| 
 | |
| #define UNKNOWN_COMMAND		0xfb00 /* "unrecognized command " */
 | |
| #define UNKNOWN_REGISTER	0xfb01 /* "unknown register "*/
 | |
| #define ILLEGAL_RD_STAGE	0xfb02 /* cannot specify reg. family in range*/
 | |
| #define ILLEGAL_REG_FAMILY	0xfb03 /* "cannot specify a range of special
 | |
| 					or miscellaneous registers"*/
 | |
| #define RANGE_CROSS_FAMILY	0xfb04 /* "cannot specify a range across
 | |
| 					register families" */
 | |
| #define UNIMPLEMENTED_STAGE	0xfb05 /* invalid rd or rmm parameter format */
 | |
| #define REG_NOT_WRITEABLE	0xfb06 /* "unknown operator in arguements"*/
 | |
| #define INVALID_FILENAME	0xfb07 /* "invalid download filename" */
 | |
| #define INVALID_BAUD_RATE	0xfb08	/* invalid baud rate from sb command */
 | |
| #define UNSUPPORTED_REGISTER	0xfb09	/* Special register is not supported */
 | |
| #define FOR_BOARD_ONLY		0xfb0a  /* "Not available for Unix." */
 | |
| 
 | |
| 
 | |
| /*----------------------------------------------------------------------*/
 | |
| /* these are for the error checking toolbox				*/
 | |
| 
 | |
| #define INVALID			0xfd00 /* NOT valid */
 | |
| #define VALID			0xfd01 /* valid */
 | |
| 
 | |
| 					/* This error is found in the fcn:
 | |
| 					is_right_size_input() to indicate
 | |
| 					that the input was not 8 characters
 | |
| 					long.  */
 | |
| #define INVALID_SIZE		0xfd02
 | |
| 
 | |
| 					/* This error is found in the fcn:
 | |
| 					is_valid_address_range() to indicate
 | |
| 					that the address given falls outside
 | |
| 					of valid memory defined by MEM_START
 | |
| 					to MEM_END.
 | |
| 					*/
 | |
| #define OUT_OF_BOUNDS_ADDRESS	0xfd03
 | |
| 
 | |
| 					/* This error is found in the fcn:
 | |
| 					is_valid_hex_input() to indicate that
 | |
| 					one of more of the characters entered
 | |
| 					are not valid hex characters.  Valid
 | |
| 					hex characters are 0-9, A-F, a-f.
 | |
| 					*/
 | |
| #define INVALID_HEX_INPUT	0xfd04
 | |
| 
 | |
| 					/* This error is found in the fcn:
 | |
| 					is_valid_register_number() to indicate
 | |
| 					that a given register does not exist.
 | |
| 					*/
 | |
| #define REG_NOT_READABLE	0xfd05
 | |
| 
 | |
| 					/* This error is found in the fcn:
 | |
| 					is_word_aligned_address() to indicate
 | |
| 					that the given address is not word-
 | |
| 					aligned.  A word-aligned address ends
 | |
| 					in 0x0,0x4,0x8,0xc.
 | |
| 					*/
 | |
| #define	NOT_WORD_ALIGNED	0xfd07
 | |
| 
 | |
| 					/* This error is found in the fcn:
 | |
| 					is_valid_address_range() to indicate
 | |
| 					that the starting address is greater
 | |
| 					than the ending address.
 | |
| 					*/
 | |
| #define REVERSED_ADDRESS	0xfd08
 | |
| 
 | |
| 					/* this error tells us that the address
 | |
| 					specified as the destination is within
 | |
| 					the source addresses  */
 | |
| #define RANGE_OVERLAP		0xfd09
 | |
| 
 | |
| 
 | |
| #define	ERROR			0xfd0a /* An error occured */
 | |
| #define INVALID_PARAM		0xfd0b /* "invalid input parameter " */
 | |
| 
 | |
| 
 | |
| #define INVALID_FLAG		0xfd0c	/* invalid flag */
 | |
| 
 | |
| /*----------------------------------------------------------------------*/
 | |
| /* these are for the getarg toolbox					*/
 | |
| 
 | |
| #define INVALID_NUMBER_ARGS	0xFE00 /* invalid number of commd arguements */
 | |
| #define UNKNOWN_PARAMETER	0xFE01 /* "unknown type of parameter "*/
 | |
| 
 | |
| 
 | |
| /*----------------------------------------------------------------------*/
 | |
| /* these are for the tokenizer toolbox					*/
 | |
| 
 | |
| #define ILLEGAL_CHARACTER	0xFF00 /* unrecognized char. in input stream*/
 | |
| #define TTL_NOT_SORTED		0xFF01 /* token translation list not sorted */
 | |
| #define TTL_NOT_DEFINED		0xFF02 /* token translation list not assigned*/
 | |
| #define INVALID_STRING		0xFF03 /* unable to extract string from input */
 | |
| #define BUFFER_EMPTY		0xFF04 /* "input buffer is empty" */
 | |
| #define INVALID_MODE		0xFF05 /* input buf is in an unrecognized mode*/
 | |
| #define TOK_INTERNAL_ERROR	0xFF06 /* "internal tokenizer error" */
 | |
| #define TOO_MANY_IBS		0xFF07 /* "too many open input buffers" */
 | |
| #define NO_OPEN_IBS		0xFF08 /* "no open input buffers" */
 | |
| 
 | |
| 
 | |
| /* these are for the read from screen toolbox */
 | |
| 
 | |
| #define RESERVED_WORD		0xFC00 /* used a reserved word as an arguement*/
 | |
| 
 | |
| 
 | |
| /* these are for the breakpoint routines */
 | |
| 
 | |
| #define FULL_BPDS		0xFA00 /* breakpoint data structure is full */
 | |
| 
 | |
| 
 | |
| /* THESE are for the downloader */
 | |
| 
 | |
| #define NOT_IN_S_RECORD_FORMAT	0xf900 /* "not in S-Record Format" */
 | |
| #define UNREC_RECORD_TYPE	0xf901 /* "unrecognized record type" */
 | |
| #define CONVERSION_ERROR	0xf902 /* "ascii to int conversion error" */
 | |
| #define INVALID_MEMORY		0xf903 /* "bad s-record memory address " */
 | |
| 
 | |
| 
 | |
| /* these are for the compression and decompression stuff */
 | |
| 
 | |
| #define COMP_UNK_CHARACTER	0xf800 /* "unknown compressed character " */
 | |
| 
 | |
| #define COMP_UNKNOWN_STATE	0xf801 /* "unknown binary state" */
 | |
| 
 | |
| #define NOT_IN_COMPRESSED_FORMAT 0xf802 /* not in compressed S-Record format */
 | |
| 
 | |
| 
 | |
| /* these are for the DUART handling things */
 | |
| 
 | |
| 					/* "unrecognized serial port configuration" */
 | |
| #define UNKNOWN_PORT_STATE	0xf700
 | |
| 
 | |
| 
 | |
| /* these are for the register toolbox */
 | |
| 
 | |
| 					/* "cannot find register in special
 | |
| 					 purpose register file " */
 | |
| #define SPR_NOT_FOUND		0xf600
 | |
| 
 | |
| 
 | |
| /* these are for the duart specific stuff */
 | |
| 
 | |
| 					/* "transparent mode needs access to
 | |
| 						two serial ports" */
 | |
| #define TM_NEEDS_BOTH_PORTS	0xf500
 | |
| 
 | |
| 
 | |
| /*----------------------------------------------------------------------*/
 | |
| /* these are specifically for the flash routines			*/
 | |
| #define FLASH_ERROR		0xf100		/* general flash error */
 |