types.h

来自「Linux Kernel 2.6.9 for OMAP1710」· C头文件 代码 · 共 95 行

H
95
字号
/* * types.h - Defines for NTFS Linux kernel driver specific types. *	     Part of the Linux-NTFS project. * * Copyright (c) 2001-2004 Anton Altaparmakov * * This program/include file is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as published * by the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program/include file is distributed in the hope that it will be * useful, but WITHOUT ANY WARRANTY; without even the implied warranty * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program (in the main directory of the Linux-NTFS * distribution in the file COPYING); if not, write to the Free Software * Foundation,Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */#ifndef _LINUX_NTFS_TYPES_H#define _LINUX_NTFS_TYPES_H#include <linux/types.h>typedef __le16 le16;typedef __le32 le32;typedef __le64 le64;typedef __u16 __bitwise sle16;typedef __u32 __bitwise sle32;typedef __u64 __bitwise sle64;/* 2-byte Unicode character type. */typedef le16 ntfschar;#define UCHAR_T_SIZE_BITS 1/* * Clusters are signed 64-bit values on NTFS volumes. We define two types, LCN * and VCN, to allow for type checking and better code readability. */typedef s64 VCN;typedef sle64 leVCN;typedef s64 LCN;typedef sle64 leLCN;/* * The NTFS journal $LogFile uses log sequence numbers which are signed 64-bit * values.  We define our own type LSN, to allow for type checking and better * code readability. */typedef s64 LSN;typedef sle64 leLSN;/** * runlist_element - in memory vcn to lcn mapping array element * @vcn:	starting vcn of the current array element * @lcn:	starting lcn of the current array element * @length:	length in clusters of the current array element * * The last vcn (in fact the last vcn + 1) is reached when length == 0. * * When lcn == -1 this means that the count vcns starting at vcn are not * physically allocated (i.e. this is a hole / data is sparse). */typedef struct {	/* In memory vcn to lcn mapping structure element. */	VCN vcn;	/* vcn = Starting virtual cluster number. */	LCN lcn;	/* lcn = Starting logical cluster number. */	s64 length;	/* Run length in clusters. */} runlist_element;/** * runlist - in memory vcn to lcn mapping array including a read/write lock * @rl:		pointer to an array of runlist elements * @lock:	read/write spinlock for serializing access to @rl * */typedef struct {	runlist_element *rl;	struct rw_semaphore lock;} runlist;typedef enum {	FALSE = 0,	TRUE = 1} BOOL;typedef enum {	CASE_SENSITIVE = 0,	IGNORE_CASE = 1,} IGNORE_CASE_BOOL;#endif /* _LINUX_NTFS_TYPES_H */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?