2005-04-16 15:20:36 -07:00
/*
2008-08-05 16:14:15 +01:00
* arch / arm / mach - clps711x / include / mach / uncompress . h
2005-04-16 15:20:36 -07:00
*
* Copyright ( C ) 2000 Deep Blue Solutions Ltd
*
* 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 .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* 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 . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
2012-05-14 21:46:08 +04:00
# include <mach/clps711x.h>
2005-04-16 15:20:36 -07:00
# ifdef CONFIG_DEBUG_CLPS711X_UART2
# define SYSFLGx SYSFLG2
# define UARTDRx UARTDR2
# else
# define SYSFLGx SYSFLG1
# define UARTDRx UARTDR1
# endif
2012-05-06 09:21:57 +04:00
# define phys_reg(x) (*(volatile u32 *)(CLPS711X_PHYS_BASE + (x)))
2005-04-16 15:20:36 -07:00
/*
2012-05-06 09:21:57 +04:00
* The following code assumes the serial port has already been
* initialized by the bootloader . If you didn ' t setup a port in
* your bootloader then nothing will appear ( which might be desired ) .
*
2005-04-16 15:20:36 -07:00
* This does not append a newline
*/
2006-03-28 10:24:33 +01:00
static inline void putc ( int c )
2005-04-16 15:20:36 -07:00
{
2012-05-06 09:21:57 +04:00
while ( phys_reg ( SYSFLGx ) & SYSFLG_UTXFF )
2006-03-28 10:24:33 +01:00
barrier ( ) ;
2012-05-06 09:21:57 +04:00
phys_reg ( UARTDRx ) = c ;
2006-03-28 10:24:33 +01:00
}
2005-04-16 15:20:36 -07:00
2006-03-28 10:24:33 +01:00
static inline void flush ( void )
{
2012-05-06 09:21:57 +04:00
while ( phys_reg ( SYSFLGx ) & SYSFLG_UBUSY )
2005-04-16 15:20:36 -07:00
barrier ( ) ;
}
/*
* nothing to do
*/
# define arch_decomp_setup()