uncompress.h 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. /*
  2. * Copyright 2003 ARM Limited
  3. * Copyright 2008 Cavium Networks
  4. *
  5. * This file is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License, Version 2, as
  7. * published by the Free Software Foundation.
  8. */
  9. #include <asm/mach-types.h>
  10. #include <mach/cns3xxx.h>
  11. #define AMBA_UART_DR(base) (*(volatile unsigned char *)((base) + 0x00))
  12. #define AMBA_UART_LCRH(base) (*(volatile unsigned char *)((base) + 0x2c))
  13. #define AMBA_UART_CR(base) (*(volatile unsigned char *)((base) + 0x30))
  14. #define AMBA_UART_FR(base) (*(volatile unsigned char *)((base) + 0x18))
  15. /*
  16. * Return the UART base address
  17. */
  18. static inline unsigned long get_uart_base(void)
  19. {
  20. if (machine_is_cns3420vb())
  21. return CNS3XXX_UART0_BASE;
  22. else
  23. return 0;
  24. }
  25. /*
  26. * This does not append a newline
  27. */
  28. static inline void putc(int c)
  29. {
  30. unsigned long base = get_uart_base();
  31. while (AMBA_UART_FR(base) & (1 << 5))
  32. barrier();
  33. AMBA_UART_DR(base) = c;
  34. }
  35. static inline void flush(void)
  36. {
  37. unsigned long base = get_uart_base();
  38. while (AMBA_UART_FR(base) & (1 << 3))
  39. barrier();
  40. }
  41. /*
  42. * nothing to do
  43. */
  44. #define arch_decomp_setup()
  45. #define arch_decomp_wdog()