diff options
| author | Keith Packard <keithp@keithp.com> | 2016-11-11 21:07:09 -0800 | 
|---|---|---|
| committer | Keith Packard <keithp@keithp.com> | 2017-02-20 11:16:50 -0800 | 
| commit | d46ca67f93e9ecbc4d8c051c3fbdead85490b690 (patch) | |
| tree | 3db7c362164b99c3c047eb213f12c7f9601971fd | |
| parent | 00827a0ffe30938c26be216369fd2d8f8946d2c4 (diff) | |
altos/lisp: Make ao_lisp_ref and ao_lisp_poly non-inline
These functions are pretty large and end up consuming quite a bit of
space if inlined everywhere they are used.
Signed-off-by: Keith Packard <keithp@keithp.com>
| -rw-r--r-- | src/lisp/ao_lisp.h | 23 | ||||
| -rw-r--r-- | src/lisp/ao_lisp_poly.c | 18 | 
2 files changed, 22 insertions, 19 deletions
| diff --git a/src/lisp/ao_lisp.h b/src/lisp/ao_lisp.h index 86a5ddcf..7a165cd8 100644 --- a/src/lisp/ao_lisp.h +++ b/src/lisp/ao_lisp.h @@ -99,26 +99,11 @@ ao_lisp_is_const(ao_poly poly) {  #define AO_LISP_IS_CONST(a)	(ao_lisp_const <= ((uint8_t *) (a)) && ((uint8_t *) (a)) < ao_lisp_const + AO_LISP_POOL_CONST)  #define AO_LISP_IS_POOL(a)	(ao_lisp_pool <= ((uint8_t *) (a)) && ((uint8_t *) (a)) < ao_lisp_pool + AO_LISP_POOL) -static inline void * -ao_lisp_ref(ao_poly poly) { -	if (poly == 0xBEEF) -		ao_lisp_abort(); -	if (poly == AO_LISP_NIL) -		return NULL; -	if (poly & AO_LISP_CONST) -		return (void *) (AO_LISP_CONST_BASE + (poly & AO_LISP_REF_MASK)); -	return (void *) (AO_LISP_POOL_BASE + (poly & AO_LISP_REF_MASK)); -} +void * +ao_lisp_ref(ao_poly poly); -static inline ao_poly -ao_lisp_poly(const void *addr, ao_poly type) { -	const uint8_t	*a = addr; -	if (a == NULL) -		return AO_LISP_NIL; -	if (AO_LISP_IS_CONST(a)) -		return AO_LISP_CONST | (a - AO_LISP_CONST_BASE) | type; -	return (a - AO_LISP_POOL_BASE) | type; -} +ao_poly +ao_lisp_poly(const void *addr, ao_poly type);  struct ao_lisp_type {  	int	(*size)(void *addr); diff --git a/src/lisp/ao_lisp_poly.c b/src/lisp/ao_lisp_poly.c index bfd75ae3..9717fd73 100644 --- a/src/lisp/ao_lisp_poly.c +++ b/src/lisp/ao_lisp_poly.c @@ -84,3 +84,21 @@ ao_lisp_poly_patom(ao_poly p)  		f->patom(p);  } +void * +ao_lisp_ref(ao_poly poly) { +	if (poly == AO_LISP_NIL) +		return NULL; +	if (poly & AO_LISP_CONST) +		return (void *) (AO_LISP_CONST_BASE + (poly & AO_LISP_REF_MASK)); +	return (void *) (AO_LISP_POOL_BASE + (poly & AO_LISP_REF_MASK)); +} + +ao_poly +ao_lisp_poly(const void *addr, ao_poly type) { +	const uint8_t	*a = addr; +	if (a == NULL) +		return AO_LISP_NIL; +	if (AO_LISP_IS_CONST(a)) +		return AO_LISP_CONST | (a - AO_LISP_CONST_BASE) | type; +	return (a - AO_LISP_POOL_BASE) | type; +} | 
