psycho_common.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. /* psycho_common.c: Code common to PSYCHO and derivative PCI controllers.
  2. *
  3. * Copyright (C) 2008 David S. Miller <davem@davemloft.net>
  4. */
  5. #include <linux/kernel.h>
  6. #include <asm/upa.h>
  7. #include "pci_impl.h"
  8. #include "psycho_common.h"
  9. #define PSYCHO_IOMMU_TAG 0xa580UL
  10. #define PSYCHO_IOMMU_DATA 0xa600UL
  11. static void psycho_iommu_flush(struct pci_pbm_info *pbm)
  12. {
  13. int i;
  14. for (i = 0; i < 16; i++) {
  15. unsigned long off = i * 8;
  16. upa_writeq(0, pbm->controller_regs + PSYCHO_IOMMU_TAG + off);
  17. upa_writeq(0, pbm->controller_regs + PSYCHO_IOMMU_DATA + off);
  18. }
  19. }
  20. #define PSYCHO_IOMMU_CONTROL 0x0200UL
  21. #define PSYCHO_IOMMU_CTRL_TSBSZ 0x0000000000070000UL
  22. #define PSYCHO_IOMMU_TSBSZ_1K 0x0000000000000000UL
  23. #define PSYCHO_IOMMU_TSBSZ_2K 0x0000000000010000UL
  24. #define PSYCHO_IOMMU_TSBSZ_4K 0x0000000000020000UL
  25. #define PSYCHO_IOMMU_TSBSZ_8K 0x0000000000030000UL
  26. #define PSYCHO_IOMMU_TSBSZ_16K 0x0000000000040000UL
  27. #define PSYCHO_IOMMU_TSBSZ_32K 0x0000000000050000UL
  28. #define PSYCHO_IOMMU_TSBSZ_64K 0x0000000000060000UL
  29. #define PSYCHO_IOMMU_TSBSZ_128K 0x0000000000070000UL
  30. #define PSYCHO_IOMMU_CTRL_TBWSZ 0x0000000000000004UL
  31. #define PSYCHO_IOMMU_CTRL_DENAB 0x0000000000000002UL
  32. #define PSYCHO_IOMMU_CTRL_ENAB 0x0000000000000001UL
  33. #define PSYCHO_IOMMU_FLUSH 0x0210UL
  34. #define PSYCHO_IOMMU_TSBBASE 0x0208UL
  35. int psycho_iommu_init(struct pci_pbm_info *pbm, int tsbsize,
  36. u32 dvma_offset, u32 dma_mask,
  37. unsigned long write_complete_offset)
  38. {
  39. struct iommu *iommu = pbm->iommu;
  40. u64 control;
  41. int err;
  42. iommu->iommu_control = pbm->controller_regs + PSYCHO_IOMMU_CONTROL;
  43. iommu->iommu_tsbbase = pbm->controller_regs + PSYCHO_IOMMU_TSBBASE;
  44. iommu->iommu_flush = pbm->controller_regs + PSYCHO_IOMMU_FLUSH;
  45. iommu->iommu_tags = pbm->controller_regs + PSYCHO_IOMMU_TAG;
  46. iommu->write_complete_reg = (pbm->controller_regs +
  47. write_complete_offset);
  48. iommu->iommu_ctxflush = 0;
  49. control = upa_readq(iommu->iommu_control);
  50. control |= PSYCHO_IOMMU_CTRL_DENAB;
  51. upa_writeq(control, iommu->iommu_control);
  52. psycho_iommu_flush(pbm);
  53. /* Leave diag mode enabled for full-flushing done in pci_iommu.c */
  54. err = iommu_table_init(iommu, tsbsize * 1024 * 8,
  55. dvma_offset, dma_mask, pbm->numa_node);
  56. if (err)
  57. return err;
  58. upa_writeq(__pa(iommu->page_table), iommu->iommu_tsbbase);
  59. control = upa_readq(iommu->iommu_control);
  60. control &= ~(PSYCHO_IOMMU_CTRL_TSBSZ | PSYCHO_IOMMU_CTRL_TBWSZ);
  61. control |= PSYCHO_IOMMU_CTRL_ENAB;
  62. switch (tsbsize) {
  63. case 64:
  64. control |= PSYCHO_IOMMU_TSBSZ_64K;
  65. break;
  66. case 128:
  67. control |= PSYCHO_IOMMU_TSBSZ_128K;
  68. break;
  69. default:
  70. return -EINVAL;
  71. }
  72. upa_writeq(control, iommu->iommu_control);
  73. return 0;
  74. }
  75. void psycho_pbm_init_common(struct pci_pbm_info *pbm, struct of_device *op,
  76. const char *chip_name, int chip_type)
  77. {
  78. struct device_node *dp = op->node;
  79. pbm->name = dp->full_name;
  80. pbm->numa_node = -1;
  81. pbm->chip_type = chip_type;
  82. pbm->chip_version = of_getintprop_default(dp, "version#", 0);
  83. pbm->chip_revision = of_getintprop_default(dp, "module-revision#", 0);
  84. pbm->op = op;
  85. pbm->pci_ops = &sun4u_pci_ops;
  86. pbm->config_space_reg_bits = 8;
  87. pbm->index = pci_num_pbms++;
  88. pci_get_pbm_props(pbm);
  89. pci_determine_mem_io_space(pbm);
  90. printk(KERN_INFO "%s: %s PCI Bus Module ver[%x:%x]\n",
  91. pbm->name, chip_name,
  92. pbm->chip_version, pbm->chip_revision);
  93. }