/* * * (c) Copyright 1990 OPEN SOFTWARE FOUNDATION, INC. * (c) Copyright 1990 HEWLETT-PACKARD COMPANY * (c) Copyright 1990 DIGITAL EQUIPMENT CORPORATION * To anyone who acknowledges that this file is provided "AS IS" * without any express or implied warranty: * permission to use, copy, modify, and distribute this * file for any purpose is hereby granted without fee, provided that * the above copyright notices and this notice appears in all source * code copies, and that none of the names of Open Software * Foundation, Inc., Hewlett-Packard Company, or Digital Equipment * Corporation be used in advertising or publicity pertaining to * distribution of the software without specific, written prior * permission. Neither Open Software Foundation, Inc., Hewlett- * Packard Company, nor Digital Equipment Corporation makes any * representations about the suitability of this software for any * purpose. * */ /* */ /* ** ** NAME ** ** cnfbuf.c ** ** FACILITY: ** ** Remote Procedure Call (RPC) ** ** ABSTRACT: ** ** Fragment buffer management routines for connection based ** protocol services. ** ** */ #include /* Common declarations for all RPC runtime */ #include /* More common declarations */ #include /* Connection common declarations */ #include /* Fragment buffer declarations */ GLOBAL unsigned32 rpc_g_cn_large_frag_size = RPC_C_CN_LARGE_FRAG_SIZE; /* **++ ** ** ROUTINE NAME: rpc__cn_fragbuf_free ** ** SCOPE: PRIVATE ** ** DESCRIPTION: ** ** Deallocates a large fragment buffer. ** ** INPUTS: ** ** buffer_p Pointer to the large fragment buffer which is to be ** deallocated. ** ** INPUTS/OUTPUTS: none ** ** OUTPUTS: none ** ** IMPLICIT INPUTS: lg_fragbuf_list ** ** IMPLICIT OUTPUTS: none ** ** FUNCTION VALUE: none ** ** SIDE EFFECTS: none ** **-- **/ PRIVATE void rpc__cn_fragbuf_free #ifdef _DCE_PROTO_ ( rpc_cn_fragbuf_p_t buffer_p ) #else (buffer_p) rpc_cn_fragbuf_p_t buffer_p; #endif { #ifdef MAX_DEBUG memset ((char *) buffer_p->data_area, 0, rpc_g_cn_large_frag_size); memset ((char *) buffer_p, 0, sizeof (rpc_cn_fragbuf_t)); #endif rpc__list_element_free (&rpc_g_cn_lg_fbuf_lookaside_list, (pointer_t) buffer_p); } /* **++ ** ** ROUTINE NAME: rpc__cn_smfragbuf_free ** ** SCOPE: PRIVATE ** ** DESCRIPTION: ** ** Deallocates a small fragment buffer. ** ** INPUTS: ** ** buffer_p Pointer to the small fragment buffer which is to be ** deallocated. ** ** INPUTS/OUTPUTS: none ** ** OUTPUTS: none ** ** IMPLICIT INPUTS: sm_fragbuf_list ** ** IMPLICIT OUTPUTS: none ** ** FUNCTION VALUE: none ** ** SIDE EFFECTS: none ** **-- **/ PRIVATE void rpc__cn_smfragbuf_free #ifdef _DCE_PROTO_ ( rpc_cn_fragbuf_p_t buffer_p ) #else (buffer_p) rpc_cn_fragbuf_p_t buffer_p; #endif { #ifdef MAX_DEBUG memset ((char *) buffer_p->data_area, 0, RPC_C_CN_SMALL_FRAG_SIZE); memset ((char *) buffer_p, 0, sizeof (rpc_cn_fragbuf_t)); #endif rpc__list_element_free (&rpc_g_cn_sm_fbuf_lookaside_list, (pointer_t) buffer_p ); } /* **++ ** ** ROUTINE NAME: rpc__cn_fragbuf_alloc ** ** SCOPE: PRIVATE ** ** DESCRIPTION: ** ** Allocates a fragment buffer and returns a pointer to it. ** ** INPUTS: ** ** alloc_large_buf If TRUE, then allocates a large fragment ** buffer. Otherwise, allocates a small one. ** ** INPUTS/OUTPUTS: none ** ** OUTPUTS: none ** ** IMPLICIT INPUTS: none ** ** IMPLICIT OUTPUTS: none ** ** FUNCTION VALUE: Address of the allocated fragment buffer. ** ** SIDE EFFECTS: none ** **-- **/ PRIVATE rpc_cn_fragbuf_p_t rpc__cn_fragbuf_alloc #ifdef _DCE_PROTO_ ( boolean32 alloc_large_buf ) #else (alloc_large_buf) boolean32 alloc_large_buf; #endif { rpc_cn_fragbuf_p_t fbp; /* * Get a fragment buffer from the appropriate lookaside list */ if (alloc_large_buf) { fbp = (rpc_cn_fragbuf_p_t) rpc__list_element_alloc (&rpc_g_cn_lg_fbuf_lookaside_list, true); if (fbp != NULL) { fbp->fragbuf_dealloc = rpc__cn_fragbuf_free; fbp->max_data_size = rpc_g_cn_large_frag_size; } else { return (NULL); } } else { fbp = (rpc_cn_fragbuf_p_t) rpc__list_element_alloc (&rpc_g_cn_sm_fbuf_lookaside_list, true); if (fbp != NULL) { fbp->fragbuf_dealloc = rpc__cn_smfragbuf_free; fbp->max_data_size = RPC_C_CN_SMALL_FRAG_SIZE; } else { return (NULL); } } /* * Set the data pointer to an 8 byte aligned boundary. */ fbp->data_p = (pointer_t) RPC_CN_ALIGN_PTR(fbp->data_area, 8); memset (fbp->data_area, 0, fbp->max_data_size); /* * Set up the size of the data being pointed to. */ fbp->data_size = 0; /* * Return a pointer to the "filled-in" fragment buffer */ return (fbp); } /* **++ ** ** ROUTINE NAME: rpc__cn_dynfragbuf_free ** ** SCOPE: INTERNAL ** ** DESCRIPTION: ** ** Deallocates a dynamic fragment buffer. ** ** INPUTS: ** ** buffer_p Pointer to the dynamic fragment buffer which is to be ** deallocated. ** ** INPUTS/OUTPUTS: none ** ** OUTPUTS: none ** ** IMPLICIT INPUTS: none ** ** IMPLICIT OUTPUTS: none ** ** FUNCTION VALUE: none ** ** SIDE EFFECTS: none ** **-- **/ INTERNAL void rpc__cn_dynfragbuf_free #ifdef _DCE_PROTO_ ( rpc_cn_fragbuf_p_t buffer_p ) #else (buffer_p) rpc_cn_fragbuf_p_t buffer_p; #endif { #ifdef MAX_DEBUG memset ((char *) buffer_p->data_area, 0, buffer_p->max_data_size); memset ((char *) buffer_p, 0, sizeof (rpc_cn_fragbuf_t)); #endif RPC_MEM_FREE(buffer_p, RPC_C_MEM_CN_PAC_BUF); } /* **++ ** ** ROUTINE NAME: rpc__cn_fragbuf_alloc_dyn ** ** SCOPE: PRIVATE ** ** DESCRIPTION: ** ** Allocates a fragment buffer and returns a pointer to it. ** ** INPUTS: ** ** alloc_size The size of the dynamic allocated fragment buffer. ** ** INPUTS/OUTPUTS: none ** ** OUTPUTS: none ** ** IMPLICIT INPUTS: none ** ** IMPLICIT OUTPUTS: none ** ** FUNCTION VALUE: Address of the allocated fragment buffer. ** ** SIDE EFFECTS: none ** **-- **/ PRIVATE rpc_cn_fragbuf_p_t rpc__cn_fragbuf_alloc_dyn #ifdef _DCE_PROTO_ ( unsigned32 alloc_size ) #else (alloc_size) unsigned32 alloc_size; #endif { rpc_cn_fragbuf_p_t fbp; RPC_MEM_ALLOC (fbp, rpc_cn_fragbuf_p_t, sizeof(rpc_cn_fragbuf_t) + alloc_size, RPC_C_MEM_CN_PAC_BUF, RPC_C_MEM_NOWAIT); if (fbp != NULL) { memset(fbp, 0, sizeof(rpc_cn_fragbuf_t)); fbp->fragbuf_dealloc = rpc__cn_dynfragbuf_free; fbp->max_data_size = alloc_size; } else { return (NULL); } /* * Set the data pointer to an 8 byte aligned boundary. */ fbp->data_p = (pointer_t) RPC_CN_ALIGN_PTR(fbp->data_area, 8); memset(fbp->data_area, 0, fbp->max_data_size); /* * Set up the size of the data being pointed to. */ fbp->data_size = 0; /* * Return a pointer to the "filled-in" fragment buffer */ return (fbp); }