offset = VMRegionAddress( region ) - (TCAddress)context->buffer;
while ( ptr < top ) {
- if ( context->compareFunc(ptr,context->value->_value) ) {
+ char firstValue[context->value->_size];
+ memcpy(firstValue, ptr, context->value->_size);
+
+ if (context->value->_isEmulated)
+ {
+ if (context->value->_type == TCFloat)
+ {
+ CFSwappedFloat32 firstSwappedFloat = CFConvertFloat32HostToSwapped(*((float *)firstValue));
+ memcpy(firstValue, &firstSwappedFloat, context->value->_size);
+ }
+ else if (context->value->_type == TCDouble)
+ {
+ CFSwappedFloat64 firstSwappedDouble = CFConvertDoubleHostToSwapped(*((double *)firstValue));
+ memcpy(firstValue, &firstSwappedDouble, context->value->_size);
+ }
+ }
+
+ if ( context->compareFunc(firstValue,context->value->_value) ) {
if ( context->numberOfResults >= TCArrayElementCount(context->addresses) ) {
TCArrayResize( context->addresses, TCArrayElementCount(context->addresses) + TC_BUFFER_SIZE / sizeof(TCAddress) );
context->addressPtr = (TCAddress *)TCArrayBytes(context->addresses) + context->numberOfResults;
context->lastRegion = VMMakeRegion( context->process, *(context->lastRegionPtr), 0 );
region = VMNextRegionWithAttributes( context->process, context->lastRegion, VMREGION_READABLE | VMREGION_WRITABLE );
if ( VMRegionIsNotNull( region ) ) {
-
if ( context->bufferSize < VMRegionSize( region ) ) {
char *buf = realloc( context->buffer, VMRegionSize( region ) );
if ( buf ) {
top = *context->lastPerRegionPtr;
for ( i = 0; i < top; i++ ) {
-
ptr = context->buffer + *context->lastAddressPtr - VMRegionAddress(region);
- if ( context->compareFunc(ptr,context->value->_value) ) {
+
+ char firstValue[context->value->_size];
+ memcpy(firstValue, ptr, context->value->_size);
+
+ if (context->value->_isEmulated)
+ {
+ if (context->value->_type == TCFloat)
+ {
+ CFSwappedFloat32 firstSwappedFloat = CFConvertFloat32HostToSwapped(*((float *)firstValue));
+ memcpy(firstValue, &firstSwappedFloat, context->value->_size);
+ }
+ else if (context->value->_type == TCDouble)
+ {
+ CFSwappedFloat64 firstSwappedDouble = CFConvertDoubleHostToSwapped(*((double *)firstValue));
+ memcpy(firstValue, &firstSwappedDouble, context->value->_size);
+ }
+ }
+
+ if (ptr >= context->buffer && context->compareFunc(firstValue,context->value->_value)) {
if ( context->numberOfResults >= TCArrayElementCount(context->addresses) ) {
TCArrayResize( context->addresses, TCArrayElementCount(context->addresses) + TC_BUFFER_SIZE / sizeof(TCAddress) );
context->addressPtr = (TCAddress *)TCArrayBytes(context->addresses) + context->numberOfResults;
for ( i = 0; i < top; i++ ) {
ptr = context->buffer + *context->lastAddressPtr - VMRegionAddress(region);
- if ( context->compareFunc(ptr,context->lastValuePtr) ) {
+ if ( ptr >= context->buffer && context->compareFunc(ptr,context->lastValuePtr) ) {
if ( context->numberOfResults >= TCArrayElementCount(context->addresses) ) {
TCArrayResize( context->addresses, TCArrayElementCount(context->addresses) + TC_BUFFER_SIZE / sizeof(TCAddress) );
context->addressPtr = (TCAddress *)TCArrayBytes(context->addresses) + context->numberOfResults;
for ( i = 0; i < top; i++ ) {
ptr = context->buffer + *context->lastAddressPtr - VMRegionAddress(region);
- if ( memcmp( ptr, context->value->_value, MIN(TCArrayElementSize(context->values),context->buffer+VMRegionAddress(region)-ptr) ) == 0 ) {
+
+ if ( ptr >= context->buffer && memcmp( ptr, context->value->_value, MIN(TCArrayElementSize(context->values),context->buffer+VMRegionAddress(region)-ptr) ) == 0 ) {
if ( context->numberOfResults >= TCArrayElementCount(context->addresses) ) {
TCArrayResize( context->addresses, TCArrayElementCount(context->addresses) + TC_BUFFER_SIZE / sizeof(TCAddress) );
context->addressPtr = (TCAddress *)TCArrayBytes(context->addresses) + context->numberOfResults;
for ( i = 0; i < top; i++ ) {
ptr = context->buffer + *context->lastAddressPtr - VMRegionAddress(region);
- if ( memcmp( ptr, context->lastValuePtr, MIN(TCArrayElementSize(context->values),context->buffer+VMRegionAddress(region)-ptr) ) == 0 ) {
+ if ( ptr >= context->buffer && memcmp( ptr, context->lastValuePtr, MIN(TCArrayElementSize(context->values),context->buffer+VMRegionAddress(region)-ptr) ) == 0 ) {
if ( context->numberOfResults >= TCArrayElementCount(context->addresses) ) {
TCArrayResize( context->addresses, TCArrayElementCount(context->addresses) + TC_BUFFER_SIZE / sizeof(TCAddress) );
context->addressPtr = (TCAddress *)TCArrayBytes(context->addresses) + context->numberOfResults;