udf_sb.h
上传用户:light_show
上传日期:2007-01-06
资源大小:218k
文件大小:3k
源码类别:

SCSI/ASPI

开发平台:

Unix_Linux

  1. #ifndef __LINUX_UDF_SB_H
  2. #define __LINUX_UDF_SB_H
  3. /* Since UDF 1.50 is ISO 13346 based... */
  4. #define UDF_SUPER_MAGIC 0x15013346
  5. #define UDF_FLAG_STRICT 0x00000001U
  6. #define UDF_FLAG_UNDELETE 0x00000002U
  7. #define UDF_FLAG_UNHIDE 0x00000004U
  8. #define UDF_FLAG_VARCONV 0x00000008U
  9. /* following is set only when compiling outside kernel tree */
  10. #ifndef CONFIG_UDF_FS_EXT
  11. #define UDF_SB_ALLOC(X)
  12. #define UDF_SB_FREE(X)
  13. {
  14. if (UDF_SB(X))
  15. {
  16. if (UDF_SB_PARTMAPS(X))
  17. kfree(UDF_SB_PARTMAPS(X));
  18. UDF_SB_PARTMAPS(X) = NULL;
  19. }
  20. }
  21. #define UDF_SB(X) (&((X)->u.udf_sb))
  22. #else
  23. /* else we kmalloc a page to hold our stuff */
  24. #define UDF_SB_ALLOC(X)
  25. (UDF_SB(X) = kmalloc(sizeof(struct udf_sb_info), GFP_KERNEL))
  26. #define UDF_SB_FREE(X)
  27. {
  28. if (UDF_SB(X))
  29. {
  30. if (UDF_SB_PARTMAPS(X))
  31. kfree(UDF_SB_PARTMAPS(X));
  32. kfree(UDF_SB(X));
  33. UDF_SB(X) = NULL;
  34. }
  35. }
  36. #define UDF_SB(X) ((struct udf_sb_info *) ((X)->u.generic_sbp))
  37. #endif
  38. #define UDF_SB_ALLOC_PARTMAPS(X,Y)
  39. {
  40. UDF_SB_NUMPARTS(X) = Y;
  41. UDF_SB_PARTMAPS(X) = kmalloc(sizeof(struct udf_part_map) * Y, GFP_KERNEL);
  42. memset(UDF_SB_PARTMAPS(X), 0x00, sizeof(struct udf_part_map) * Y);
  43. }
  44. #if LINUX_VERSION_CODE < KERNEL_VERSION(2,2,6)
  45. #define UDF_SB_RENAME_LOCK(X) ( UDF_SB(X)->s_rename_lock )
  46. #define UDF_SB_RENAME_WAIT(X) ( UDF_SB(X)->s_rename_wait )
  47. #endif
  48. #define IS_STRICT(X) ( UDF_SB(X)->s_flags & UDF_FLAG_STRICT )
  49. #define IS_UNDELETE(X) ( UDF_SB(X)->s_flags & UDF_FLAG_UNDELETE )
  50. #define IS_UNHIDE(X) ( UDF_SB(X)->s_flags & UDF_FLAG_UNHIDE )
  51. #define UDF_SB_SESSION(X) ( UDF_SB(X)->s_session )
  52. #define UDF_SB_ANCHOR(X) ( UDF_SB(X)->s_anchor )
  53. #define UDF_SB_NUMPARTS(X) ( UDF_SB(X)->s_partitions )
  54. #define UDF_SB_VOLUME(X) ( UDF_SB(X)->s_thisvolume )
  55. #define UDF_SB_LASTBLOCK(X) ( UDF_SB(X)->s_lastblock )
  56. #define UDF_SB_VOLDESC(X) ( UDF_SB(X)->s_voldesc )
  57. #define UDF_SB_LVIDBH(X) ( UDF_SB(X)->s_lvidbh )
  58. #define UDF_SB_LVID(X) ( (struct LogicalVolIntegrityDesc *)UDF_SB_LVIDBH(X)->b_data )
  59. #define UDF_SB_LVIDIU(X) ( (struct LogicalVolIntegrityDescImpUse *)&(UDF_SB_LVID(sb)->impUse[UDF_SB_LVID(sb)->numOfPartitions * 2 * sizeof(Uint32)/sizeof(Uint8)]) )
  60. #define UDF_SB_PARTITION(X) ( UDF_SB(X)->s_partition )
  61. #define UDF_SB_RECORDTIME(X) ( UDF_SB(X)->s_recordtime )
  62. #define UDF_SB_VOLIDENT(X) ( UDF_SB(X)->s_volident )
  63. #define UDF_SB_PARTMAPS(X) ( UDF_SB(X)->s_partmaps )
  64. #define UDF_SB_SERIALNUM(X) ( UDF_SB(X)->s_serialnum )
  65. #define UDF_SB_VAT(X) ( UDF_SB(X)->s_vat )
  66. #define UDF_SB_BLOCK_BITMAP_NUMBER(X,Y) ( UDF_SB(X)->s_block_bitmap_number[Y] )
  67. #define UDF_SB_BLOCK_BITMAP(X,Y) ( UDF_SB(X)->s_block_bitmap[Y] )
  68. #define UDF_SB_LOADED_BLOCK_BITMAPS(X) ( UDF_SB(X)->s_loaded_block_bitmaps )
  69. #define UDF_SB_PARTTYPE(X,Y) ( UDF_SB_PARTMAPS(X)[Y].s_partition_type )
  70. #define UDF_SB_PARTROOT(X,Y) ( UDF_SB_PARTMAPS(X)[Y].s_partition_root )
  71. #define UDF_SB_PARTLEN(X,Y) ( UDF_SB_PARTMAPS(X)[Y].s_partition_len )
  72. #define UDF_SB_PARTVSN(X,Y) ( UDF_SB_PARTMAPS(X)[Y].s_volumeseqnum )
  73. #define UDF_SB_PARTNUM(X,Y) ( UDF_SB_PARTMAPS(X)[Y].s_partition_num )
  74. #define UDF_SB_TYPESPAR(X,Y) ( UDF_SB_PARTMAPS(X)[Y].s_type_specific.s_sparing )
  75. #define UDF_SB_TYPEVIRT(X,Y) ( UDF_SB_PARTMAPS(X)[Y].s_type_specific.s_virtual )
  76. #define UDF_SB_PARTFUNC(X,Y) ( UDF_SB_PARTMAPS(X)[Y].s_partition_func )
  77. #endif /* __LINUX_UDF_SB_H */