diff options
author | Stewart Smith <stewart@linux.vnet.ibm.com> | 2016-11-23 11:38:29 +1100 |
---|---|---|
committer | Stewart Smith <stewart@linux.vnet.ibm.com> | 2016-11-24 16:47:16 +1100 |
commit | ecac29429861a912bd061df799dbc54493966f98 (patch) | |
tree | c3a39ae4011099e5569c4cd541307d4dc0335f64 /core | |
parent | 9fcb109218b1374a8caa3cac62e83fbedb1f7f2f (diff) | |
download | blackbird-skiboot-ecac29429861a912bd061df799dbc54493966f98.tar.gz blackbird-skiboot-ecac29429861a912bd061df799dbc54493966f98.zip |
run pollers in cpu_process_local_jobs() if running job synchonously
In the event we only have 1 CPU thread, we run asynchronous jobs
synchronously, and while we wait for them to finish, we run pollers.
However, if the jobs themselves don't call pollers (e.g. by time_wait())
then we'll end up in long periods of not running pollers at all.
To work around this, explicitly run pollers when we're the only
CPU thread (i.e. when we run the job synchronously).
Signed-off-by: Stewart Smith <stewart@linux.vnet.ibm.com>
Diffstat (limited to 'core')
-rw-r--r-- | core/cpu.c | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -403,6 +403,7 @@ void cpu_process_local_jobs(void) if (cpu == this_cpu()) { prlog_once(PR_DEBUG, "Processing jobs synchronously\n"); cpu_process_jobs(); + opal_run_pollers(); } } |