vme_pio2_cntr.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /*
  2. * GE PIO2 Counter Driver
  3. *
  4. * Author: Martyn Welch <martyn.welch@ge.com>
  5. * Copyright 2009 GE Intelligent Platforms Embedded Systems, Inc.
  6. *
  7. * This program is free software; you can redistribute it and/or modify it
  8. * under the terms of the GNU General Public License as published by the
  9. * Free Software Foundation; either version 2 of the License, or (at your
  10. * option) any later version.
  11. *
  12. * The PIO-2 has 6 counters, currently this code just disables the interrupts
  13. * and leaves them alone.
  14. *
  15. */
  16. #include <linux/device.h>
  17. #include <linux/types.h>
  18. #include <linux/gpio.h>
  19. #include <linux/vme.h>
  20. #include "vme_pio2.h"
  21. static int pio2_cntr_irq_set(struct pio2_card *card, int id)
  22. {
  23. int retval;
  24. u8 data;
  25. data = PIO2_CNTR_SC_DEV[id] | PIO2_CNTR_RW_BOTH | card->cntr[id].mode;
  26. retval = vme_master_write(card->window, &data, 1, PIO2_CNTR_CTRL[id]);
  27. if (retval < 0)
  28. return retval;
  29. data = card->cntr[id].count & 0xFF;
  30. retval = vme_master_write(card->window, &data, 1, PIO2_CNTR_DATA[id]);
  31. if (retval < 0)
  32. return retval;
  33. data = (card->cntr[id].count >> 8) & 0xFF;
  34. retval = vme_master_write(card->window, &data, 1, PIO2_CNTR_DATA[id]);
  35. if (retval < 0)
  36. return retval;
  37. return 0;
  38. }
  39. int pio2_cntr_reset(struct pio2_card *card)
  40. {
  41. int i, retval = 0;
  42. u8 reg;
  43. /* Clear down all timers */
  44. for (i = 0; i < 6; i++) {
  45. card->cntr[i].mode = PIO2_CNTR_MODE5;
  46. card->cntr[i].count = 0;
  47. retval = pio2_cntr_irq_set(card, i);
  48. if (retval < 0)
  49. return retval;
  50. }
  51. /* Ensure all counter interrupts are cleared */
  52. do {
  53. retval = vme_master_read(card->window, &reg, 1,
  54. PIO2_REGS_INT_STAT_CNTR);
  55. if (retval < 0)
  56. return retval;
  57. } while (reg != 0);
  58. return retval;
  59. }