aboutsummaryrefslogtreecommitdiffstats
path: root/erts/emulator/beam/erl_bif_ddll.c
diff options
context:
space:
mode:
authorRickard Green <[email protected]>2012-08-15 01:28:55 +0200
committerRickard Green <[email protected]>2012-12-03 21:18:06 +0100
commit50cb7c24f061fd3d7df5970d8202f47c470a4047 (patch)
tree8d352994515c3217052cc5b64b78b597028ca75c /erts/emulator/beam/erl_bif_ddll.c
parentb434a3ab242dde66e23a72122474854f51a61eff (diff)
downloadotp-50cb7c24f061fd3d7df5970d8202f47c470a4047.tar.gz
otp-50cb7c24f061fd3d7df5970d8202f47c470a4047.tar.bz2
otp-50cb7c24f061fd3d7df5970d8202f47c470a4047.zip
Use ptab functionality also for ports
Diffstat (limited to 'erts/emulator/beam/erl_bif_ddll.c')
-rw-r--r--erts/emulator/beam/erl_bif_ddll.c45
1 files changed, 12 insertions, 33 deletions
diff --git a/erts/emulator/beam/erl_bif_ddll.c b/erts/emulator/beam/erl_bif_ddll.c
index a120a3e5f2..e18b1f0159 100644
--- a/erts/emulator/beam/erl_bif_ddll.c
+++ b/erts/emulator/beam/erl_bif_ddll.c
@@ -117,48 +117,27 @@ static void ddll_no_more_references(void *vdh);
static void
kill_ports_driver_unloaded(DE_Handle *dh)
{
- int ix;
+ int ix, max = erts_ptab_max(&erts_port);
- for (ix = 0; ix < erts_max_ports; ix++) {
- Port* prt = &erts_port[ix];
+ for (ix = 0; ix < max; ix++) {
erts_aint32_t state;
- state = erts_smp_atomic32_read_acqb(&prt->state);
- if (state & FREE_PORT_FLAGS)
+ Port* prt = erts_pix2port(ix);
+ if (!prt)
continue;
- erts_smp_port_minor_lock(prt);
+ ERTS_SMP_DATA_DEPENDENCY_READ_MEMORY_BARRIER;
- if (prt->drv_ptr->handle != dh) {
- erts_smp_port_minor_unlock(prt);
+ state = erts_atomic32_read_nob(&prt->state);
+ if (state & FREE_PORT_FLAGS)
continue;
- }
- erts_smp_atomic32_inc_nob(&prt->common.refc);
- erts_smp_port_minor_unlock(prt);
-
- state = erts_smp_atomic32_read_acqb(&prt->state);
- if (!(state & FREE_PORT_FLAGS)) {
-#if DDLL_SMP
- if (state & ERTS_PORT_SFLG_INITIALIZING) {
- /* Extremely rare busy wait */
- do {
- ERTS_SPIN_BODY;
- state = erts_smp_atomic32_read_acqb(&prt->state);
- } while (state & ERTS_PORT_SFLG_INITIALIZING);
- }
+ erts_smp_port_lock(prt);
- erts_smp_mtx_lock(prt->lock);
+ state = erts_atomic32_read_nob(&prt->state);
+ if (!(state & ERTS_PORT_SFLGS_DEAD) && prt->drv_ptr->handle == dh)
+ driver_failure_atom((ErlDrvPort) prt, "driver_unloaded");
- if (prt->drv_ptr->handle == dh) {
- state = erts_smp_atomic32_read_acqb(&prt->state);
- if (!(state & ERTS_PORT_SFLGS_DEAD))
- driver_failure_atom(ix, "driver_unloaded");
- }
-#else
- driver_failure_atom(ix, "driver_unloaded");
-#endif
- erts_port_release(prt);
- }
+ erts_port_release(prt);
}
}