early_printk.c 888 B

12345678910111213141516171819202122232425262728293031323334
  1. /*
  2. * This program is free software; you can redistribute it and/or modify it
  3. * under the terms of the GNU General Public License version 2 as published
  4. * by the Free Software Foundation.
  5. *
  6. * Copyright (C) 2010 John Crispin <blogic@openwrt.org>
  7. */
  8. #include <linux/init.h>
  9. #include <linux/cpu.h>
  10. #include <lantiq.h>
  11. #include <lantiq_soc.h>
  12. /* no ioremap possible at this early stage, lets use KSEG1 instead */
  13. #define LTQ_ASC_BASE KSEG1ADDR(LTQ_ASC1_BASE_ADDR)
  14. #define ASC_BUF 1024
  15. #define LTQ_ASC_FSTAT ((u32 *)(LTQ_ASC_BASE + 0x0048))
  16. #define LTQ_ASC_TBUF ((u32 *)(LTQ_ASC_BASE + 0x0020))
  17. #define TXMASK 0x3F00
  18. #define TXOFFSET 8
  19. void prom_putchar(char c)
  20. {
  21. unsigned long flags;
  22. local_irq_save(flags);
  23. do { } while ((ltq_r32(LTQ_ASC_FSTAT) & TXMASK) >> TXOFFSET);
  24. if (c == '\n')
  25. ltq_w32('\r', LTQ_ASC_TBUF);
  26. ltq_w32(c, LTQ_ASC_TBUF);
  27. local_irq_restore(flags);
  28. }