fixed a bug of wrong short number conversion in stix_strtoint() when STIX_LIW_BITS == STIX_OOHW_BITS
This commit is contained in:
		| @ -27,10 +27,12 @@ | ||||
| #include "stix-prv.h" | ||||
|  | ||||
|  | ||||
| #if defined(STIX_USE_FULL_WORD) | ||||
| #if (STIX_LIW_BITS == STIX_OOW_BITS) | ||||
| 	/* nothing special */ | ||||
| #else | ||||
| #elif (STIX_LIW_BITS == STIX_OOHW_BITS) | ||||
| #	define MAKE_WORD(hw1,hw2) ((stix_oow_t)(hw1) | (stix_oow_t)(hw2) << STIX_LIW_BITS) | ||||
| #else | ||||
| #	error UNSUPPORTED LIW BIT SIZE | ||||
| #endif | ||||
|  | ||||
| /*#define IS_POWER_OF_2(ui) (((ui) > 0) && (((ui) & (~(ui)+ 1)) == (ui)))*/ | ||||
| @ -167,7 +169,7 @@ static STIX_INLINE int is_integer (stix_t* stix, stix_oop_t oop) | ||||
|  | ||||
| static STIX_INLINE stix_oop_t make_bigint_with_ooi (stix_t* stix, stix_ooi_t i) | ||||
| { | ||||
| #if defined(STIX_USE_FULL_WORD) | ||||
| #if (STIX_LIW_BITS == STIX_OOW_BITS) | ||||
| 	stix_oow_t w; | ||||
|  | ||||
| 	STIX_ASSERT (STIX_SIZEOF(stix_oow_t) == STIX_SIZEOF(stix_liw_t)); | ||||
| @ -185,7 +187,7 @@ static STIX_INLINE stix_oop_t make_bigint_with_ooi (stix_t* stix, stix_ooi_t i) | ||||
| 		w = -i; | ||||
| 		return stix_instantiate (stix, stix->_large_negative_integer, &w, 1); | ||||
| 	} | ||||
| #else | ||||
| #elif (STIX_LIW_BITS == STIX_OOHW_BITS) | ||||
| 	stix_liw_t hw[2]; | ||||
| 	stix_oow_t w; | ||||
|  | ||||
| @ -204,6 +206,8 @@ static STIX_INLINE stix_oop_t make_bigint_with_ooi (stix_t* stix, stix_ooi_t i) | ||||
| 		hw[1] = w >> STIX_LIW_BITS; | ||||
| 		return stix_instantiate (stix, stix->_large_negative_integer, &hw, (hw[1] > 0? 2: 1)); | ||||
| 	} | ||||
| #else | ||||
| #	error UNSUPPORTED LIW BIT SIZE | ||||
| #endif | ||||
| } | ||||
|  | ||||
| @ -317,7 +321,7 @@ static stix_oop_t normalize_bigint (stix_t* stix, stix_oop_t oop) | ||||
| 	STIX_ASSERT (STIX_OOP_IS_POINTER(oop)); | ||||
| 	count = count_effective_digits (oop); | ||||
|  | ||||
| #if defined(STIX_USE_FULL_WORD) | ||||
| #if (STIX_LIW_BITS == STIX_OOW_BITS) | ||||
| 	if (count == 1) /* 1 word */ | ||||
| 	{ | ||||
| 		stix_oow_t w; | ||||
| @ -334,7 +338,8 @@ static stix_oop_t normalize_bigint (stix_t* stix, stix_oop_t oop) | ||||
| 			if (w <= STIX_SMOOI_MAX) return STIX_SMOOI_TO_OOP(-(stix_ooi_t)w); | ||||
| 		} | ||||
| 	} | ||||
| #else | ||||
| #elif (STIX_LIW_BITS == STIX_OOHW_BITS) | ||||
|  | ||||
| 	if (count == 1) /* 1 half-word */ | ||||
| 	{ | ||||
| 		if (STIX_OBJ_GET_CLASS(oop) == stix->_large_positive_integer) | ||||
| @ -363,6 +368,8 @@ static stix_oop_t normalize_bigint (stix_t* stix, stix_oop_t oop) | ||||
| 			if (w <= STIX_SMOOI_MAX) return STIX_SMOOI_TO_OOP(-(stix_ooi_t)w); | ||||
| 		} | ||||
| 	} | ||||
| #else | ||||
| #	error UNSUPPORTED LIW BIT SIZE | ||||
| #endif | ||||
| 	if (STIX_OBJ_GET_SIZE(oop) == count) | ||||
| 	{ | ||||
| @ -1077,27 +1084,6 @@ stix_oop_t stix_mulints (stix_t* stix, stix_oop_t x, stix_oop_t y) | ||||
| 			STIX_OBJ_SET_CLASS(z, stix->_large_negative_integer); | ||||
| 	} | ||||
|  | ||||
| { int i; | ||||
| printf ("MUL=>"); | ||||
| for (i = STIX_OBJ_GET_SIZE(z); i > 0;) | ||||
| { | ||||
| printf ("%0*lX ", (int)(STIX_SIZEOF(stix_liw_t) * 2), (unsigned long)((stix_oop_liword_t)z)->slot[--i]); | ||||
| } | ||||
| printf ("\n"); | ||||
| } | ||||
|  | ||||
| /* | ||||
| lshift_unsigned_array (((stix_oop_liword_t)z)->slot, STIX_OBJ_GET_SIZE(z), 16 * 5 + 4); | ||||
| { int i; | ||||
| printf ("LSHIFT10=>"); | ||||
| for (i = STIX_OBJ_GET_SIZE(z); i > 0;) | ||||
| { | ||||
| printf ("%0*lX ", (int)(STIX_SIZEOF(stix_liw_t) * 2), (unsigned long)((stix_oop_liword_t)z)->slot[--i]); | ||||
| } | ||||
| printf ("\n"); | ||||
| }*/ | ||||
|  | ||||
|  | ||||
| 	return normalize_bigint (stix, z); | ||||
|  | ||||
| oops_einval: | ||||
| @ -1117,6 +1103,7 @@ stix_oop_t stix_divints (stix_t* stix, stix_oop_t x, stix_oop_t y, int modulo, s | ||||
| 		xv = STIX_OOP_TO_SMOOI(x); | ||||
| 		yv = STIX_OOP_TO_SMOOI(y); | ||||
|  | ||||
| printf ("%d %d\n", (int)xv, (int)yv); | ||||
| 		if (yv == 0) | ||||
| 		{ | ||||
| 			stix->errnum = STIX_EDIVBY0; | ||||
| @ -1382,7 +1369,8 @@ static stix_uint8_t ooch_val_tab[] = | ||||
|  | ||||
| stix_oop_t stix_strtoint (stix_t* stix, const stix_ooch_t* str, stix_oow_t len, int radix) | ||||
| { | ||||
| 	int neg = 0; | ||||
| 	//int neg = 0; | ||||
| 	int sign = 1; | ||||
| 	const stix_ooch_t* ptr, * start, * end; | ||||
| 	stix_lidw_t w, v; | ||||
| 	stix_liw_t hw[16], * hwp = STIX_NULL; | ||||
| @ -1391,7 +1379,8 @@ stix_oop_t stix_strtoint (stix_t* stix, const stix_ooch_t* str, stix_oow_t len, | ||||
|  | ||||
| 	if (radix < 0)  | ||||
| 	{ | ||||
| 		neg = 1; | ||||
| 		/* when radix is less than 0, it treats it as if '-' is preceeding */ | ||||
| 		sign = -1; | ||||
| 		radix = -radix; | ||||
| 	} | ||||
|  | ||||
| @ -1406,7 +1395,7 @@ stix_oop_t stix_strtoint (stix_t* stix, const stix_ooch_t* str, stix_oow_t len, | ||||
| 		else if (*ptr == '-')  | ||||
| 		{ | ||||
| 			ptr++;  | ||||
| 			neg = 1; | ||||
| 			sign = -1; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @ -1579,38 +1568,31 @@ stix_oop_t stix_strtoint (stix_t* stix, const stix_ooch_t* str, stix_oow_t len, | ||||
| 	} | ||||
|  | ||||
| 	STIX_ASSERT (hwlen >= 1); | ||||
| #if defined(STIX_USE_FULL_WORD) | ||||
|  | ||||
| #if (STIX_LIW_BITS == STIX_OOW_BITS) | ||||
| 	if (hwlen == 1)  | ||||
| 	{ | ||||
| 		w = hwp[0]; | ||||
| 		if (neg)  | ||||
| 		{ | ||||
| 			STIX_ASSERT (-STIX_SMOOI_MAX == STIX_SMOOI_MIN); | ||||
| 			if (w <= STIX_SMOOI_MAX) return STIX_SMOOI_TO_OOP(-(stix_ooi_t)w); | ||||
| 		} | ||||
| 		else  | ||||
| 		{ | ||||
| 			if (w <= STIX_SMOOI_MAX) return STIX_SMOOI_TO_OOP(w); | ||||
| 		} | ||||
| 		STIX_ASSERT (-STIX_SMOOI_MAX == STIX_SMOOI_MIN); | ||||
| 		if (w <= STIX_SMOOI_MAX) return STIX_SMOOI_TO_OOP((stix_ooi_t)w * sign); | ||||
| 	} | ||||
| #elif (STIX_LIW_BITS == STIX_OOHW_BITS) | ||||
| 	if (hwlen == 1)  | ||||
| 	{ | ||||
| 		STIX_ASSERT (hwp[0] <= STIX_SMOOI_MAX); | ||||
| 		return STIX_SMOOI_TO_OOP((stix_ooi_t)hwp[0] * sign); | ||||
| 	} | ||||
| #else | ||||
| 	if (hwlen == 1) return STIX_SMOOI_TO_OOP((stix_ooi_t)hwp[0] * -neg); | ||||
| 	else if (hwlen == 2) | ||||
| 	{ | ||||
| 		w = MAKE_WORD(hwp[0], hwp[1]); | ||||
| 		if (neg)  | ||||
| 		{ | ||||
| 			STIX_ASSERT (-STIX_SMOOI_MAX == STIX_SMOOI_MIN); | ||||
| 			if (w <= STIX_SMOOI_MAX) return STIX_SMOOI_TO_OOP(-(stix_ooi_t)w); | ||||
| 		} | ||||
| 		else  | ||||
| 		{ | ||||
| 			if (w <= STIX_SMOOI_MAX) return STIX_SMOOI_TO_OOP(w); | ||||
| 		} | ||||
| 		STIX_ASSERT (-STIX_SMOOI_MAX == STIX_SMOOI_MIN); | ||||
| 		if (w <= STIX_SMOOI_MAX) return STIX_SMOOI_TO_OOP((stix_ooi_t)w * sign); | ||||
| 	} | ||||
| #else | ||||
| #	error UNSUPPORTED LIW BIT SIZE | ||||
| #endif | ||||
|  | ||||
| 	res = stix_instantiate (stix, (neg? stix->_large_negative_integer: stix->_large_positive_integer), hwp, hwlen); | ||||
| 	res = stix_instantiate (stix, (sign < 0? stix->_large_negative_integer: stix->_large_positive_integer), hwp, hwlen); | ||||
| 	if (hwp && hw != hwp) stix_freemem (stix, hwp); | ||||
| 	return res; | ||||
|  | ||||
| @ -1677,13 +1659,13 @@ stix_oop_t stix_inttostr (stix_t* stix, stix_oop_t num, int radix) | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 	#if STIX_LIW_BITS == STIX_OOW_BITS | ||||
| 	#if (STIX_LIW_BITS == STIX_OOW_BITS) | ||||
| 		if (STIX_OBJ_GET_SIZE(num) == 1) | ||||
| 		{ | ||||
| 			w = ((stix_oop_word_t)num)->slot[0]; | ||||
| 			v = (STIX_OBJ_GET_CLASS(num) == stix->_large_negative_integer)? -1: 1; | ||||
| 		} | ||||
| 	#elif STIX_LIW_BITS == STIX_OOHW_BITS | ||||
| 	#elif (STIX_LIW_BITS == STIX_OOHW_BITS) | ||||
| 		if (STIX_OBJ_GET_SIZE(num) == 1) | ||||
| 		{ | ||||
| 			w = ((stix_oop_halfword_t)num)->slot[0]; | ||||
| @ -1692,8 +1674,10 @@ stix_oop_t stix_inttostr (stix_t* stix, stix_oop_t num, int radix) | ||||
| 		else if (STIX_OBJ_GET_SIZE(num) == 2) | ||||
| 		{ | ||||
| 			w = MAKE_WORD (((stix_oop_halfword_t)num)->slot[0], ((stix_oop_halfword_t)num)->slot[1]); | ||||
| 			v = (STIX_OBJ_GET_CLASS(oop) == stix->_large_negative_integer)? -1: 1; | ||||
| 			v = (STIX_OBJ_GET_CLASS(num) == stix->_large_negative_integer)? -1: 1; | ||||
| 		} | ||||
| 	#else | ||||
| 	#	error UNSUPPORTED LIW BIT SIZE | ||||
| 	#endif | ||||
| 	} | ||||
|  | ||||
| @ -1714,7 +1698,7 @@ stix_oop_t stix_inttostr (stix_t* stix, stix_oop_t num, int radix) | ||||
| 		return stix_makestring (stix, buf, len); | ||||
| 	} | ||||
|  | ||||
|  | ||||
| #if 0 | ||||
| 	/* Do it in a hard way */ | ||||
| 	do | ||||
| 	{ | ||||
| @ -1728,6 +1712,7 @@ stix_oop_t stix_inttostr (stix_t* stix, stix_oop_t num, int radix) | ||||
|  | ||||
| 	} | ||||
| 	while (1); | ||||
| #endif | ||||
|  | ||||
| oops_einval: | ||||
| 	stix->errnum = STIX_EINVAL; | ||||
|  | ||||
| @ -1778,29 +1778,37 @@ static int emit_push_smint_literal (stix_t* stix, stix_ooi_t i) | ||||
| 	switch (i) | ||||
| 	{ | ||||
| 		case -1: | ||||
| printf ("\tpush negone\n"); | ||||
| 			return emit_byte_instruction (stix, BCODE_PUSH_NEGONE); | ||||
|  | ||||
| 		case 0: | ||||
| printf ("\tpush zero\n"); | ||||
| 			return emit_byte_instruction (stix, BCODE_PUSH_ZERO); | ||||
|  | ||||
| 		case 1: | ||||
| printf ("\tpush one\n"); | ||||
| 			return emit_byte_instruction (stix, BCODE_PUSH_ONE); | ||||
|  | ||||
| 		case 2: | ||||
| printf ("\tpush two\n"); | ||||
| 			return emit_byte_instruction (stix, BCODE_PUSH_TWO); | ||||
| 	} | ||||
|  | ||||
| 	if (i >= 0 && i <= MAX_CODE_PARAM) | ||||
| 	{ | ||||
| printf ("\tpush intlit %d\n", (int)i); | ||||
| 		return emit_single_param_instruction(stix, BCODE_PUSH_INTLIT, i); | ||||
| 	} | ||||
| 	else if (i < 0 && i >= -(stix_ooi_t)MAX_CODE_PARAM) | ||||
| 	{ | ||||
| printf ("\tpush negintlit %d\n", (int)i); | ||||
| 		return emit_single_param_instruction(stix, BCODE_PUSH_NEGINTLIT, -i); | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	if (add_literal(stix, STIX_SMOOI_TO_OOP(i), &index) <= -1 || | ||||
| 	    emit_single_param_instruction(stix, BCODE_PUSH_LITERAL_0, index) <= -1) return -1; | ||||
| printf ("\tpush litral_0 %d\n", (int)index); | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
| @ -3517,18 +3525,19 @@ printf ("\tpush symbol literal %d\n", (int)index); | ||||
| /* TODO: floating pointer number */ | ||||
| 				/* TODO: other types of numbers, etc */ | ||||
| 				stix_oop_t tmp; | ||||
|  | ||||
| 				tmp = string_to_num (stix, &stix->c->tok.name, stix->c->tok.type == STIX_IOTOK_RADNUMLIT); | ||||
| 				if (!tmp) return -1; | ||||
|  | ||||
| 				if (STIX_OOP_IS_SMOOI(tmp)) | ||||
| 				{ | ||||
| printf ("\tpush int literal\n"); | ||||
| 					if (emit_push_smint_literal(stix, STIX_OOP_TO_SMOOI(tmp)) <= -1) return -1; | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					if (add_literal(stix, tmp, &index) <= -1 || | ||||
| 					    emit_single_param_instruction(stix, BCODE_PUSH_LITERAL_0, index) <= -1) return -1; | ||||
| printf ("\tpush_literal_0 %d\n", (int)index); | ||||
| 				} | ||||
|  | ||||
| 				GET_TOKEN (stix); | ||||
|  | ||||
| @ -122,14 +122,18 @@ static void switch_process (stix_t* stix, stix_oop_process_t proc) | ||||
| { | ||||
| 	if (stix->processor->active != proc) | ||||
| 	{ | ||||
| #if defined(STIX_DEBUG_PROCESSOR) | ||||
| printf ("ACTUAL PROCESS SWITCHING BF...%d %p\n", (int)stix->ip, stix->active_context); | ||||
| #endif | ||||
|  | ||||
| /* store the active context to the active process */ | ||||
| STIX_ASSERT ((stix_oop_t)stix->processor->active != stix->_nil); | ||||
| stix->processor->active->active_context = stix->active_context; | ||||
|  | ||||
| 		SWITCH_ACTIVE_CONTEXT (stix, proc->active_context); | ||||
| #if defined(STIX_DEBUG_PROCESSOR) | ||||
| printf ("ACTUAL PROCESS SWITCHING AF...%d %p\n", (int)stix->ip, stix->active_context); | ||||
| #endif | ||||
| 		/*TODO: set the state to RUNNING */ | ||||
| 		stix->processor->active = proc; | ||||
| 	} | ||||
| @ -140,12 +144,16 @@ static void switch_to_next_process (stix_t* stix) | ||||
| /* TODO: this is experimental. rewrite it */ | ||||
| 	if ((stix_oop_t)stix->processor->active->next == stix->_nil) | ||||
| 	{ | ||||
| #if defined(STIX_DEBUG_PROCESSOR) | ||||
| printf ("SWITCHING TO THE HEAD PROCESS\n"); | ||||
| #endif | ||||
| 		switch_process (stix, stix->processor->head); | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| #if defined(STIX_DEBUG_PROCESSOR) | ||||
| printf ("SWITCHING TO THE NEXT PROCESS\n"); | ||||
| #endif | ||||
| 		switch_process (stix, stix->processor->active->next); | ||||
| 	} | ||||
| } | ||||
| @ -169,22 +177,27 @@ static STIX_INLINE int register_new_process (stix_t* stix, stix_oop_process_t pr | ||||
| 		stix->processor->head = proc; | ||||
| 		stix->processor->tail = proc; | ||||
| 		stix->processor->tally  = STIX_SMOOI_TO_OOP(1); | ||||
| #if defined(STIX_DEBUG_PROCESSOR) | ||||
| printf ("ADD NEW PROCESS X - %d\n", (int)1); | ||||
| #endif | ||||
| 	} | ||||
| 	else if (tally >= STIX_SMOOI_MAX) | ||||
| 	{ | ||||
| #if defined(STIX_DEBUG_PROCESSOR) | ||||
| printf ("TOO MANY PROCESS\n"); | ||||
| #endif | ||||
| 		stix->errnum = STIX_EPFULL; | ||||
| 		return -1; | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		/* TODO: over flow check or maximum number of process check using the tally field? */ | ||||
| 		proc->next = stix->processor->head; | ||||
| 		stix->processor->head->prev = proc; | ||||
| 		stix->processor->head = proc; | ||||
| 		stix->processor->tally = STIX_SMOOI_TO_OOP(tally + 1); | ||||
| #if defined(STIX_DEBUG_PROCESSOR) | ||||
| printf ("ADD NEW PROCESS Y - %d\n", (int)tally + 1); | ||||
| #endif | ||||
| 	} | ||||
|  | ||||
| 	proc->state = STIX_SMOOI_TO_OOP(1); /* TODO: change the code properly... changing state alone doesn't help */ | ||||
| @ -1115,6 +1128,7 @@ static int prim_integer_quo (stix_t* stix, stix_ooi_t nargs) | ||||
|  | ||||
| 	quo = stix_divints (stix, rcv, arg, 0, STIX_NULL); | ||||
| 	if (!quo) return (stix->errnum == STIX_EINVAL? 0: -1); /* soft or hard failure */ | ||||
| /* TODO: STIX_EDIVBY0 soft or hard failure? */ | ||||
|  | ||||
| 	ACTIVE_STACK_POP (stix); | ||||
| 	ACTIVE_STACK_SETTOP (stix, quo); | ||||
| @ -1132,6 +1146,7 @@ static int prim_integer_rem (stix_t* stix, stix_ooi_t nargs) | ||||
|  | ||||
| 	quo = stix_divints (stix, rcv, arg, 0, &rem); | ||||
| 	if (!quo) return (stix->errnum == STIX_EINVAL? 0: -1); /* soft or hard failure */ | ||||
| /* TODO: STIX_EDIVBY0 soft or hard failure? */ | ||||
|  | ||||
| 	ACTIVE_STACK_POP (stix); | ||||
| 	ACTIVE_STACK_SETTOP (stix, rem); | ||||
| @ -1149,6 +1164,7 @@ static int prim_integer_quo2 (stix_t* stix, stix_ooi_t nargs) | ||||
|  | ||||
| 	quo = stix_divints (stix, rcv, arg, 1, STIX_NULL); | ||||
| 	if (!quo) return (stix->errnum == STIX_EINVAL? 0: -1); /* soft or hard failure */ | ||||
| /* TODO: STIX_EDIVBY0 soft or hard failure? */ | ||||
|  | ||||
| 	ACTIVE_STACK_POP (stix); | ||||
| 	ACTIVE_STACK_SETTOP (stix, quo); | ||||
| @ -1166,6 +1182,7 @@ static int prim_integer_rem2 (stix_t* stix, stix_ooi_t nargs) | ||||
|  | ||||
| 	quo = stix_divints (stix, rcv, arg, 1, &rem); | ||||
| 	if (!quo) return (stix->errnum == STIX_EINVAL? 0: -1); /* soft or hard failure */ | ||||
| /* TODO: STIX_EDIVBY0 soft or hard failure? */ | ||||
|  | ||||
| 	ACTIVE_STACK_POP (stix); | ||||
| 	ACTIVE_STACK_SETTOP (stix, rem); | ||||
| @ -2397,7 +2414,6 @@ fflush (stdout); | ||||
| 				newrcv = ACTIVE_STACK_GET(stix, stix->sp - b1); | ||||
|  | ||||
| #if defined(STIX_DEBUG_EXEC) | ||||
| printf ("NEWRCV => %p\n", newrcv); | ||||
| printf (" RECEIVER = "); | ||||
| print_object(stix, newrcv); | ||||
| printf ("\n"); | ||||
|  | ||||
| @ -50,10 +50,12 @@ | ||||
| #define STIX_USE_OBJECT_TRAILER | ||||
|  | ||||
| /* this is for gc debugging */ | ||||
| /*#define STIX_DEBUG_PROCESSOR*/ | ||||
| #define STIX_DEBUG_GC_001 | ||||
| /*#define STIX_DEBUG_EXEC*/ | ||||
| #define STIX_PROFILE_EXEC | ||||
|  | ||||
|  | ||||
| #include <stdio.h> /* TODO: delete these header inclusion lines */ | ||||
| #include <string.h> | ||||
| #include <assert.h> | ||||
|  | ||||
		Reference in New Issue
	
	Block a user