diff options
Diffstat (limited to 'erts/emulator/beam/beam_emu.c')
| -rw-r--r-- | erts/emulator/beam/beam_emu.c | 54 | 
1 files changed, 27 insertions, 27 deletions
| diff --git a/erts/emulator/beam/beam_emu.c b/erts/emulator/beam/beam_emu.c index e909a0b4da..6b34024a5a 100644 --- a/erts/emulator/beam/beam_emu.c +++ b/erts/emulator/beam/beam_emu.c @@ -206,8 +206,12 @@ void** beam_ops;  #ifdef DEBUG  #  /* The stack pointer is used in an assertion. */  #  define LIGHT_SWAPOUT SWAPOUT +#  define DEBUG_SWAPOUT SWAPOUT +#  define DEBUG_SWAPIN  SWAPIN  #else  #  define LIGHT_SWAPOUT HEAP_TOP(c_p) = HTOP +#  define DEBUG_SWAPOUT +#  define DEBUG_SWAPIN  #endif  /* @@ -386,7 +390,6 @@ do {                                            \   */  static void init_emulator_finish(void) NOINLINE;  static ErtsCodeMFA *ubif2mfa(void* uf) NOINLINE; -static ErtsCodeMFA *gcbif2mfa(void* gcf) NOINLINE;  static BeamInstr* handle_error(Process* c_p, BeamInstr* pc,  			       Eterm* reg, ErtsCodeMFA* bif_mfa) NOINLINE;  static BeamInstr* call_error_handler(Process* p, ErtsCodeMFA* mfa, @@ -1301,18 +1304,6 @@ void erts_dirty_process_main(ErtsSchedulerData *esdp)  }  static ErtsCodeMFA * -gcbif2mfa(void* gcf) -{ -    int i; -    for (i = 0; erts_gc_bifs[i].bif; i++) { -	if (erts_gc_bifs[i].gc_bif == gcf) -	    return &bif_export[erts_gc_bifs[i].exp_ix]->info.mfa; -    } -    erts_exit(ERTS_ERROR_EXIT, "bad gc bif"); -    return NULL; -} - -static ErtsCodeMFA *  ubif2mfa(void* uf)  {      int i; @@ -1320,7 +1311,7 @@ ubif2mfa(void* uf)  	if (erts_u_bifs[i].bif == uf)  	    return &bif_export[erts_u_bifs[i].exp_ix]->info.mfa;      } -    erts_exit(ERTS_ERROR_EXIT, "bad u bif"); +    erts_exit(ERTS_ERROR_EXIT, "bad u bif: %p\n", uf);      return NULL;  } @@ -3062,12 +3053,14 @@ erts_gc_update_map_exact(Process* p, Eterm* reg, Uint live, Uint n, Eterm* new_p      Uint need;      flatmap_t *old_mp, *mp;      Eterm res; +    Eterm* old_hp;      Eterm* hp;      Eterm* E;      Eterm* old_keys;      Eterm* old_vals;      Eterm new_key;      Eterm map; +    int changed = 0;      n /= 2;		/* Number of values to be updated */      ASSERT(n > 0); @@ -3134,6 +3127,7 @@ erts_gc_update_map_exact(Process* p, Eterm* reg, Uint live, Uint n, Eterm* new_p       * Update map, keeping the old key tuple.       */ +    old_hp = p->htop;      hp = p->htop;      E = p->stop; @@ -3156,20 +3150,26 @@ erts_gc_update_map_exact(Process* p, Eterm* reg, Uint live, Uint n, Eterm* new_p  	    /* Not same keys */  	    *hp++ = *old_vals;  	} else { -	    GET_TERM(new_p[1], *hp); -	    hp++; -	    n--; +            GET_TERM(new_p[1], *hp); +            if(*hp != *old_vals) changed = 1; +            hp++; +            n--;  	    if (n == 0) { -		/* -		 * All updates done. Copy remaining values -		 * and return the result. -		 */ -		for (i++, old_vals++; i < num_old; i++) { -		    *hp++ = *old_vals++; -		} -		ASSERT(hp == p->htop + need); -		p->htop = hp; -		return res; +                /* +                * All updates done. Copy remaining values +                * if any changed or return the original one. +                */ +                if(changed) { +		    for (i++, old_vals++; i < num_old; i++) { +		        *hp++ = *old_vals++; +		    } +		    ASSERT(hp == p->htop + need); +		    p->htop = hp; +		    return res; +                } else { +                    p->htop = old_hp; +                    return map; +                }  	    } else {  		new_p += 2;  		GET_TERM(*new_p, new_key); | 
