|  | @@ -205,7 +205,7 @@ struct grpc_pollset {
 | 
	
		
			
				|  |  |       For example, we may choose a poll() based implementation on linux for
 | 
	
		
			
				|  |  |       few fds, and an epoll() based implementation for many fds */
 | 
	
		
			
				|  |  |    const grpc_pollset_vtable *vtable;
 | 
	
		
			
				|  |  | -  gpr_mu *mu;
 | 
	
		
			
				|  |  | +  gpr_mu mu;
 | 
	
		
			
				|  |  |    grpc_pollset_worker root_worker;
 | 
	
		
			
				|  |  |    int in_flight_cbs;
 | 
	
		
			
				|  |  |    int shutting_down;
 | 
	
	
		
			
				|  | @@ -271,11 +271,6 @@ static int pollset_has_workers(grpc_pollset *pollset);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  static void remove_fd_from_all_epoll_sets(int fd);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -/* override to allow tests to hook poll() usage */
 | 
	
		
			
				|  |  | -typedef int (*grpc_poll_function_type)(struct pollfd *, nfds_t, int);
 | 
	
		
			
				|  |  | -extern grpc_poll_function_type grpc_poll_function;
 | 
	
		
			
				|  |  | -extern grpc_wakeup_fd grpc_global_wakeup_fd;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |  /*******************************************************************************
 | 
	
		
			
				|  |  |   * pollset_set definitions
 | 
	
		
			
				|  |  |   */
 | 
	
	
		
			
				|  | @@ -426,11 +421,11 @@ static bool fd_is_orphaned(grpc_fd *fd) {
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  static void pollset_kick_locked(grpc_fd_watcher *watcher) {
 | 
	
		
			
				|  |  | -  gpr_mu_lock(watcher->pollset->mu);
 | 
	
		
			
				|  |  | +  gpr_mu_lock(&watcher->pollset->mu);
 | 
	
		
			
				|  |  |    GPR_ASSERT(watcher->worker);
 | 
	
		
			
				|  |  |    pollset_kick_ext(watcher->pollset, watcher->worker,
 | 
	
		
			
				|  |  |                     GRPC_POLLSET_REEVALUATE_POLLING_ON_WAKEUP);
 | 
	
		
			
				|  |  | -  gpr_mu_unlock(watcher->pollset->mu);
 | 
	
		
			
				|  |  | +  gpr_mu_unlock(&watcher->pollset->mu);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  static void maybe_wake_one_watcher_locked(grpc_fd *fd) {
 | 
	
	
		
			
				|  | @@ -706,10 +701,6 @@ static void fd_become_writable(grpc_exec_ctx *exec_ctx, grpc_fd *fd) {
 | 
	
		
			
				|  |  |  GPR_TLS_DECL(g_current_thread_poller);
 | 
	
		
			
				|  |  |  GPR_TLS_DECL(g_current_thread_worker);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -/** Default poll() function - a pointer so that it can be overridden by some
 | 
	
		
			
				|  |  | - *  tests */
 | 
	
		
			
				|  |  | -grpc_poll_function_type grpc_poll_function = poll;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |  /** The alarm system needs to be able to wakeup 'some poller' sometimes
 | 
	
		
			
				|  |  |   *  (specifically when a new alarm needs to be triggered earlier than the next
 | 
	
		
			
				|  |  |   *  alarm 'epoch').
 | 
	
	
		
			
				|  | @@ -837,8 +828,9 @@ static void kick_poller(void) { grpc_wakeup_fd_wakeup(&grpc_global_wakeup_fd); }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  static void become_basic_pollset(grpc_pollset *pollset, grpc_fd *fd_or_null);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -static void pollset_init(grpc_pollset *pollset, gpr_mu *mu) {
 | 
	
		
			
				|  |  | -  pollset->mu = mu;
 | 
	
		
			
				|  |  | +static void pollset_init(grpc_pollset *pollset, gpr_mu **mu) {
 | 
	
		
			
				|  |  | +  gpr_mu_init(&pollset->mu);
 | 
	
		
			
				|  |  | +  *mu = &pollset->mu;
 | 
	
		
			
				|  |  |    pollset->root_worker.next = pollset->root_worker.prev = &pollset->root_worker;
 | 
	
		
			
				|  |  |    pollset->in_flight_cbs = 0;
 | 
	
		
			
				|  |  |    pollset->shutting_down = 0;
 | 
	
	
		
			
				|  | @@ -861,6 +853,7 @@ static void pollset_destroy(grpc_pollset *pollset) {
 | 
	
		
			
				|  |  |      gpr_free(pollset->local_wakeup_cache);
 | 
	
		
			
				|  |  |      pollset->local_wakeup_cache = next;
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  | +  gpr_mu_destroy(&pollset->mu);
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  static void pollset_reset(grpc_pollset *pollset) {
 | 
	
	
		
			
				|  | @@ -877,15 +870,15 @@ static void pollset_reset(grpc_pollset *pollset) {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  static void pollset_add_fd(grpc_exec_ctx *exec_ctx, grpc_pollset *pollset,
 | 
	
		
			
				|  |  |                             grpc_fd *fd) {
 | 
	
		
			
				|  |  | -  gpr_mu_lock(pollset->mu);
 | 
	
		
			
				|  |  | +  gpr_mu_lock(&pollset->mu);
 | 
	
		
			
				|  |  |    pollset->vtable->add_fd(exec_ctx, pollset, fd, 1);
 | 
	
		
			
				|  |  |  /* the following (enabled only in debug) will reacquire and then release
 | 
	
		
			
				|  |  |     our lock - meaning that if the unlocking flag passed to add_fd above is
 | 
	
		
			
				|  |  |     not respected, the code will deadlock (in a way that we have a chance of
 | 
	
		
			
				|  |  |     debugging) */
 | 
	
		
			
				|  |  |  #ifndef NDEBUG
 | 
	
		
			
				|  |  | -  gpr_mu_lock(pollset->mu);
 | 
	
		
			
				|  |  | -  gpr_mu_unlock(pollset->mu);
 | 
	
		
			
				|  |  | +  gpr_mu_lock(&pollset->mu);
 | 
	
		
			
				|  |  | +  gpr_mu_unlock(&pollset->mu);
 | 
	
		
			
				|  |  |  #endif
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -934,7 +927,7 @@ static void pollset_work(grpc_exec_ctx *exec_ctx, grpc_pollset *pollset,
 | 
	
		
			
				|  |  |    /* Give do_promote priority so we don't starve it out */
 | 
	
		
			
				|  |  |    if (pollset->in_flight_cbs) {
 | 
	
		
			
				|  |  |      GPR_TIMER_MARK("pollset_work.in_flight_cbs", 0);
 | 
	
		
			
				|  |  | -    gpr_mu_unlock(pollset->mu);
 | 
	
		
			
				|  |  | +    gpr_mu_unlock(&pollset->mu);
 | 
	
		
			
				|  |  |      locked = 0;
 | 
	
		
			
				|  |  |      goto done;
 | 
	
		
			
				|  |  |    }
 | 
	
	
		
			
				|  | @@ -968,7 +961,7 @@ static void pollset_work(grpc_exec_ctx *exec_ctx, grpc_pollset *pollset,
 | 
	
		
			
				|  |  |    done:
 | 
	
		
			
				|  |  |      if (!locked) {
 | 
	
		
			
				|  |  |        queued_work |= grpc_exec_ctx_flush(exec_ctx);
 | 
	
		
			
				|  |  | -      gpr_mu_lock(pollset->mu);
 | 
	
		
			
				|  |  | +      gpr_mu_lock(&pollset->mu);
 | 
	
		
			
				|  |  |        locked = 1;
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |      /* If we're forced to re-evaluate polling (via pollset_kick with
 | 
	
	
		
			
				|  | @@ -998,19 +991,19 @@ static void pollset_work(grpc_exec_ctx *exec_ctx, grpc_pollset *pollset,
 | 
	
		
			
				|  |  |        pollset_kick(pollset, NULL);
 | 
	
		
			
				|  |  |      } else if (!pollset->called_shutdown && pollset->in_flight_cbs == 0) {
 | 
	
		
			
				|  |  |        pollset->called_shutdown = 1;
 | 
	
		
			
				|  |  | -      gpr_mu_unlock(pollset->mu);
 | 
	
		
			
				|  |  | +      gpr_mu_unlock(&pollset->mu);
 | 
	
		
			
				|  |  |        finish_shutdown(exec_ctx, pollset);
 | 
	
		
			
				|  |  |        grpc_exec_ctx_flush(exec_ctx);
 | 
	
		
			
				|  |  |        /* Continuing to access pollset here is safe -- it is the caller's
 | 
	
		
			
				|  |  |         * responsibility to not destroy when it has outstanding calls to
 | 
	
		
			
				|  |  |         * pollset_work.
 | 
	
		
			
				|  |  |         * TODO(dklempner): Can we refactor the shutdown logic to avoid this? */
 | 
	
		
			
				|  |  | -      gpr_mu_lock(pollset->mu);
 | 
	
		
			
				|  |  | +      gpr_mu_lock(&pollset->mu);
 | 
	
		
			
				|  |  |      } else if (!grpc_closure_list_empty(pollset->idle_jobs)) {
 | 
	
		
			
				|  |  |        grpc_exec_ctx_enqueue_list(exec_ctx, &pollset->idle_jobs, NULL);
 | 
	
		
			
				|  |  | -      gpr_mu_unlock(pollset->mu);
 | 
	
		
			
				|  |  | +      gpr_mu_unlock(&pollset->mu);
 | 
	
		
			
				|  |  |        grpc_exec_ctx_flush(exec_ctx);
 | 
	
		
			
				|  |  | -      gpr_mu_lock(pollset->mu);
 | 
	
		
			
				|  |  | +      gpr_mu_lock(&pollset->mu);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |    *worker_hdl = NULL;
 | 
	
	
		
			
				|  | @@ -1078,7 +1071,7 @@ static void basic_do_promote(grpc_exec_ctx *exec_ctx, void *args,
 | 
	
		
			
				|  |  |     * 4. The pollset may be shutting down.
 | 
	
		
			
				|  |  |     */
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  gpr_mu_lock(pollset->mu);
 | 
	
		
			
				|  |  | +  gpr_mu_lock(&pollset->mu);
 | 
	
		
			
				|  |  |    /* First we need to ensure that nobody is polling concurrently */
 | 
	
		
			
				|  |  |    GPR_ASSERT(!pollset_has_workers(pollset));
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -1118,7 +1111,7 @@ static void basic_do_promote(grpc_exec_ctx *exec_ctx, void *args,
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  gpr_mu_unlock(pollset->mu);
 | 
	
		
			
				|  |  | +  gpr_mu_unlock(&pollset->mu);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    /* Matching ref in basic_pollset_add_fd */
 | 
	
		
			
				|  |  |    GRPC_FD_UNREF(fd, "basicpoll_add");
 | 
	
	
		
			
				|  | @@ -1170,7 +1163,7 @@ static void basic_pollset_add_fd(grpc_exec_ctx *exec_ctx, grpc_pollset *pollset,
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  exit:
 | 
	
		
			
				|  |  |    if (and_unlock_pollset) {
 | 
	
		
			
				|  |  | -    gpr_mu_unlock(pollset->mu);
 | 
	
		
			
				|  |  | +    gpr_mu_unlock(&pollset->mu);
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -1206,14 +1199,14 @@ static void basic_pollset_maybe_work_and_unlock(grpc_exec_ctx *exec_ctx,
 | 
	
		
			
				|  |  |      pfd[2].fd = fd->fd;
 | 
	
		
			
				|  |  |      pfd[2].revents = 0;
 | 
	
		
			
				|  |  |      GRPC_FD_REF(fd, "basicpoll_begin");
 | 
	
		
			
				|  |  | -    gpr_mu_unlock(pollset->mu);
 | 
	
		
			
				|  |  | +    gpr_mu_unlock(&pollset->mu);
 | 
	
		
			
				|  |  |      pfd[2].events =
 | 
	
		
			
				|  |  |          (short)fd_begin_poll(fd, pollset, worker, POLLIN, POLLOUT, &fd_watcher);
 | 
	
		
			
				|  |  |      if (pfd[2].events != 0) {
 | 
	
		
			
				|  |  |        nfds++;
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |    } else {
 | 
	
		
			
				|  |  | -    gpr_mu_unlock(pollset->mu);
 | 
	
		
			
				|  |  | +    gpr_mu_unlock(&pollset->mu);
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    /* TODO(vpai): Consider first doing a 0 timeout poll here to avoid
 | 
	
	
		
			
				|  | @@ -1576,7 +1569,7 @@ static void perform_delayed_add(grpc_exec_ctx *exec_ctx, void *arg,
 | 
	
		
			
				|  |  |      finally_add_fd(exec_ctx, da->pollset, da->fd);
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  gpr_mu_lock(da->pollset->mu);
 | 
	
		
			
				|  |  | +  gpr_mu_lock(&da->pollset->mu);
 | 
	
		
			
				|  |  |    da->pollset->in_flight_cbs--;
 | 
	
		
			
				|  |  |    if (da->pollset->shutting_down) {
 | 
	
		
			
				|  |  |      /* We don't care about this pollset anymore. */
 | 
	
	
		
			
				|  | @@ -1585,7 +1578,7 @@ static void perform_delayed_add(grpc_exec_ctx *exec_ctx, void *arg,
 | 
	
		
			
				|  |  |        grpc_exec_ctx_enqueue(exec_ctx, da->pollset->shutdown_done, true, NULL);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  | -  gpr_mu_unlock(da->pollset->mu);
 | 
	
		
			
				|  |  | +  gpr_mu_unlock(&da->pollset->mu);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    GRPC_FD_UNREF(da->fd, "delayed_add");
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -1597,7 +1590,7 @@ static void multipoll_with_epoll_pollset_add_fd(grpc_exec_ctx *exec_ctx,
 | 
	
		
			
				|  |  |                                                  grpc_fd *fd,
 | 
	
		
			
				|  |  |                                                  int and_unlock_pollset) {
 | 
	
		
			
				|  |  |    if (and_unlock_pollset) {
 | 
	
		
			
				|  |  | -    gpr_mu_unlock(pollset->mu);
 | 
	
		
			
				|  |  | +    gpr_mu_unlock(&pollset->mu);
 | 
	
		
			
				|  |  |      finally_add_fd(exec_ctx, pollset, fd);
 | 
	
		
			
				|  |  |    } else {
 | 
	
		
			
				|  |  |      delayed_add *da = gpr_malloc(sizeof(*da));
 | 
	
	
		
			
				|  | @@ -1629,7 +1622,7 @@ static void multipoll_with_epoll_pollset_maybe_work_and_unlock(
 | 
	
		
			
				|  |  |     * here.
 | 
	
		
			
				|  |  |     */
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -  gpr_mu_unlock(pollset->mu);
 | 
	
		
			
				|  |  | +  gpr_mu_unlock(&pollset->mu);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |    timeout_ms = poll_deadline_to_millis_timeout(deadline, now);
 | 
	
		
			
				|  |  |  
 |