summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJérôme de Bretagne <jerome.debretagne@gmail.com>2021-09-14 00:43:29 +0200
committerJérôme de Bretagne <jerome.debretagne@gmail.com>2021-09-14 00:43:29 +0200
commitdee2f1c92c5081a7d02e2abd217baf133acf3ef9 (patch)
tree0359fab96071c11fe70850a1ee21b099dd19e4ed
parent5660e960e9a1fa73d98b3aecbd24cef15fcc66c4 (diff)
downloaderlang-dee2f1c92c5081a7d02e2abd217baf133acf3ef9.tar.gz
kernel: Support net_ticker_spawn_options in erl_uds_dist
This change allows user to specify extra spawn options for net ticker processes in erl_uds_dist, as introduced with OTP-17617 in PR-5069.
-rw-r--r--lib/kernel/examples/erl_uds_dist/src/erl_uds_dist.erl17
1 files changed, 13 insertions, 4 deletions
diff --git a/lib/kernel/examples/erl_uds_dist/src/erl_uds_dist.erl b/lib/kernel/examples/erl_uds_dist/src/erl_uds_dist.erl
index 44035e8e42..af7a577b20 100644
--- a/lib/kernel/examples/erl_uds_dist/src/erl_uds_dist.erl
+++ b/lib/kernel/examples/erl_uds_dist/src/erl_uds_dist.erl
@@ -432,8 +432,7 @@ accept_loop(Kernel, ListeningSocket) ->
accept_connection(AcceptPid, DistCtrl, MyNode, Allowed, SetupTime) ->
spawn_opt(?MODULE, accept_supervisor,
[self(), AcceptPid, DistCtrl, MyNode, Allowed, SetupTime],
- %% Spawn on max priority
- [link, {priority, max}]).
+ net_ticker_spawn_options()).
accept_supervisor(Kernel, AcceptPid, DistCtrl, MyNode, Allowed, SetupTime) ->
?trace("~p~n", [{?MODULE, accept_connection, self()}]),
@@ -475,6 +474,17 @@ accept_supervisor(Kernel, AcceptPid, DistCtrl, MyNode, Allowed, SetupTime) ->
%% ---------------------------------------------------------------------
+%% Allow to set different spawn options for dist_util processes using
+%% the net_ticker_spawn_options configuration parameter. Default is
+%% [link, {priority, max}] and these two options cannot be changed.
+%% ---------------------------------------------------------------------
+net_ticker_spawn_options() ->
+ Opts = application:get_env(kernel, net_ticker_spawn_options, []),
+ Opts1 = [{priority, max} | proplists:delete(priority, Opts)],
+ [link | proplists:delete(link, Opts1)].
+
+
+%% ---------------------------------------------------------------------
%% Define common values of the handshake data record, defined in
%% kernel/include/dist_util.hrl
%% ---------------------------------------------------------------------
@@ -666,8 +676,7 @@ getopts(ListeningSocket, Options) ->
setup(Node, Type, MyNode, _LongOrShortNames, SetupTime) ->
spawn_opt(?MODULE, setup_supervisor,
[self(), Node, Type, MyNode, SetupTime],
- %% Spawn on max priority
- [link, {priority, max}]).
+ net_ticker_spawn_options()).
setup_supervisor(Kernel, Node, Type, MyNode, SetupTime) ->
?trace("~p~n", [{?MODULE, setup, self(), Node}]),