1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
/* Division by powers of two.
*/
#include <testfwk.h>
#include <stddef.h>
typedef unsigned int UINT;
typedef struct _HeapEntryState
{
void *pBase;
UINT uFlags;
} HeapEntryState;
static HeapEntryState *
_getHeapEntryState (void *p, HeapEntryState *pStates, UINT nStateEntries)
{
int uLeft = -1, uRight = nStateEntries, uMiddle;
while (uRight - uLeft > 1)
{
int iDiff;
uMiddle = (uLeft + uRight)/2;
/* A divide by zero is added just before iDiff is assigned */
iDiff = pStates[uMiddle].pBase - p;
if (iDiff > 0)
{
uRight = uMiddle;
}
else if (iDiff < 0)
{
uLeft = uMiddle;
}
else
{
return pStates + uMiddle;
}
}
return NULL;
}
void
testDivByZero (void)
{
HeapEntryState aStates[] = {
{ (void __xdata *)1, 0 }
};
void *p = (void __xdata *)0x1234;
ASSERT (_getHeapEntryState (p, aStates, 1) == NULL);
aStates[0].pBase = p;
ASSERT (_getHeapEntryState (p, aStates, 1) == aStates + 0);
}
|