ext4_trans.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. /*
  2. * Copyright (c) 2015 Grzegorz Kostka (kostka.grzegorz@gmail.com)
  3. * Copyright (c) 2015 Kaho Ng (ngkaho1234@gmail.com)
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. *
  9. * - Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. * - Redistributions in binary form must reproduce the above copyright
  12. * notice, this list of conditions and the following disclaimer in the
  13. * documentation and/or other materials provided with the distribution.
  14. * - The name of the author may not be used to endorse or promote products
  15. * derived from this software without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  18. * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  19. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  20. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  21. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  22. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  23. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  24. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  25. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  26. * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27. */
  28. /** @addtogroup lwext4
  29. * @{
  30. */
  31. /**
  32. * @file ext4_trans.h
  33. * @brief Transaction handle functions
  34. */
  35. #ifndef EXT4_TRANS_H
  36. #define EXT4_TRANS_H
  37. #ifdef __cplusplus
  38. extern "C" {
  39. #endif
  40. #include <ext4_config.h>
  41. #include <ext4_types.h>
  42. /**@brief Mark a buffer dirty and add it to the current transaction.
  43. * @param buf buffer
  44. * @return standard error code*/
  45. int ext4_trans_set_block_dirty(struct ext4_buf *buf);
  46. /**@brief Block get function (through cache, don't read).
  47. * jbd_trans_get_access would be called in order to
  48. * get write access to the buffer.
  49. * @param bdev block device descriptor
  50. * @param b block descriptor
  51. * @param lba logical block address
  52. * @return standard error code*/
  53. int ext4_trans_block_get_noread(struct ext4_blockdev *bdev,
  54. struct ext4_block *b,
  55. uint64_t lba);
  56. /**@brief Block get function (through cache).
  57. * jbd_trans_get_access would be called in order to
  58. * get write access to the buffer.
  59. * @param bdev block device descriptor
  60. * @param b block descriptor
  61. * @param lba logical block address
  62. * @return standard error code*/
  63. int ext4_trans_block_get(struct ext4_blockdev *bdev,
  64. struct ext4_block *b,
  65. uint64_t lba);
  66. /**@brief Try to add block to be revoked to the current transaction.
  67. * @param bdev block device descriptor
  68. * @param lba logical block address
  69. * @return standard error code*/
  70. int ext4_trans_try_revoke_block(struct ext4_blockdev *bdev,
  71. uint64_t lba);
  72. #ifdef __cplusplus
  73. }
  74. #endif
  75. #endif /* EXT4_TRANS_H */
  76. /**
  77. * @}
  78. */