diff options
Diffstat (limited to 'erts/emulator/beam/erl_thr_progress.c')
| -rw-r--r-- | erts/emulator/beam/erl_thr_progress.c | 37 | 
1 files changed, 25 insertions, 12 deletions
| diff --git a/erts/emulator/beam/erl_thr_progress.c b/erts/emulator/beam/erl_thr_progress.c index 700ed90def..aa08eb40ec 100644 --- a/erts/emulator/beam/erl_thr_progress.c +++ b/erts/emulator/beam/erl_thr_progress.c @@ -1,7 +1,7 @@  /*   * %CopyrightBegin%   * - * Copyright Ericsson AB 2011-2016. All Rights Reserved. + * Copyright Ericsson AB 2011-2018. All Rights Reserved.   *   * Licensed under the Apache License, Version 2.0 (the "License");   * you may not use this file except in compliance with the License. @@ -80,7 +80,6 @@  #include "erl_thr_progress.h"  #include "global.h" -#ifdef ERTS_SMP  #define ERTS_THR_PRGR_DBG_CHK_WAKEUP_REQUEST_VALUE 0 @@ -321,13 +320,23 @@ tmp_thr_prgr_data(ErtsSchedulerData *esdp)      ErtsThrPrgrData *tpd = perhaps_thr_prgr_data(esdp);      if (!tpd) { -	/* -	 * We only allocate the part up to the wakeup_request field -	 * which is the first field only used by registered threads -	 */ -	tpd = erts_alloc(ERTS_ALC_T_T_THR_PRGR_DATA, -			 offsetof(ErtsThrPrgrData, wakeup_request)); -	init_tmp_thr_prgr_data(tpd); +        /* +         * We only allocate the part up to the wakeup_request field which is +         * the first field only used by registered threads +         */ +        size_t alloc_size = offsetof(ErtsThrPrgrData, wakeup_request); + +        /* We may land here as a result of unmanaged_delay being called from +         * the lock counting module, which in turn might be called from within +         * the allocator, so we use plain malloc to avoid deadlocks. */ +        tpd = +#ifdef ERTS_ENABLE_LOCK_COUNT +            malloc(alloc_size); +#else +            erts_alloc(ERTS_ALC_T_T_THR_PRGR_DATA, alloc_size); +#endif + +        init_tmp_thr_prgr_data(tpd);      }      return tpd; @@ -337,8 +346,13 @@ static ERTS_INLINE void  return_tmp_thr_prgr_data(ErtsThrPrgrData *tpd)  {      if (tpd->is_temporary) { -	erts_tsd_set(erts_thr_prgr_data_key__, NULL); -	erts_free(ERTS_ALC_T_T_THR_PRGR_DATA, tpd); +        erts_tsd_set(erts_thr_prgr_data_key__, NULL); + +#ifdef ERTS_ENABLE_LOCK_COUNT +        free(tpd); +#else +        erts_free(ERTS_ALC_T_T_THR_PRGR_DATA, tpd); +#endif      }  } @@ -1498,4 +1512,3 @@ void erts_thr_progress_dbg_print_state(void)  } -#endif | 
