xref: /haiku/src/add-ons/kernel/file_systems/nfs4/NFS4Defs.h (revision ceed5fe0762ad5e37c023e420f46c913e46f022e)
14aeb5952SPawel Dziepak /*
24aeb5952SPawel Dziepak  * Copyright 2012 Haiku, Inc. All rights reserved.
34aeb5952SPawel Dziepak  * Distributed under the terms of the MIT License.
44aeb5952SPawel Dziepak  *
54aeb5952SPawel Dziepak  * Authors:
64aeb5952SPawel Dziepak  *		Paweł Dziepak, pdziepak@quarnos.org
74aeb5952SPawel Dziepak  */
84aeb5952SPawel Dziepak #ifndef NFS4DEFS_H
94aeb5952SPawel Dziepak #define NFS4DEFS_H
104aeb5952SPawel Dziepak 
114aeb5952SPawel Dziepak 
127d0b8c97SPawel Dziepak #include <fcntl.h>
13d38e98d8SPawel Dziepak #include <sys/stat.h>
14d38e98d8SPawel Dziepak 
1545aa18acSPawel Dziepak #include <SupportDefs.h>
1645aa18acSPawel Dziepak 
177bfa4fe8SPawel Dziepak #include "Filehandle.h"
18196403c9SPawel Dziepak 
194aeb5952SPawel Dziepak enum Procedure {
204aeb5952SPawel Dziepak 	ProcNull		= 0,
214aeb5952SPawel Dziepak 	ProcCompound	= 1
224aeb5952SPawel Dziepak };
234aeb5952SPawel Dziepak 
244aeb5952SPawel Dziepak enum Opcode {
254aeb5952SPawel Dziepak 	OpAccess				= 3,
2660a8140dSPawel Dziepak 	OpClose					= 4,
27f5baf2efSPawel Dziepak 	OpCreate				= 6,
284aeb5952SPawel Dziepak 	OpGetAttr				= 9,
294aeb5952SPawel Dziepak 	OpGetFH					= 10,
30c0de7acaSPawel Dziepak 	OpLink					= 11,
317d0b8c97SPawel Dziepak 	OpLock					= 12,
327d0b8c97SPawel Dziepak 	OpLockT					= 13,
337d0b8c97SPawel Dziepak 	OpLockU					= 14,
344aeb5952SPawel Dziepak 	OpLookUp				= 15,
357bfa4fe8SPawel Dziepak 	OpLookUpUp				= 16,
3697378968SPawel Dziepak 	OpNverify				= 17,
372a292557SPawel Dziepak 	OpOpen					= 18,
382a292557SPawel Dziepak 	OpOpenConfirm			= 20,
39bf31ee39SPawel Dziepak 	OpPutFH					= 22,
404b48348fSPawel Dziepak 	OpPutRootFH				= 24,
412f2e57d0SPawel Dziepak 	OpRead					= 25,
422a292557SPawel Dziepak 	OpReadDir				= 26,
43f2da914dSPawel Dziepak 	OpReadLink				= 27,
446fb3845bSPawel Dziepak 	OpRemove				= 28,
451ec6b0c1SPawel Dziepak 	OpRename				= 29,
4627a291deSPawel Dziepak 	OpRenew					= 30,
471ec6b0c1SPawel Dziepak 	OpSaveFH				= 32,
48abba2fddSPawel Dziepak 	OpSetAttr				= 34,
492a292557SPawel Dziepak 	OpSetClientID			= 35,
50cf511f24SPawel Dziepak 	OpSetClientIDConfirm	= 36,
51e36a5442SPawel Dziepak 	OpVerify				= 37,
52e36a5442SPawel Dziepak 	OpWrite					= 38
534aeb5952SPawel Dziepak };
544aeb5952SPawel Dziepak 
554aeb5952SPawel Dziepak enum Access {
564aeb5952SPawel Dziepak 	ACCESS4_READ		= 0x00000001,
574aeb5952SPawel Dziepak 	ACCESS4_LOOKUP		= 0x00000002,
584aeb5952SPawel Dziepak 	ACCESS4_MODIFY		= 0x00000004,
594aeb5952SPawel Dziepak 	ACCESS4_EXTEND		= 0x00000008,
604aeb5952SPawel Dziepak 	ACCESS4_DELETE		= 0x00000010,
614aeb5952SPawel Dziepak 	ACCESS4_EXECUTE		= 0x00000020
624aeb5952SPawel Dziepak };
634aeb5952SPawel Dziepak 
644aeb5952SPawel Dziepak enum Attribute {
654aeb5952SPawel Dziepak 	// Mandatory Attributes
664aeb5952SPawel Dziepak 	FATTR4_SUPPORTED_ATTRS		= 0,
674aeb5952SPawel Dziepak 	FATTR4_TYPE					= 1,
684aeb5952SPawel Dziepak 	FATTR4_FH_EXPIRE_TYPE		= 2,
694aeb5952SPawel Dziepak 	FATTR4_CHANGE				= 3,
704aeb5952SPawel Dziepak 	FATTR4_SIZE					= 4,
714aeb5952SPawel Dziepak 	FATTR4_LINK_SUPPORT			= 5,
724aeb5952SPawel Dziepak 	FATTR4_SYMLINK_SUPPORT		= 6,
734aeb5952SPawel Dziepak 	FATTR4_NAMED_ATTR			= 7,
744aeb5952SPawel Dziepak 	FATTR4_FSID					= 8,
754aeb5952SPawel Dziepak 	FATTR4_UNIQUE_HANDLES		= 9,
764aeb5952SPawel Dziepak 	FATTR4_LEASE_TIME			= 10,
774aeb5952SPawel Dziepak 	FATTR4_RDATTR_ERROR			= 11,
784aeb5952SPawel Dziepak 	FATTR4_FILEHANDLE			= 19,
794aeb5952SPawel Dziepak 
804aeb5952SPawel Dziepak 	// Recommended Attributes
814aeb5952SPawel Dziepak 	FATTR4_ACL					= 12,
824aeb5952SPawel Dziepak 	FATTR4_ACLSUPPORT			= 13,
834aeb5952SPawel Dziepak 	FATTR4_ARCHIVE				= 14,
844aeb5952SPawel Dziepak 	FATTR4_CANSETTIME			= 15,
854aeb5952SPawel Dziepak 	FATTR4_CASE_INSENSITIVE		= 16,
864aeb5952SPawel Dziepak 	FATTR4_CASE_PRESERVING		= 17,
874aeb5952SPawel Dziepak 	FATTR4_CHOWN_RESTRICTED		= 18,
884aeb5952SPawel Dziepak 	FATTR4_FILEID				= 20,
894aeb5952SPawel Dziepak 	FATTR4_FILES_AVAIL			= 21,
904aeb5952SPawel Dziepak 	FATTR4_FILES_FREE			= 22,
914aeb5952SPawel Dziepak 	FATTR4_FILES_TOTAL			= 23,
924aeb5952SPawel Dziepak 	FATTR4_FS_LOCATIONS			= 24,
934aeb5952SPawel Dziepak 	FATTR4_HIDDEN				= 25,
944aeb5952SPawel Dziepak 	FATTR4_HOMOGENEOUS			= 26,
954aeb5952SPawel Dziepak 	FATTR4_MAXFILESIZE			= 27,
964aeb5952SPawel Dziepak 	FATTR4_MAXLINK				= 28,
974aeb5952SPawel Dziepak 	FATTR4_MAXNAME				= 29,
984aeb5952SPawel Dziepak 	FATTR4_MAXREAD				= 30,
994aeb5952SPawel Dziepak 	FATTR4_MAXWRITE				= 31,
1004aeb5952SPawel Dziepak 	FATTR4_MIMETYPE				= 32,
1014aeb5952SPawel Dziepak 	FATTR4_MODE					= 33,
1024aeb5952SPawel Dziepak 	FATTR4_NO_TRUNC				= 34,
1034aeb5952SPawel Dziepak 	FATTR4_NUMLINKS				= 35,
1044aeb5952SPawel Dziepak 	FATTR4_OWNER				= 36,
1054aeb5952SPawel Dziepak 	FATTR4_OWNER_GROUP			= 37,
1064aeb5952SPawel Dziepak 	FATTR4_QUOTA_AVAIL_HARD		= 38,
1074aeb5952SPawel Dziepak 	FATTR4_QUOTA_AVAIL_SOFT		= 39,
1084aeb5952SPawel Dziepak 	FATTR4_QUOTA_USED			= 40,
1094aeb5952SPawel Dziepak 	FATTR4_RAWDEV				= 41,
1104aeb5952SPawel Dziepak 	FATTR4_SPACE_AVAIL			= 42,
1114aeb5952SPawel Dziepak 	FATTR4_SPACE_FREE			= 43,
1124aeb5952SPawel Dziepak 	FATTR4_SPACE_TOTAL			= 44,
1134aeb5952SPawel Dziepak 	FATTR4_SPACE_USED			= 45,
1144aeb5952SPawel Dziepak 	FATTR4_SYSTEM				= 46,
1154aeb5952SPawel Dziepak 	FATTR4_TIME_ACCESS			= 47,
1164aeb5952SPawel Dziepak 	FATTR4_TIME_ACCESS_SET		= 48,
1174aeb5952SPawel Dziepak 	FATTR4_TIME_BACKUP			= 49,
1184aeb5952SPawel Dziepak 	FATTR4_TIME_CREATE			= 50,
1194aeb5952SPawel Dziepak 	FATTR4_TIME_DELTA			= 51,
1204aeb5952SPawel Dziepak 	FATTR4_TIME_METADATA		= 52,
1214aeb5952SPawel Dziepak 	FATTR4_TIME_MODIFY			= 53,
1224aeb5952SPawel Dziepak 	FATTR4_TIME_MODIFY_SET		= 54,
123f29ac4afSPawel Dziepak 	FATTR4_MOUNTED_ON_FILEID	= 55,
124f29ac4afSPawel Dziepak 	FATTR4_MAXIMUM_ATTR_ID
1254aeb5952SPawel Dziepak };
1264aeb5952SPawel Dziepak 
127f7bf941aSPawel Dziepak 
128f7bf941aSPawel Dziepak static inline bool sIsAttrSet(Attribute attr, const uint32* bitmap,
129f7bf941aSPawel Dziepak 	uint32 count)
130f7bf941aSPawel Dziepak {
131f7bf941aSPawel Dziepak 	if ((uint32)attr / 32 >= count)
132f7bf941aSPawel Dziepak 		return false;
133f7bf941aSPawel Dziepak 
134f7bf941aSPawel Dziepak 	return (bitmap[attr / 32] & 1 << attr % 32) != 0;
135f7bf941aSPawel Dziepak }
136f7bf941aSPawel Dziepak 
137f7bf941aSPawel Dziepak 
138d38e98d8SPawel Dziepak enum FileType {
139d38e98d8SPawel Dziepak 	NF4REG			= 1,    /* Regular File */
140d38e98d8SPawel Dziepak 	NF4DIR			= 2,    /* Directory */
141d38e98d8SPawel Dziepak 	NF4BLK			= 3,    /* Special File - block device */
142d38e98d8SPawel Dziepak 	NF4CHR			= 4,    /* Special File - character device */
143d38e98d8SPawel Dziepak 	NF4LNK			= 5,    /* Symbolic Link */
144d38e98d8SPawel Dziepak 	NF4SOCK			= 6,    /* Special File - socket */
145d38e98d8SPawel Dziepak 	NF4FIFO			= 7,    /* Special File - fifo */
146d38e98d8SPawel Dziepak 	NF4ATTRDIR		= 8,    /* Attribute Directory */
147d38e98d8SPawel Dziepak 	NF4NAMEDATTR	= 9     /* Named Attribute */
148d38e98d8SPawel Dziepak };
149d38e98d8SPawel Dziepak 
150d38e98d8SPawel Dziepak static const mode_t sNFSFileTypeToHaiku[] = {
151212de720SPawel Dziepak 	S_IFREG, S_IFREG, S_IFDIR, S_IFBLK, S_IFCHR, S_IFLNK, S_IFSOCK, S_IFIFO,
152212de720SPawel Dziepak 	S_IFDIR, S_IFREG
153d38e98d8SPawel Dziepak };
154d38e98d8SPawel Dziepak 
1554aeb5952SPawel Dziepak enum FileHandleExpiryType {
1564aeb5952SPawel Dziepak 	FH4_PERSISTENT			= 0x00,
1574aeb5952SPawel Dziepak 	FH4_NOEXPIRE_WITH_OPEN	= 0x01,
1584aeb5952SPawel Dziepak 	FH4_VOLATILE_ANY		= 0x02,
1594aeb5952SPawel Dziepak 	FH4_VOL_MIGRATION		= 0x04,
1604aeb5952SPawel Dziepak 	FH4_VOL_RENAME			= 0x08
1614aeb5952SPawel Dziepak };
1624aeb5952SPawel Dziepak 
1632a292557SPawel Dziepak enum OpenAccess {
1642a292557SPawel Dziepak 	OPEN4_SHARE_ACCESS_READ		= 1,
16520bd3ee1SPawel Dziepak 	OPEN4_SHARE_ACCESS_WRITE	= 2,
16620bd3ee1SPawel Dziepak 	OPEN4_SHARE_ACCESS_BOTH		= 3
1672a292557SPawel Dziepak };
1682a292557SPawel Dziepak 
1696ebe67d0SPawel Dziepak 
1706ebe67d0SPawel Dziepak static inline OpenAccess
1716ebe67d0SPawel Dziepak sModeToAccess(int mode)
1726ebe67d0SPawel Dziepak {
1736ebe67d0SPawel Dziepak 	switch (mode & O_RWMASK) {
1746ebe67d0SPawel Dziepak 		case O_RDONLY:
1756ebe67d0SPawel Dziepak 			return OPEN4_SHARE_ACCESS_READ;
1766ebe67d0SPawel Dziepak 		case O_WRONLY:
1776ebe67d0SPawel Dziepak 			return OPEN4_SHARE_ACCESS_WRITE;
1786ebe67d0SPawel Dziepak 		case O_RDWR:
1796ebe67d0SPawel Dziepak 			return OPEN4_SHARE_ACCESS_BOTH;
1806ebe67d0SPawel Dziepak 	}
1816ebe67d0SPawel Dziepak 
1826ebe67d0SPawel Dziepak 	return OPEN4_SHARE_ACCESS_READ;
1836ebe67d0SPawel Dziepak }
1846ebe67d0SPawel Dziepak 
1856ebe67d0SPawel Dziepak 
1862a292557SPawel Dziepak enum OpenCreate {
1872a292557SPawel Dziepak 	OPEN4_NOCREATE			= 0,
1882a292557SPawel Dziepak 	OPEN4_CREATE			= 1
1892a292557SPawel Dziepak };
1902a292557SPawel Dziepak 
19120bd3ee1SPawel Dziepak enum OpenCreateHow {
19220bd3ee1SPawel Dziepak 	UNCHECKED4				= 0,
19320bd3ee1SPawel Dziepak 	GUARDED4				= 1,
19420bd3ee1SPawel Dziepak 	EXCLUSIVE4				= 2
19520bd3ee1SPawel Dziepak };
19620bd3ee1SPawel Dziepak 
197d1e6b61eSPawel Dziepak enum OpenClaim {
198d1e6b61eSPawel Dziepak 	CLAIM_NULL				= 0,
199d1e6b61eSPawel Dziepak 	CLAIM_PREVIOUS			= 1,
200d1e6b61eSPawel Dziepak 	CLAIM_DELEGATE_CUR		= 2,
201d1e6b61eSPawel Dziepak 	CLAIM_DELEGATE_PREV		= 3
202d1e6b61eSPawel Dziepak };
203d1e6b61eSPawel Dziepak 
2042a292557SPawel Dziepak enum OpenFlags {
2052a292557SPawel Dziepak 	OPEN4_RESULT_CONFIRM		= 2,
2062a292557SPawel Dziepak 	OPEN4_RESULT_LOCKTYPE_POSIX	= 4
2072a292557SPawel Dziepak };
2082a292557SPawel Dziepak 
209e36a5442SPawel Dziepak enum WriteStable {
210e36a5442SPawel Dziepak 	UNSTABLE4				= 0,
211e36a5442SPawel Dziepak 	DATA_SYNC4				= 1,
212e36a5442SPawel Dziepak 	FILE_SYNC4				= 2
213e36a5442SPawel Dziepak };
214e36a5442SPawel Dziepak 
2157d0b8c97SPawel Dziepak enum LockType {
2167d0b8c97SPawel Dziepak 	READ_LT			= 1,
2177d0b8c97SPawel Dziepak 	WRITE_LT		= 2,
2187d0b8c97SPawel Dziepak 	READW_LT		= 3,
2197d0b8c97SPawel Dziepak 	WRITEW_LT		= 4
2207d0b8c97SPawel Dziepak };
2217d0b8c97SPawel Dziepak 
2227d0b8c97SPawel Dziepak 
2236ebe67d0SPawel Dziepak static inline LockType
2246ebe67d0SPawel Dziepak sGetLockType(short type, bool wait) {
2257d0b8c97SPawel Dziepak 	switch (type) {
2267d0b8c97SPawel Dziepak 		case F_RDLCK:	return wait ? READW_LT : READ_LT;
2277d0b8c97SPawel Dziepak 		case F_WRLCK:	return wait ? WRITEW_LT : WRITE_LT;
2287d0b8c97SPawel Dziepak 		default:		return READ_LT;
2297d0b8c97SPawel Dziepak 	}
2307d0b8c97SPawel Dziepak }
2317d0b8c97SPawel Dziepak 
2327d0b8c97SPawel Dziepak 
2336ebe67d0SPawel Dziepak static inline short
2346ebe67d0SPawel Dziepak sLockTypeToHaiku(LockType type) {
2357d0b8c97SPawel Dziepak 	switch (type) {
2367d0b8c97SPawel Dziepak 		case READ_LT:
2377d0b8c97SPawel Dziepak 		case READW_LT:
2387d0b8c97SPawel Dziepak 						return F_RDLCK;
2397d0b8c97SPawel Dziepak 
2407d0b8c97SPawel Dziepak 		case WRITE_LT:
2417d0b8c97SPawel Dziepak 		case WRITEW_LT:
2427d0b8c97SPawel Dziepak 						return F_WRLCK;
2437d0b8c97SPawel Dziepak 
2447d0b8c97SPawel Dziepak 		default:		return F_UNLCK;
2457d0b8c97SPawel Dziepak 	}
2467d0b8c97SPawel Dziepak }
2477d0b8c97SPawel Dziepak 
2487d0b8c97SPawel Dziepak 
2494aeb5952SPawel Dziepak enum Errors {
2504aeb5952SPawel Dziepak 	NFS4_OK						= 0,
2514aeb5952SPawel Dziepak 	NFS4ERR_PERM				= 1,
2524aeb5952SPawel Dziepak 	NFS4ERR_NOENT				= 2,
2534aeb5952SPawel Dziepak 	NFS4ERR_IO					= 5,
2544aeb5952SPawel Dziepak 	NFS4ERR_NXIO				= 6,
2554aeb5952SPawel Dziepak 	NFS4ERR_ACCESS				= 13,
2564aeb5952SPawel Dziepak 	NFS4ERR_EXIST				= 17,
2574aeb5952SPawel Dziepak 	NFS4ERR_XDEV				= 18,
2584aeb5952SPawel Dziepak 	NFS4ERR_NOTDIR				= 20,
2594aeb5952SPawel Dziepak 	NFS4ERR_ISDIR				= 21,
2604aeb5952SPawel Dziepak 	NFS4ERR_INVAL				= 22,
261b268b6f2SPawel Dziepak 	NFS4ERR_FBIG				= 27,
262b268b6f2SPawel Dziepak 	NFS4ERR_BADHANDLE			= 10001,
263b268b6f2SPawel Dziepak 	NFS4ERR_BAD_COOKIE			= 10003,
264b268b6f2SPawel Dziepak 	NFS4ERR_NOTSUPP				= 10004,
265b268b6f2SPawel Dziepak 	NFS4ERR_TOOSMALL			= 10005,
266b268b6f2SPawel Dziepak 	NFS4ERR_SERVERFAULT			= 10006,
267b268b6f2SPawel Dziepak 	NFS4ERR_BADTYPE				= 10007,
268b268b6f2SPawel Dziepak 	NFS4ERR_DELAY				= 10008,
269b268b6f2SPawel Dziepak 	NFS4ERR_SAME				= 10009,
270b268b6f2SPawel Dziepak 	NFS4ERR_DENIED				= 10010,
271b268b6f2SPawel Dziepak 	NFS4ERR_EXPIRED				= 10011,
272b268b6f2SPawel Dziepak 	NFS4ERR_LOCKED				= 10012,
273b268b6f2SPawel Dziepak 	NFS4ERR_GRACE				= 10013,
274b268b6f2SPawel Dziepak 	NFS4ERR_FHEXPIRED			= 10014,
275b268b6f2SPawel Dziepak 	NFS4ERR_SHARE_DENIED		= 10015,
276b268b6f2SPawel Dziepak 	NFS4ERR_WRONGSEC			= 10016,
277b268b6f2SPawel Dziepak 	NFS4ERR_CLID_INUSE			= 10017,
278b268b6f2SPawel Dziepak 	NFS4ERR_RESOURCE			= 10018,
279b268b6f2SPawel Dziepak 	NFS4ERR_MOVED				= 10019,
280b268b6f2SPawel Dziepak 	NFS4ERR_NOFILEHANDLE		= 10020,
281b268b6f2SPawel Dziepak 	NFS4ERR_MINOR_VERS_MISMATCH	= 10021,
282b268b6f2SPawel Dziepak 	NFS4ERR_STALE_CLIENTID		= 10022,
283b268b6f2SPawel Dziepak 	NFS4ERR_STALE_STATEID		= 10023,
284b268b6f2SPawel Dziepak 	NFS4ERR_OLD_STATEID			= 10024,
285b268b6f2SPawel Dziepak 	NFS4ERR_BAD_STATEID			= 10025,
286b268b6f2SPawel Dziepak 	NFS4ERR_BAD_SEQID			= 10026,
287b268b6f2SPawel Dziepak 	NFS4ERR_NOT_SAME			= 10027,
288b268b6f2SPawel Dziepak 	NFS4ERR_LOCK_RANGE			= 10028,
289b268b6f2SPawel Dziepak 	NFS4ERR_SYMLINK				= 10029,
290b268b6f2SPawel Dziepak 	NFS4ERR_RESTOREFH			= 10030,
291b268b6f2SPawel Dziepak 	NFS4ERR_LEASE_MOVED			= 10031,
292b268b6f2SPawel Dziepak 	NFS4ERR_ATTRNOTSUPP			= 10032,
293b268b6f2SPawel Dziepak 	NFS4ERR_NO_GRACE			= 10033,
294b268b6f2SPawel Dziepak 	NFS4ERR_RECLAIM_BAD			= 10034,
295b268b6f2SPawel Dziepak 	NFS4ERR_RECLAIM_CONFLICT	= 10035,
296b268b6f2SPawel Dziepak 	NFS4ERR_BADXDR				= 10036,
297b268b6f2SPawel Dziepak 	NFS4ERR_LOCKS_HELD			= 10037,
298b268b6f2SPawel Dziepak 	NFS4ERR_OPENMODE			= 10038,
299b268b6f2SPawel Dziepak 	NFS4ERR_BADOWNER			= 10039,
300b268b6f2SPawel Dziepak 	NFS4ERR_BADCHAR				= 10040,
301b268b6f2SPawel Dziepak 	NFS4ERR_BADNAME				= 10041,
302b268b6f2SPawel Dziepak 	NFS4ERR_BAD_RANGE			= 10042,
303b268b6f2SPawel Dziepak 	NFS4ERR_LOCK_NOTSUPP		= 10043,
304b268b6f2SPawel Dziepak 	NFS4ERR_OP_ILLEGAL			= 10044,
305b268b6f2SPawel Dziepak 	NFS4ERR_DEADLOCK			= 10045,
306b268b6f2SPawel Dziepak 	NFS4ERR_FILE_OPEN			= 10046,
307b268b6f2SPawel Dziepak 	NFS4ERR_ADMIN_REVOKED		= 10047,
308b268b6f2SPawel Dziepak 	NFS4ERR_CB_PATH_DOWN		= 10048
3094aeb5952SPawel Dziepak };
3104aeb5952SPawel Dziepak 
3114aeb5952SPawel Dziepak 
312*ceed5fe0SPawel Dziepak static inline bigtime_t
313*ceed5fe0SPawel Dziepak sSecToBigTime(uint32 sec)
314*ceed5fe0SPawel Dziepak {
315*ceed5fe0SPawel Dziepak 	return static_cast<bigtime_t>(sec) * 1000000;
316*ceed5fe0SPawel Dziepak }
317*ceed5fe0SPawel Dziepak 
318*ceed5fe0SPawel Dziepak 
3194aeb5952SPawel Dziepak #endif	// NFS4DEFS_H
3204aeb5952SPawel Dziepak 
321