2003-10-30 08:32:26 +00:00
/*
Unix SMB / CIFS implementation .
rpc interface definitions
Copyright ( C ) Andrew Tridgell 2003
This program 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 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 ; if not , write to the Free Software
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
/*
this provides definitions for the libcli / rpc / MSRPC library
*/
2003-11-17 02:18:11 +00:00
/* offset lists are used to allow a push/pull function to find the
start of an encapsulating structure */
struct ndr_ofs_list {
uint32 offset ;
struct ndr_ofs_list * next ;
} ;
2003-10-30 08:32:26 +00:00
/* this is the base structure passed to routines that
parse MSRPC formatted data
note that in Samba4 we use separate routines and structures for
MSRPC marshalling and unmarshalling . Also note that these routines
are being kept deliberately very simple , and are not tied to a
particular transport
*/
2003-11-03 06:22:45 +00:00
struct ndr_pull {
2003-10-30 08:32:26 +00:00
uint32 flags ; /* LIBNDR_FLAG_* */
char * data ;
uint32 data_size ;
uint32 offset ;
TALLOC_CTX * mem_ctx ;
2003-11-17 02:18:11 +00:00
/* this points at a list of offsets to the structures being processed.
The first element in the list is the current structure */
struct ndr_ofs_list * ofs_list ;
2003-10-30 08:32:26 +00:00
} ;
2003-11-03 06:22:45 +00:00
struct ndr_pull_save {
2003-10-30 08:32:26 +00:00
uint32 data_size ;
uint32 offset ;
2003-11-17 02:18:11 +00:00
struct ndr_pull_save * next ;
2003-10-30 08:32:26 +00:00
} ;
2003-11-03 06:22:45 +00:00
/* structure passed to functions that generate NDR formatted data */
struct ndr_push {
uint32 flags ; /* LIBNDR_FLAG_* */
char * data ;
uint32 alloc_size ;
uint32 offset ;
TALLOC_CTX * mem_ctx ;
2003-11-16 11:36:59 +00:00
2003-11-17 02:18:11 +00:00
/* this points at a list of offsets to the structures being processed.
The first element in the list is the current structure */
struct ndr_ofs_list * ofs_list ;
2003-11-16 13:49:14 +00:00
/* this list is used by the [relative] code to find the offsets */
2003-11-17 02:18:11 +00:00
struct ndr_ofs_list * relative_list ;
2003-11-03 06:22:45 +00:00
} ;
2003-11-04 09:10:31 +00:00
struct ndr_push_save {
uint32 offset ;
2003-11-16 11:36:59 +00:00
struct ndr_push_save * next ;
2003-11-04 09:10:31 +00:00
} ;
2003-11-11 04:04:36 +00:00
/* structure passed to functions that print IDL structures */
struct ndr_print {
uint32 flags ; /* LIBNDR_FLAG_* */
TALLOC_CTX * mem_ctx ;
uint32 depth ;
void ( * print ) ( struct ndr_print * , const char * , . . . ) ;
2003-11-12 05:34:21 +00:00
void * private ;
2003-11-11 04:04:36 +00:00
} ;
2003-10-30 08:32:26 +00:00
# define LIBNDR_FLAG_BIGENDIAN 1
2003-11-11 04:04:36 +00:00
/* useful macro for debugging */
# define NDR_PRINT_DEBUG(type, p) ndr_print_debug((ndr_print_fn_t)ndr_print_ ##type, #p, p)
2003-11-11 04:38:51 +00:00
# define NDR_PRINT_UNION_DEBUG(type, level, p) ndr_print_union_debug((ndr_print_union_fn_t)ndr_print_ ##type, #p, level, p)
2003-11-17 11:55:56 +00:00
# define NDR_PRINT_FUNCTION_DEBUG(type, flags, p) ndr_print_function_debug((ndr_print_function_t)ndr_print_ ##type, #type, flags, p)
# define NDR_PRINT_BOTH_DEBUG(type, p) NDR_PRINT_FUNCTION_DEBUG(type, NDR_BOTH, p)
# define NDR_PRINT_OUT_DEBUG(type, p) NDR_PRINT_FUNCTION_DEBUG(type, NDR_OUT, p)
# define NDR_PRINT_IN_DEBUG(type, p) NDR_PRINT_FUNCTION_DEBUG(type, NDR_IN, p)
2003-11-11 04:04:36 +00:00
2003-11-13 09:26:53 +00:00
enum ndr_err_code {
NDR_ERR_CONFORMANT_SIZE ,
NDR_ERR_ARRAY_SIZE ,
2003-11-15 10:58:29 +00:00
NDR_ERR_BAD_SWITCH ,
NDR_ERR_OFFSET ,
2003-11-16 13:49:14 +00:00
NDR_ERR_RELATIVE ,
2003-11-16 11:36:59 +00:00
NDR_ERR_CHARCNV ,
2003-11-15 10:58:29 +00:00
NDR_ERR_LENGTH
2003-11-13 09:26:53 +00:00
} ;
2003-11-08 11:21:57 +00:00
/*
flags passed to control parse flow
*/
# define NDR_SCALARS 1
# define NDR_BUFFERS 2
2003-11-17 11:55:56 +00:00
/*
flags passed to ndr_print_ * ( )
*/
# define NDR_IN 1
# define NDR_OUT 2
# define NDR_BOTH 3
2003-11-15 04:42:48 +00:00
# define NDR_PULL_NEED_BYTES(ndr, n) do { \
if ( ( n ) > ndr - > data_size | | ndr - > offset + ( n ) > ndr - > data_size ) { \
return NT_STATUS_BUFFER_TOO_SMALL ; \
} \
} while ( 0 )
# define NDR_PULL_ALIGN(ndr, n) do { \
ndr - > offset = ( ndr - > offset + ( n - 1 ) ) & ~ ( n - 1 ) ; \
if ( ndr - > offset > = ndr - > data_size ) { \
return NT_STATUS_BUFFER_TOO_SMALL ; \
} \
} while ( 0 )
# define NDR_PUSH_NEED_BYTES(ndr, n) NDR_CHECK(ndr_push_expand(ndr, ndr->offset+(n)))
# define NDR_PUSH_ALIGN(ndr, n) do { \
uint32 _pad = ( ndr - > offset & ( n - 1 ) ) ; \
while ( _pad - - ) NDR_CHECK ( ndr_push_uint8 ( ndr , 0 ) ) ; \
} while ( 0 )
2003-10-30 08:32:26 +00:00
/* these are used to make the error checking on each element in libndr
less tedious , hopefully making the code more readable */
# define NDR_CHECK(call) do { NTSTATUS _status; \
_status = call ; \
if ( ! NT_STATUS_IS_OK ( _status ) ) \
return _status ; \
} while ( 0 )
2003-11-13 09:26:53 +00:00
# define NDR_ALLOC_SIZE(ndr, s, size) do { \
( s ) = talloc ( ndr - > mem_ctx , size ) ; \
2003-10-30 08:32:26 +00:00
if ( ! ( s ) ) return NT_STATUS_NO_MEMORY ; \
} while ( 0 )
2003-11-13 09:26:53 +00:00
# define NDR_ALLOC(ndr, s) NDR_ALLOC_SIZE(ndr, s, sizeof(*(s)))
2003-11-08 11:21:57 +00:00
# define NDR_ALLOC_N_SIZE(ndr, s, n, elsize) do { \
2003-10-30 08:32:26 +00:00
if ( ( n ) = = 0 ) { \
( s ) = NULL ; \
} else { \
2003-11-08 11:21:57 +00:00
( s ) = talloc ( ndr - > mem_ctx , ( n ) * elsize ) ; \
2003-10-30 08:32:26 +00:00
if ( ! ( s ) ) return NT_STATUS_NO_MEMORY ; \
} \
} while ( 0 )
2003-11-13 09:26:53 +00:00
2003-11-08 11:21:57 +00:00
# define NDR_ALLOC_N(ndr, s, n) NDR_ALLOC_N_SIZE(ndr, s, n, sizeof(*(s)))
2003-11-03 07:26:30 +00:00
2003-11-03 08:37:48 +00:00
/* these are used when generic fn pointers are needed for ndr push/pull fns */
typedef NTSTATUS ( * ndr_push_fn_t ) ( struct ndr_push * , void * ) ;
typedef NTSTATUS ( * ndr_pull_fn_t ) ( struct ndr_pull * , void * ) ;
2003-11-08 11:21:57 +00:00
typedef NTSTATUS ( * ndr_push_flags_fn_t ) ( struct ndr_push * , int ndr_flags , void * ) ;
2003-11-16 13:49:14 +00:00
typedef NTSTATUS ( * ndr_push_const_fn_t ) ( struct ndr_push * , int ndr_flags , const void * ) ;
2003-11-08 11:21:57 +00:00
typedef NTSTATUS ( * ndr_pull_flags_fn_t ) ( struct ndr_pull * , int ndr_flags , void * ) ;
2003-11-16 11:36:59 +00:00
typedef NTSTATUS ( * ndr_push_union_fn_t ) ( struct ndr_push * , int ndr_flags , uint16 , void * ) ;
typedef NTSTATUS ( * ndr_pull_union_fn_t ) ( struct ndr_pull * , int ndr_flags , uint16 * , void * ) ;
2003-11-11 04:04:36 +00:00
typedef void ( * ndr_print_fn_t ) ( struct ndr_print * , const char * , void * ) ;
2003-11-17 11:55:56 +00:00
typedef void ( * ndr_print_function_t ) ( struct ndr_print * , const char * , int , void * ) ;
2003-11-11 04:38:51 +00:00
typedef void ( * ndr_print_union_fn_t ) ( struct ndr_print * , const char * , uint16 , void * ) ;
2003-11-08 11:21:57 +00:00
2003-11-03 07:26:30 +00:00
/* now pull in the individual parsers */
2003-11-17 06:27:45 +00:00
# include "librpc/ndr/ndr_basic.h"
2003-11-06 12:34:04 +00:00
# include "librpc/ndr/ndr_sec.h"
# include "librpc/ndr/ndr_misc.h"
# include "librpc/ndr/ndr_echo.h"
# include "librpc/ndr/ndr_lsa.h"
2003-11-12 05:34:21 +00:00
# include "librpc/ndr/ndr_dfs.h"
2003-11-15 05:42:49 +00:00
# include "librpc/ndr/ndr_spoolss.h"
2003-11-16 11:36:59 +00:00
# include "librpc/ndr/ndr_spoolss_buf.h"
2003-11-15 06:00:21 +00:00
# include "librpc/ndr/ndr_samr.h"
2003-11-17 12:43:18 +00:00
# include "librpc/ndr/ndr_wkssvc.h"
2003-11-19 09:15:46 +00:00
# include "librpc/ndr/ndr_srvsvc.h"