625 lines
16 KiB
C
625 lines
16 KiB
C
/*
|
|
* Copyright (C) 2009 Mamadou Diop.
|
|
*
|
|
* Contact: Mamadou Diop <diopmamadou@yahoo.fr>
|
|
*
|
|
* This file is part of Open Source Doubango Framework.
|
|
*
|
|
* DOUBANGO 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 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* DOUBANGO 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 Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with DOUBANGO.
|
|
*
|
|
*/
|
|
|
|
/**@file tcomp_buffer.c
|
|
* @brief SigComp Buffer
|
|
*
|
|
* @author Mamadou Diop <diopmamadou(at)yahoo.fr>
|
|
*
|
|
* @date Created: Sat Nov 8 16:54:58 2009 mdiop
|
|
*/
|
|
#include "tcomp_buffer.h"
|
|
#include "tsk_binaryutils.h"
|
|
#include "tsk_memory.h"
|
|
#include "tsk_debug.h"
|
|
|
|
#include <string.h>
|
|
|
|
/**@defgroup tcomp_buffer_group SigComp Buffer
|
|
*/
|
|
|
|
/**@typedef tcomp_buffer_t
|
|
* SigComp buffer.
|
|
*/
|
|
typedef struct tcomp_buffer_s
|
|
{
|
|
size_t size; /**< The size of the buffer */
|
|
uint8_t* lpbuffer; /**< Pointer to the buffer */
|
|
size_t index_bytes; /**< Bytes (8bit size) cursor */
|
|
size_t index_bits; /**< Bits (1bit size) cursor */
|
|
unsigned owner:1; /**< If we are the owner of the buffer or not (external buffer) */
|
|
uint8_t P_BIT; /**< P-BIT controller. */
|
|
}
|
|
tcomp_buffer_t;
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Create SigComp buffer handle. You MUST use @ref tcomp_buffer_destroy to free the handle.
|
|
* @param data Reference to an external buffer
|
|
* @param len The length of the external buffer
|
|
* @retval Returns a new buffer handle.
|
|
* @sa @ref tcomp_buffer_destroy.
|
|
*/
|
|
tcomp_buffer_handle_t* _tcomp_buffer_create(const void* data, size_t len)
|
|
{
|
|
tcomp_buffer_t* buffer = tsk_calloc2(1, sizeof(tcomp_buffer_t));
|
|
|
|
if(buffer)
|
|
{
|
|
buffer->owner = 1;
|
|
|
|
/*The P-bit controls the order in which bits are passed from the
|
|
dispatcher to the INPUT instructions*/
|
|
buffer->P_BIT = TCOMP_P_BIT_MSB_TO_LSB;
|
|
|
|
if(data && len)
|
|
{
|
|
tcomp_buffer_appendBuff(buffer, data, len);
|
|
}
|
|
}
|
|
else TSK_DEBUG_ERROR("Cannot create new SigComp handle");
|
|
|
|
return ((tcomp_buffer_handle_t*)buffer);
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Compare two sigomp buffers.
|
|
* @param handle1 First handle to compare.
|
|
* @param handle2 Second handle to compare.
|
|
* @retval 1 if the two handles are equals and 0 otherwise.
|
|
*/
|
|
int tcomp_buffer_equals(const tcomp_buffer_handle_t* handle1, const tcomp_buffer_handle_t* handle2)
|
|
{
|
|
if( tcomp_buffer_getSize(handle1) == tcomp_buffer_getSize(handle2) )
|
|
{
|
|
return tcomp_buffer_startsWith(handle1, handle2);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Checks if the first internal buffer starts with the second handle internal buffer.
|
|
* @param handle1 First handle
|
|
* @param handle2 Second handle
|
|
* @retval Returns 1 if the first internal buffer starts with the second handle internal buffer and 0 otherwise.
|
|
*/
|
|
int tcomp_buffer_startsWith(const tcomp_buffer_handle_t* handle1, const tcomp_buffer_handle_t* handle2) /*const*/
|
|
{
|
|
size_t i;
|
|
tcomp_buffer_t* buffer1 = (tcomp_buffer_t*)handle1;
|
|
tcomp_buffer_t* buffer2 = (tcomp_buffer_t*)handle2;
|
|
|
|
if(buffer1->size < buffer2->size) return 0;
|
|
|
|
for(i = 0; i< buffer2->size; i++)
|
|
{
|
|
if(buffer1->lpbuffer[i] != buffer2->lpbuffer[i])
|
|
{
|
|
return 0;
|
|
}
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Get a readonly pointer to the internal buffer.
|
|
* @param handle The handle for which to get the internal buffer.
|
|
* @param position Position pointer
|
|
* @retval Pointer to the internal buffer.
|
|
*/
|
|
const uint8_t* tcomp_buffer_getReadOnlyBufferAtPos(const tcomp_buffer_handle_t* handle, size_t position)/*const*/
|
|
{
|
|
if(handle)
|
|
{
|
|
return (((tcomp_buffer_t*)handle)->lpbuffer + position);
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Get a read/write pointer to the internal buffer.
|
|
* @param handle The handle for which to get the internal buffer.
|
|
* @param position Position pointer
|
|
* @retval Pointer to the internal buffer.
|
|
*/
|
|
uint8_t* tcomp_buffer_getBufferAtPos(const tcomp_buffer_handle_t* handle, size_t position)
|
|
{
|
|
if(handle)
|
|
{
|
|
return (((tcomp_buffer_t*)handle)->lpbuffer + position);
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Gets the internal buffer size
|
|
* @retval The size of the internal buffer
|
|
*/
|
|
const size_t tcomp_buffer_getSize(const tcomp_buffer_handle_t* handle) /*const*/
|
|
{
|
|
if(handle)
|
|
{
|
|
return ((tcomp_buffer_t*)handle)->size;
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Gets the remainning bits.
|
|
* @param handle The handle for which to get the remaining bits.
|
|
*/
|
|
const size_t tcomp_buffer_getRemainingBits(const tcomp_buffer_handle_t* handle) /*const*/
|
|
{
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
size_t result = ((buffer->size * 8) - ((buffer->index_bytes * 8) + buffer->index_bits));
|
|
return (result < 0) ? 0: result;
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Read @a size bytes.
|
|
* @param handle The handle for which to read bytes.
|
|
* @param length Number of bytes to read.
|
|
* @retval Pointer to the resulting buffer.
|
|
*/
|
|
uint8_t* tcomp_buffer_readBytes(tcomp_buffer_handle_t* handle, size_t length)
|
|
{
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
size_t old_index;
|
|
|
|
if((buffer->index_bytes + length) > (buffer->size))
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
old_index = buffer->index_bytes;
|
|
buffer->index_bytes += length;
|
|
|
|
return tcomp_buffer_getBufferAtPos(handle, old_index);
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Read the internal buffer from LSB to MSB as per RFC 3320 subclause 8.2.
|
|
* @param handle The SigComp handle holding the internal buffer to read.
|
|
* @param length The length of the buffer to read.
|
|
* @retval All bits as a 2-bytes integer value
|
|
*/
|
|
uint16_t tcomp_buffer_readLsbToMsb(tcomp_buffer_handle_t* handle, size_t length)
|
|
{
|
|
// UDV Memory is always MSB first
|
|
// MSB <-- LSB
|
|
// FIXME: use mask
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
uint8_t pos = 0;
|
|
char* end;
|
|
uint16_t result_val = 0;
|
|
char result_str[16]; memset(result_str, 0, 16);
|
|
while(pos < length)
|
|
{
|
|
result_str[pos++] = (buffer->lpbuffer[buffer->index_bytes]
|
|
&(1 << (buffer->index_bits))) ? '1' : '0';
|
|
if(++buffer->index_bits == 8)
|
|
{
|
|
buffer->index_bytes++;
|
|
buffer->index_bits = 0;
|
|
}
|
|
}
|
|
|
|
end = (result_str+length);
|
|
result_val = (uint16_t)strtol(result_str, &end, 2);
|
|
|
|
return result_val;
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Read the internal buffer from MSB to LSB as per RFC 3320 subclause 8.2.
|
|
* @param handle The SigComp handle holding the internal buffer to read.
|
|
* @param length The length of the buffer to read.
|
|
* @retval All bits as a 2-bytes integer value
|
|
*/
|
|
uint16_t tcomp_buffer_readMsbToLsb(tcomp_buffer_handle_t* handle, size_t length)
|
|
{
|
|
// UDV Memory is always MSB first
|
|
// MSB --> LSB
|
|
// FIXME: use mask
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
uint8_t pos = 0;
|
|
char* end;
|
|
uint16_t result_val = 0;
|
|
char result_str[16]; memset(result_str, 0, 16);
|
|
|
|
while(pos < length)
|
|
{
|
|
result_str[pos++] = (buffer->lpbuffer[buffer->index_bytes]
|
|
&(128 >> (buffer->index_bits))) ? '1' : '0';
|
|
if(++buffer->index_bits == 8)
|
|
{
|
|
buffer->index_bytes++;
|
|
buffer->index_bits = 0;
|
|
}
|
|
}
|
|
|
|
end = (result_str + length);
|
|
result_val = (uint16_t)strtol(result_str, &end, 2);
|
|
|
|
return result_val;
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Discards bits as per RFC 3320 subclause 8.2.
|
|
* @param handle SigComp handle holding the internal buffer.
|
|
*/
|
|
void tcomp_buffer_discardBits(tcomp_buffer_handle_t* handle)
|
|
{
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
if(buffer->index_bits)
|
|
{
|
|
buffer->index_bits=0;
|
|
buffer->index_bytes++;
|
|
}
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Discards last bytes as per RFC 3320 subclause 8.2.
|
|
* @param handle SigComp handle holding the internal buffer.
|
|
* @param count The number of bytes to discard.
|
|
*/
|
|
void tcomp_buffer_discardLastBytes(tcomp_buffer_handle_t* handle, uint16_t count)
|
|
{
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
if(buffer->size > count)
|
|
{
|
|
buffer->size -= count;
|
|
}
|
|
else
|
|
{
|
|
tcomp_buffer_freeBuff(handle);
|
|
}
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Alloc the internal buffer.
|
|
* @param handle SigComp handle holding the internal buffer to alloc.
|
|
* @param size Number of bytes to allocate.
|
|
*/
|
|
void tcomp_buffer_allocBuff(tcomp_buffer_handle_t* handle, size_t size)
|
|
{
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
if(!buffer->owner)
|
|
{
|
|
TSK_DEBUG_ERROR("The SigComp is not the owner of the internal buffer to alloc.");
|
|
return;
|
|
}
|
|
if(!size)
|
|
{
|
|
TSK_DEBUG_WARN("Cannot allocate zero bytes.");
|
|
return;
|
|
}
|
|
tsk_free2(&(buffer->lpbuffer));
|
|
|
|
buffer->index_bits = buffer->index_bytes = 0;
|
|
buffer->lpbuffer = (uint8_t*) tsk_calloc2(1, size );
|
|
buffer->size = size;
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Add a buffer as a reference (not owned).
|
|
* @param handle SigComp handle holding the internal buffer.
|
|
* @param externalBuff THe external buffer to reference.
|
|
* @param size The size of the external buffer.
|
|
*/
|
|
void tcomp_buffer_referenceBuff(tcomp_buffer_handle_t* handle, uint8_t* externalBuff, size_t size)
|
|
{
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
if(buffer->size && buffer->owner)
|
|
{
|
|
TSK_DEBUG_ERROR("The SigComp handle already hold an internal buffer.");
|
|
return;
|
|
}
|
|
|
|
buffer->size = size;
|
|
buffer->lpbuffer = externalBuff;
|
|
buffer->index_bytes = 0;
|
|
buffer->index_bits = 0;
|
|
buffer->owner = 0;
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Append data to our internal buffer.
|
|
* @param handle The handle to the SigComp buffer.
|
|
* @param data Data to append to our internal buffer.
|
|
* @param size The size of the data
|
|
* @retval 1 if succeed and 0 otherwise.
|
|
*/
|
|
int tcomp_buffer_appendBuff(tcomp_buffer_handle_t* handle, const void* data, size_t size)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
size_t oldSize = buffer->size;
|
|
size_t newSize = (oldSize + size);
|
|
{
|
|
// realloc buffer
|
|
if(!buffer->size){
|
|
buffer->lpbuffer = (uint8_t*)tsk_malloc2(newSize);
|
|
}
|
|
else{
|
|
buffer->lpbuffer = (uint8_t*)tsk_realloc2(buffer->lpbuffer, newSize);
|
|
}
|
|
}
|
|
|
|
if(!buffer->lpbuffer) return 0;
|
|
|
|
if(data)
|
|
{
|
|
memmove((buffer->lpbuffer+oldSize), data, size);
|
|
}
|
|
else
|
|
{
|
|
memset((buffer->lpbuffer+oldSize), 0, size);
|
|
}
|
|
|
|
buffer->size = newSize;
|
|
return 1;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Remove bytes from the internal buffer.
|
|
* @param handle SigComp handle holding the internal buffer from which to remove bytes.
|
|
* @param pos The starting position from which to start removing bytes
|
|
* @param size The number of bytes to remove
|
|
* @retval 1 if succeed an zero otherwise.
|
|
*/
|
|
int tcomp_buffer_removeBuff(tcomp_buffer_handle_t* handle, size_t pos, size_t size)
|
|
{
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
size_t oldSize, newSize;
|
|
|
|
if(((pos + size) > buffer->size)) size = (buffer->size - pos);
|
|
memmove((buffer->lpbuffer + pos), (buffer->lpbuffer + pos + size), (buffer->size - (pos + size)));
|
|
|
|
oldSize = buffer->size;
|
|
newSize = (oldSize - size);
|
|
{
|
|
if(!(buffer->size))
|
|
{
|
|
buffer->lpbuffer = (uint8_t*)tsk_calloc2(1, newSize);
|
|
}
|
|
else
|
|
{
|
|
buffer->lpbuffer = (uint8_t*)tsk_realloc2(buffer->lpbuffer, newSize);
|
|
}
|
|
}
|
|
if(buffer->lpbuffer)
|
|
{
|
|
buffer->size = newSize;
|
|
return 1;
|
|
}
|
|
return 0;
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Free the internal buffer.
|
|
* @param handle SigComp handle holding the internal buffer to free.
|
|
*/
|
|
void tcomp_buffer_freeBuff(tcomp_buffer_handle_t* handle)
|
|
{
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
if(buffer->lpbuffer && buffer->size && buffer->owner)
|
|
{
|
|
tsk_free2(&(buffer->lpbuffer));
|
|
}
|
|
buffer->size = buffer->index_bytes = buffer->index_bits = 0;
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Gets the bytes cursor position.
|
|
* @param handle SigComp handle holding the internal buffer.
|
|
* @retval The cursor position.
|
|
*/
|
|
size_t* tcomp_buffer_getIndexBytes(const tcomp_buffer_handle_t* handle)
|
|
{
|
|
if(handle)
|
|
{
|
|
return &(((tcomp_buffer_t*)handle)->index_bytes);
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Gets the bits cursor position.
|
|
* @param handle SigComp handle holding the internal buffer.
|
|
* @retval The cursor position.
|
|
*/
|
|
size_t* tcomp_buffer_getIndexBits(const tcomp_buffer_handle_t* handle)
|
|
{
|
|
if(handle)
|
|
{
|
|
return &(((tcomp_buffer_t*)handle)->index_bits);
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Gets the P-bit controller value.
|
|
* The P-bit controls the order in which bits are passed from the dispatcher to the INPUT instructions. If set to 0, it indicates that
|
|
* the bits within an individual byte are passed to the INPUT instructions in MSB to LSB order. If it is set to 1, the bits are
|
|
* passed in LSB to MSB order.
|
|
* @param handle SigComp handle holding the internal buffer.
|
|
* @retval The P-Bit value.
|
|
*/
|
|
uint8_t* tcomp_buffer_getP_BIT(const tcomp_buffer_handle_t* handle)
|
|
{
|
|
if(handle)
|
|
{
|
|
return &(((tcomp_buffer_t*)handle)->P_BIT);
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Print the internal buffer.
|
|
* @param handle SigComp handle holding the internal buffer to print.
|
|
* @param size The number of bytes to print.
|
|
*/
|
|
void tcomp_buffer_nprint(tcomp_buffer_handle_t* handle, size_t size)
|
|
{
|
|
#if defined(_DEBUG) || defined(DEBUG)
|
|
|
|
if(handle)
|
|
{
|
|
size_t i, size_to_print;
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
size_to_print = (size<0) ? buffer->size : size;
|
|
|
|
if( !size_to_print || !buffer->lpbuffer) return;
|
|
|
|
for(i = 0; i < size_to_print; i+=2)
|
|
{
|
|
char s[10];
|
|
uint16_t value;
|
|
memset(s, 0, 10);
|
|
|
|
if((i+1) == size_to_print)
|
|
{
|
|
// last 2-byte lay in 1byte
|
|
value = buffer->lpbuffer[i];
|
|
#if 0
|
|
sprintf_s(s, 10, i?"%0.2x":"0x%0.2x", value);
|
|
#else
|
|
sprintf(s, i ? "%0.2x" : "0x%0.2x", value);
|
|
#endif
|
|
}
|
|
else
|
|
{
|
|
uint8_t *b_ptr = tcomp_buffer_getBufferAtPos(handle, i);
|
|
value = TSK_BINARY_GET_2BYTES(b_ptr);
|
|
#if 0
|
|
sprintf_s(s, 10, i?"%0.4x":"0x%0.4x", value);
|
|
#else
|
|
sprintf(s, i?"%0.4x":"0x%0.4x", value);
|
|
#endif
|
|
}
|
|
printf("%s ", s);
|
|
}
|
|
printf("\n\n");
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
#endif
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Resets a sigcomp buffer.
|
|
* @param handle Handle holding the internal buffer to reset.
|
|
*/
|
|
void tcomp_buffer_reset(tcomp_buffer_handle_t* handle)
|
|
{
|
|
if(handle)
|
|
{
|
|
tcomp_buffer_t* buffer = (tcomp_buffer_t*)handle;
|
|
|
|
buffer->index_bytes = 0;
|
|
buffer->index_bits = 0;
|
|
if(buffer->lpbuffer)
|
|
{
|
|
memset(buffer->lpbuffer, 0, buffer->size);
|
|
}
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle");
|
|
}
|
|
|
|
/**@ingroup tcomp_buffer_group
|
|
* Destroy a SigComp buffer handle previously allocated using @ref _tcomp_buffer_create or @a tcomp_buffer_create.
|
|
* @param handle The SigComp buffer handle to free.
|
|
* @sa @a tcomp_buffer_create @ref _tcomp_buffer_create.
|
|
*/
|
|
void tcomp_buffer_destroy(tcomp_buffer_handle_t** handle)
|
|
{
|
|
if(handle || !*handle)
|
|
{
|
|
tcomp_buffer_t** buffer = (tcomp_buffer_t**)handle;
|
|
|
|
tsk_free2(&((*buffer)->lpbuffer));
|
|
tsk_free2(buffer);
|
|
}
|
|
else TSK_DEBUG_ERROR("Null SigComp handle.");
|
|
} |