tc6393xb.h 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /*
  2. * Toshiba TC6393XB SoC support
  3. *
  4. * Copyright(c) 2005-2006 Chris Humbert
  5. * Copyright(c) 2005 Dirk Opfer
  6. * Copyright(c) 2005 Ian Molton <spyro@f2s.com>
  7. * Copyright(c) 2007 Dmitry Baryshkov
  8. *
  9. * Based on code written by Sharp/Lineo for 2.4 kernels
  10. * Based on locomo.c
  11. *
  12. * This program is free software; you can redistribute it and/or modify
  13. * it under the terms of the GNU General Public License version 2 as
  14. * published by the Free Software Foundation.
  15. */
  16. #ifndef MFD_TC6393XB_H
  17. #define MFD_TC6393XB_H
  18. /* Also one should provide the CK3P6MI clock */
  19. struct tc6393xb_platform_data {
  20. u16 scr_pll2cr; /* PLL2 Control */
  21. u16 scr_gper; /* GP Enable */
  22. int (*enable)(struct platform_device *dev);
  23. int (*disable)(struct platform_device *dev);
  24. int (*suspend)(struct platform_device *dev);
  25. int (*resume)(struct platform_device *dev);
  26. int irq_base; /* base for subdevice irqs */
  27. int gpio_base;
  28. int (*setup)(struct platform_device *dev);
  29. void (*teardown)(struct platform_device *dev);
  30. struct tmio_nand_data *nand_data;
  31. unsigned resume_restore : 1; /* make special actions
  32. to preserve the state
  33. on suspend/resume */
  34. };
  35. /*
  36. * Relative to irq_base
  37. */
  38. #define IRQ_TC6393_NAND 0
  39. #define IRQ_TC6393_MMC 1
  40. #define IRQ_TC6393_OHCI 2
  41. #define TC6393XB_NR_IRQS 8
  42. #endif