pstore_ram.h 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /*
  2. * Copyright (C) 2010 Marco Stornelli <marco.stornelli@gmail.com>
  3. * Copyright (C) 2011 Kees Cook <keescook@chromium.org>
  4. * Copyright (C) 2011 Google, Inc.
  5. *
  6. * This software is licensed under the terms of the GNU General Public
  7. * License version 2, as published by the Free Software Foundation, and
  8. * may be copied, distributed, and modified under those terms.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. */
  16. #ifndef __LINUX_PSTORE_RAM_H__
  17. #define __LINUX_PSTORE_RAM_H__
  18. #include <linux/device.h>
  19. #include <linux/kernel.h>
  20. #include <linux/list.h>
  21. #include <linux/types.h>
  22. #include <linux/init.h>
  23. /*
  24. * Choose whether access to the RAM zone requires locking or not. If a zone
  25. * can be written to from different CPUs like with ftrace for example, then
  26. * PRZ_FLAG_NO_LOCK is used. For all other cases, locking is required.
  27. */
  28. #define PRZ_FLAG_NO_LOCK BIT(0)
  29. struct persistent_ram_buffer;
  30. struct rs_control;
  31. struct persistent_ram_ecc_info {
  32. int block_size;
  33. int ecc_size;
  34. int symsize;
  35. int poly;
  36. };
  37. struct persistent_ram_zone {
  38. phys_addr_t paddr;
  39. size_t size;
  40. void *vaddr;
  41. struct persistent_ram_buffer *buffer;
  42. size_t buffer_size;
  43. u32 flags;
  44. raw_spinlock_t buffer_lock;
  45. /* ECC correction */
  46. char *par_buffer;
  47. char *par_header;
  48. struct rs_control *rs_decoder;
  49. int corrected_bytes;
  50. int bad_blocks;
  51. struct persistent_ram_ecc_info ecc_info;
  52. char *old_log;
  53. size_t old_log_size;
  54. };
  55. struct persistent_ram_zone *persistent_ram_new(phys_addr_t start, size_t size,
  56. u32 sig, struct persistent_ram_ecc_info *ecc_info,
  57. unsigned int memtype, u32 flags);
  58. void persistent_ram_free(struct persistent_ram_zone *prz);
  59. void persistent_ram_zap(struct persistent_ram_zone *prz);
  60. int persistent_ram_write(struct persistent_ram_zone *prz, const void *s,
  61. unsigned int count);
  62. void persistent_ram_save_old(struct persistent_ram_zone *prz);
  63. size_t persistent_ram_old_size(struct persistent_ram_zone *prz);
  64. void *persistent_ram_old(struct persistent_ram_zone *prz);
  65. void persistent_ram_free_old(struct persistent_ram_zone *prz);
  66. ssize_t persistent_ram_ecc_string(struct persistent_ram_zone *prz,
  67. char *str, size_t len);
  68. /*
  69. * Ramoops platform data
  70. * @mem_size memory size for ramoops
  71. * @mem_address physical memory address to contain ramoops
  72. */
  73. struct ramoops_platform_data {
  74. unsigned long mem_size;
  75. unsigned long mem_address;
  76. unsigned int mem_type;
  77. unsigned long record_size;
  78. unsigned long console_size;
  79. unsigned long ftrace_size;
  80. unsigned long pmsg_size;
  81. int dump_oops;
  82. struct persistent_ram_ecc_info ecc_info;
  83. };
  84. #endif