ocfs2_lockid.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /* -*- mode: c; c-basic-offset: 8; -*-
  2. * vim: noexpandtab sw=8 ts=8 sts=0:
  3. *
  4. * ocfs2_lockid.h
  5. *
  6. * Defines OCFS2 lockid bits.
  7. *
  8. * Copyright (C) 2002, 2005 Oracle. All rights reserved.
  9. *
  10. * This program is free software; you can redistribute it and/or
  11. * modify it under the terms of the GNU General Public
  12. * License as published by the Free Software Foundation; either
  13. * version 2 of the License, or (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  18. * General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU General Public
  21. * License along with this program; if not, write to the
  22. * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
  23. * Boston, MA 021110-1307, USA.
  24. */
  25. #ifndef OCFS2_LOCKID_H
  26. #define OCFS2_LOCKID_H
  27. /* lock ids are made up in the following manner:
  28. * name[0] --> type
  29. * name[1-6] --> 6 pad characters, reserved for now
  30. * name[7-22] --> block number, expressed in hex as 16 chars
  31. * name[23-30] --> i_generation, expressed in hex 8 chars
  32. * name[31] --> '\0' */
  33. #define OCFS2_LOCK_ID_MAX_LEN 32
  34. #define OCFS2_LOCK_ID_PAD "000000"
  35. #define OCFS2_DENTRY_LOCK_INO_START 18
  36. enum ocfs2_lock_type {
  37. OCFS2_LOCK_TYPE_META = 0,
  38. OCFS2_LOCK_TYPE_DATA,
  39. OCFS2_LOCK_TYPE_SUPER,
  40. OCFS2_LOCK_TYPE_RENAME,
  41. OCFS2_LOCK_TYPE_RW,
  42. OCFS2_LOCK_TYPE_DENTRY,
  43. OCFS2_LOCK_TYPE_OPEN,
  44. OCFS2_NUM_LOCK_TYPES
  45. };
  46. static inline char ocfs2_lock_type_char(enum ocfs2_lock_type type)
  47. {
  48. char c;
  49. switch (type) {
  50. case OCFS2_LOCK_TYPE_META:
  51. c = 'M';
  52. break;
  53. case OCFS2_LOCK_TYPE_DATA:
  54. c = 'D';
  55. break;
  56. case OCFS2_LOCK_TYPE_SUPER:
  57. c = 'S';
  58. break;
  59. case OCFS2_LOCK_TYPE_RENAME:
  60. c = 'R';
  61. break;
  62. case OCFS2_LOCK_TYPE_RW:
  63. c = 'W';
  64. break;
  65. case OCFS2_LOCK_TYPE_DENTRY:
  66. c = 'N';
  67. break;
  68. case OCFS2_LOCK_TYPE_OPEN:
  69. c = 'O';
  70. break;
  71. default:
  72. c = '\0';
  73. }
  74. return c;
  75. }
  76. static char *ocfs2_lock_type_strings[] = {
  77. [OCFS2_LOCK_TYPE_META] = "Meta",
  78. [OCFS2_LOCK_TYPE_DATA] = "Data",
  79. [OCFS2_LOCK_TYPE_SUPER] = "Super",
  80. [OCFS2_LOCK_TYPE_RENAME] = "Rename",
  81. /* Need to differntiate from [R]ename.. serializing writes is the
  82. * important job it does, anyway. */
  83. [OCFS2_LOCK_TYPE_RW] = "Write/Read",
  84. [OCFS2_LOCK_TYPE_DENTRY] = "Dentry",
  85. [OCFS2_LOCK_TYPE_OPEN] = "Open",
  86. };
  87. static inline const char *ocfs2_lock_type_string(enum ocfs2_lock_type type)
  88. {
  89. #ifdef __KERNEL__
  90. mlog_bug_on_msg(type >= OCFS2_NUM_LOCK_TYPES, "%d\n", type);
  91. #endif
  92. return ocfs2_lock_type_strings[type];
  93. }
  94. #endif /* OCFS2_LOCKID_H */