9d9d2b8adf92cd30f5bf7c551f6600253f3afa76
[bbaumbach/samba-autobuild/.git] / source4 / lib / tdr / tdr.h
1 /* 
2    Unix SMB/CIFS implementation.
3    TDR definitions
4    Copyright (C) Jelmer Vernooij 2005
5    
6    This program is free software; you can redistribute it and/or modify
7    it under the terms of the GNU General Public License as published by
8    the Free Software Foundation; either version 2 of the License, or
9    (at your option) any later version.
10    
11    This program is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14    GNU General Public License for more details.
15    
16    You should have received a copy of the GNU General Public License
17    along with this program; if not, write to the Free Software
18    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 */
20
21 #define TDR_BIG_ENDIAN                  0x01
22 #define TDR_ALIGN2                      0x02
23 #define TDR_ALIGN4                      0x04
24 #define TDR_ALIGN8                      0x08
25 #define TDR_REMAINING                   0x10
26
27 struct tdr_pull {
28         DATA_BLOB data;
29         uint32_t offset;
30         int flags;
31 };
32
33 struct tdr_push {
34         DATA_BLOB data;
35         uint32_t offset;
36         int flags;
37 };
38
39 struct tdr_print {
40         int level;
41         void (*print)(struct tdr_print *, const char *, ...);
42         int flags;
43 };
44
45 #define TDR_CHECK(call) do { NTSTATUS _status; \
46                              _status = call; \
47                              if (!NT_STATUS_IS_OK(_status)) \
48                                 return _status; \
49                         } while (0)
50
51 #define TDR_ALLOC(tdr, s, n) do { \
52                                (s) = talloc_array_size(tdr, sizeof(*(s)), n); \
53                            if ((n) && !(s)) return NT_STATUS_NO_MEMORY; \
54                            } while (0)