cpci_hotplug.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. /*
  2. * CompactPCI Hot Plug Core Functions
  3. *
  4. * Copyright (C) 2002 SOMA Networks, Inc.
  5. * Copyright (C) 2001 Greg Kroah-Hartman (greg@kroah.com)
  6. * Copyright (C) 2001 IBM Corp.
  7. *
  8. * All rights reserved.
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License as published by
  12. * the Free Software Foundation; either version 2 of the License, or (at
  13. * your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful, but
  16. * WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or
  18. * NON INFRINGEMENT. See the GNU General Public License for more
  19. * details.
  20. *
  21. * You should have received a copy of the GNU General Public License
  22. * along with this program; if not, write to the Free Software
  23. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  24. *
  25. * Send feedback to <scottm@somanetworks.com>
  26. */
  27. #ifndef _CPCI_HOTPLUG_H
  28. #define _CPCI_HOTPLUG_H
  29. #include <linux/types.h>
  30. #include <linux/pci.h>
  31. /* PICMG 2.1 R2.0 HS CSR bits: */
  32. #define HS_CSR_INS 0x0080
  33. #define HS_CSR_EXT 0x0040
  34. #define HS_CSR_PI 0x0030
  35. #define HS_CSR_LOO 0x0008
  36. #define HS_CSR_PIE 0x0004
  37. #define HS_CSR_EIM 0x0002
  38. #define HS_CSR_DHA 0x0001
  39. struct slot {
  40. u8 number;
  41. unsigned int devfn;
  42. struct pci_bus *bus;
  43. struct pci_dev *dev;
  44. unsigned int extracting;
  45. struct hotplug_slot *hotplug_slot;
  46. struct list_head slot_list;
  47. };
  48. struct cpci_hp_controller_ops {
  49. int (*query_enum) (void);
  50. int (*enable_irq) (void);
  51. int (*disable_irq) (void);
  52. int (*check_irq) (void *dev_id);
  53. int (*hardware_test) (struct slot* slot, u32 value);
  54. u8 (*get_power) (struct slot* slot);
  55. int (*set_power) (struct slot* slot, int value);
  56. };
  57. struct cpci_hp_controller {
  58. unsigned int irq;
  59. unsigned long irq_flags;
  60. char *devname;
  61. void *dev_id;
  62. char *name;
  63. struct cpci_hp_controller_ops *ops;
  64. };
  65. extern int cpci_hp_register_controller(struct cpci_hp_controller *controller);
  66. extern int cpci_hp_unregister_controller(struct cpci_hp_controller *controller);
  67. extern int cpci_hp_register_bus(struct pci_bus *bus, u8 first, u8 last);
  68. extern int cpci_hp_unregister_bus(struct pci_bus *bus);
  69. extern int cpci_hp_start(void);
  70. extern int cpci_hp_stop(void);
  71. /*
  72. * Internal function prototypes, these functions should not be used by
  73. * board/chassis drivers.
  74. */
  75. extern u8 cpci_get_attention_status(struct slot *slot);
  76. extern u8 cpci_get_latch_status(struct slot *slot);
  77. extern u8 cpci_get_adapter_status(struct slot *slot);
  78. extern u16 cpci_get_hs_csr(struct slot * slot);
  79. extern int cpci_set_attention_status(struct slot *slot, int status);
  80. extern int cpci_check_and_clear_ins(struct slot * slot);
  81. extern int cpci_check_ext(struct slot * slot);
  82. extern int cpci_clear_ext(struct slot * slot);
  83. extern int cpci_led_on(struct slot * slot);
  84. extern int cpci_led_off(struct slot * slot);
  85. extern int cpci_configure_slot(struct slot *slot);
  86. extern int cpci_unconfigure_slot(struct slot *slot);
  87. #endif /* _CPCI_HOTPLUG_H */