proc.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. /*
  2. * This program is free software; you can distribute it and/or modify it
  3. * under the terms of the GNU General Public License (Version 2) as
  4. * published by the Free Software Foundation.
  5. *
  6. * This program is distributed in the hope it will be useful, but WITHOUT
  7. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  8. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
  9. * for more details.
  10. *
  11. * You should have received a copy of the GNU General Public License along
  12. * with this program; if not, write to the Free Software Foundation, Inc.,
  13. * 59 Temple Place - Suite 330, Boston MA 02111-1307, USA.
  14. */
  15. #include <linux/init.h>
  16. #include <linux/proc_fs.h>
  17. #include <linux/irq.h>
  18. #include <linux/sched.h>
  19. #include <linux/slab.h>
  20. #include <linux/interrupt.h>
  21. #include <linux/kernel_stat.h>
  22. #include <linux/random.h>
  23. #include <asm/io.h>
  24. #include <asm/gdb-stub.h>
  25. #include <int.h>
  26. #include <uart.h>
  27. static int pnx8550_timers_read (char* page, char** start, off_t offset, int count, int* eof, void* data)
  28. {
  29. int len = 0;
  30. int configPR = read_c0_config7();
  31. if (offset==0) {
  32. len += sprintf(&page[len],"Timer: count, compare, tc, status\n");
  33. len += sprintf(&page[len]," 1: %11i, %8i, %1i, %s\n",
  34. read_c0_count(), read_c0_compare(),
  35. (configPR>>6)&0x1, ((configPR>>3)&0x1)? "off":"on");
  36. len += sprintf(&page[len]," 2: %11i, %8i, %1i, %s\n",
  37. read_c0_count2(), read_c0_compare2(),
  38. (configPR>>7)&0x1, ((configPR>>4)&0x1)? "off":"on");
  39. len += sprintf(&page[len]," 3: %11i, %8i, %1i, %s\n",
  40. read_c0_count3(), read_c0_compare3(),
  41. (configPR>>8)&0x1, ((configPR>>5)&0x1)? "off":"on");
  42. }
  43. return len;
  44. }
  45. static int pnx8550_registers_read (char* page, char** start, off_t offset, int count, int* eof, void* data)
  46. {
  47. int len = 0;
  48. if (offset==0) {
  49. len += sprintf(&page[len],"config1: %#10.8x\n",read_c0_config1());
  50. len += sprintf(&page[len],"config2: %#10.8x\n",read_c0_config2());
  51. len += sprintf(&page[len],"config3: %#10.8x\n",read_c0_config3());
  52. len += sprintf(&page[len],"configPR: %#10.8x\n",read_c0_config7());
  53. len += sprintf(&page[len],"status: %#10.8x\n",read_c0_status());
  54. len += sprintf(&page[len],"cause: %#10.8x\n",read_c0_cause());
  55. len += sprintf(&page[len],"count: %#10.8x\n",read_c0_count());
  56. len += sprintf(&page[len],"count_2: %#10.8x\n",read_c0_count2());
  57. len += sprintf(&page[len],"count_3: %#10.8x\n",read_c0_count3());
  58. len += sprintf(&page[len],"compare: %#10.8x\n",read_c0_compare());
  59. len += sprintf(&page[len],"compare_2: %#10.8x\n",read_c0_compare2());
  60. len += sprintf(&page[len],"compare_3: %#10.8x\n",read_c0_compare3());
  61. }
  62. return len;
  63. }
  64. static struct proc_dir_entry* pnx8550_dir = NULL;
  65. static struct proc_dir_entry* pnx8550_timers = NULL;
  66. static struct proc_dir_entry* pnx8550_registers = NULL;
  67. static int pnx8550_proc_init( void )
  68. {
  69. // Create /proc/pnx8550
  70. pnx8550_dir = create_proc_entry("pnx8550", S_IFDIR|S_IRUGO, NULL);
  71. if (pnx8550_dir){
  72. pnx8550_dir->nlink = 1;
  73. }
  74. else {
  75. printk(KERN_ERR "Can't create pnx8550 proc dir\n");
  76. return -1;
  77. }
  78. // Create /proc/pnx8550/timers
  79. pnx8550_timers = create_proc_entry("timers", S_IFREG|S_IRUGO, pnx8550_dir );
  80. if (pnx8550_timers){
  81. pnx8550_timers->nlink = 1;
  82. pnx8550_timers->read_proc = pnx8550_timers_read;
  83. }
  84. else {
  85. printk(KERN_ERR "Can't create pnx8550 timers proc file\n");
  86. }
  87. // Create /proc/pnx8550/registers
  88. pnx8550_registers = create_proc_entry("registers", S_IFREG|S_IRUGO, pnx8550_dir );
  89. if (pnx8550_registers){
  90. pnx8550_registers->nlink = 1;
  91. pnx8550_registers->read_proc = pnx8550_registers_read;
  92. }
  93. else {
  94. printk(KERN_ERR "Can't create pnx8550 registers proc file\n");
  95. }
  96. return 0;
  97. }
  98. __initcall(pnx8550_proc_init);