diff options
Diffstat (limited to 'lib/kernel')
30 files changed, 441 insertions, 130 deletions
| diff --git a/lib/kernel/doc/src/app.xml b/lib/kernel/doc/src/app.xml index 5e0da409a3..d2e9390d7e 100644 --- a/lib/kernel/doc/src/app.xml +++ b/lib/kernel/doc/src/app.xml @@ -151,7 +151,7 @@ ApplicationVersion = string()</code>            application is allowed to be started. <c>systools</c> uses            this list to generate correct start scripts. Defaults to            the empty list, but notice that all applications have -          dependencies to (at least) <c>Kernel</c> and <c>STDLIB</c>.</p> +          dependencies to (at least) Kernel and STDLIB.</p>        </item>        <tag><c>env</c></tag>        <item> @@ -171,7 +171,7 @@ ApplicationVersion = string()</code>            implemented as a supervision tree, otherwise the application            controller does not know how to start it. <c>mod</c>            can be omitted for applications without processes, typically -          code libraries, for example, <c>STDLIB</c>.</p> +          code libraries, for example, STDLIB.</p>        </item>        <tag><c>start_phases</c></tag>        <item> @@ -236,7 +236,7 @@ ApplicationVersion = string()</code>    <section>      <title>See Also</title>      <p><seealso marker="application"><c>application(3)</c></seealso>, -      <seealso marker="sasl:systools"><c>sasl:systools(3)</c></seealso></p> +      <seealso marker="sasl:systools"><c>systools(3)</c></seealso></p>    </section>  </fileref> diff --git a/lib/kernel/doc/src/application.xml b/lib/kernel/doc/src/application.xml index 8d33aa86e7..886286b76d 100644 --- a/lib/kernel/doc/src/application.xml +++ b/lib/kernel/doc/src/application.xml @@ -200,7 +200,7 @@  	<seealso marker="app"><c>app(4)</c></seealso>.</p>          <p>If <c><anno>Distributed</anno> == {<anno>Application</anno>,[<anno>Time</anno>,]<anno>Nodes</anno>}</c>,            the application becomes distributed. The argument overrides -          the value for the application in the <c>Kernel</c> configuration +          the value for the application in the Kernel configuration            parameter <c>distributed</c>. <c><anno>Application</anno></c> must be            the application name (same as in the first argument).            If a node crashes and <c><anno>Time</anno></c> is specified, @@ -221,7 +221,7 @@ Nodes = [cp1@cave, {cp2@cave, cp3@cave}]</code>            the application is to be started at <c>cp2@cave</c>            or <c>cp3@cave</c>.</p>          <p>If <c>Distributed == default</c>, the value for -          the application in the <c>Kernel</c> configuration parameter +          the application in the Kernel configuration parameter            <c>distributed</c> is used.</p>        </desc>      </func> @@ -267,7 +267,7 @@ Nodes = [cp1@cave, {cp2@cave, cp3@cave}]</code>            started, <c>Application</c> is started as well.</p>          <p>By default, all applications are loaded with permission            <c>true</c> on all nodes. The permission can be configured -          using the <c>Kernel</c> configuration parameter <c>permissions</c>.</p> +          using the Kernel configuration parameter <c>permissions</c>.</p>        </desc>      </func>      <func> diff --git a/lib/kernel/doc/src/auth.xml b/lib/kernel/doc/src/auth.xml index 03f983b96d..5901446960 100644 --- a/lib/kernel/doc/src/auth.xml +++ b/lib/kernel/doc/src/auth.xml @@ -47,7 +47,7 @@        <desc>          <p>Use            <seealso marker="erts:erlang#erlang:get_cookie/0"><c>erlang:get_cookie()</c></seealso> -          in <c>ERTS</c> instead.</p> +          in ERTS instead.</p>        </desc>      </func>      <func> @@ -59,7 +59,7 @@        <desc>          <p>Use            <seealso marker="erts:erlang#erlang:set_cookie/2"><c>erlang:set_cookie(node(), <anno>Cookie</anno>)</c> -	  in <c>ERTS</c></seealso> instead.</p> +	  in ERTS</seealso> instead.</p>        </desc>      </func>      <func> diff --git a/lib/kernel/doc/src/code.xml b/lib/kernel/doc/src/code.xml index d3611d6a03..4db377bcde 100644 --- a/lib/kernel/doc/src/code.xml +++ b/lib/kernel/doc/src/code.xml @@ -86,11 +86,11 @@        an <c>ebin</c> directory are ignored.</p>      <p>All application directories found in the additional directories        appears before the standard OTP applications, except for the -      <c>Kernel</c> and <c>STDLIB</c> applications, which are placed before +      Kernel and STDLIB applications, which are placed before        any additional applications. In other words, modules found in any        of the additional library directories override modules with -      the same name in OTP, except for modules in <c>Kernel</c> and -      <c>STDLIB</c>.</p> +      the same name in OTP, except for modules in Kernel and +      STDLIB.</p>      <p>Environment variable <c>ERL_LIBS</c> (if defined) is to contain        a colon-separated (for Unix-like systems) or semicolon-separated        (for Windows) list of additional libraries.</p> @@ -151,7 +151,7 @@ zip:create("mnesia-4.4.7.ez",       <c>$OTPROOT/lib/mnesia.ez/mnesia/ebin</c> or       <c>$OTPROOT/lib/mnesia-4.4.7.ez/mnesia-4.4.7/ebin</c>.</p> -    <p>The code server uses module <c>erl_prim_loader</c> in <c>ERTS</c> +    <p>The code server uses module <c>erl_prim_loader</c> in ERTS       (possibly through <c>erl_boot_server</c>) to read code files from       archives. However, the functions in <c>erl_prim_loader</c> can also be       used by other applications to read files from archives. For @@ -651,6 +651,11 @@ ok = code:finish_loading(Prepared),          <p>Purges the code for <c><anno>Module</anno></c>, that is, removes code            marked as old. If some processes still linger in the old code,            these processes are killed before the code is removed.</p> +	<note><p>As of ERTS version 9.0, a process is only considered +	to be lingering in the code if it has direct references to the code. +	For more information see documentation of +	<seealso marker="erts:erlang#check_process_code/3"><c>erlang:check_process_code/3</c></seealso>, +	which is used in order to determine this.</p></note>          <p>Returns <c>true</c> if successful and any process is needed to            be killed, otherwise <c>false</c>.</p>        </desc> @@ -661,6 +666,11 @@ ok = code:finish_loading(Prepared),        <desc>          <p>Purges the code for <c><anno>Module</anno></c>, that is, removes code            marked as old, but only if no processes linger in it.</p> +	<note><p>As of ERTS version 9.0, a process is only considered +	to be lingering in the code if it has direct references to the code. +	For more information see documentation of +	<seealso marker="erts:erlang#check_process_code/3"><c>erlang:check_process_code/3</c></seealso>, +	which is used in order to determine this.</p></note>          <p>Returns <c>false</c> if the module cannot be purged because            of processes lingering in old code, otherwise <c>true</c>.</p>        </desc> @@ -678,9 +688,9 @@ ok = code:finish_loading(Prepared),          <p>Normally, <c><anno>Loaded</anno></c> is the absolute filename            <c>Filename</c> from which the code is obtained. If the module            is preloaded (see -          <seealso marker="sasl:script"><c>sasl:script(4)</c></seealso>), +          <seealso marker="sasl:script"><c>script(4)</c></seealso>),            <c>Loaded==preloaded</c>. If the module is Cover-compiled (see -          <seealso marker="tools:cover"><c>tools:cover(3)</c></seealso>), +          <seealso marker="tools:cover"><c>cover(3)</c></seealso>),            <c>Loaded==cover_compiled</c>.</p>        </desc>      </func> diff --git a/lib/kernel/doc/src/erl_boot_server.xml b/lib/kernel/doc/src/erl_boot_server.xml index 897365f9b9..4109251387 100644 --- a/lib/kernel/doc/src/erl_boot_server.xml +++ b/lib/kernel/doc/src/erl_boot_server.xml @@ -38,13 +38,13 @@        command-line flag <c>-loader inet</c>. All hosts specified        with command-line flag <c>-hosts Host</c> must have one        instance of this server running.</p> -    <p>This server can be started with the <c>Kernel</c> configuration +    <p>This server can be started with the Kernel configuration        parameter <c>start_boot_server</c>.</p>      <p>The <c>erl_boot_server</c> can read regular files and        files in archives. See <seealso marker="code"><c>code(3)</c></seealso>        and      <seealso marker="erts:erl_prim_loader"><c>erl_prim_loader(3)</c></seealso> -    in <c>ERTS</c>.</p> +    in ERTS.</p>      <warning><p>The support for loading code from archive files is       experimental. It is released before it is ready       to obtain early feedback. The file format, semantics, diff --git a/lib/kernel/doc/src/erl_ddll.xml b/lib/kernel/doc/src/erl_ddll.xml index a5ce58ef3e..75114e015c 100644 --- a/lib/kernel/doc/src/erl_ddll.xml +++ b/lib/kernel/doc/src/erl_ddll.xml @@ -201,7 +201,7 @@        <desc>          <p>Removes a driver monitor in much the same way as             <seealso marker="erts:erlang#erlang:demonitor/1"><c>erlang:demonitor/1</c></seealso> -	  in <c>ERTS</c> +	  in ERTS  	  does with process monitors. For details about how to create  	  driver monitors, see  	  <seealso marker="#monitor/2"><c>monitor/2</c></seealso>, @@ -431,7 +431,7 @@          <p>Creates a driver monitor and works in many            ways as  	  <seealso marker="erts:erlang#erlang:monitor/2"><c>erlang:monitor/2</c></seealso> -	  in <c>ERTS</c>, +	  in ERTS,            does for processes. When a driver changes state, the monitor            results in a monitor message that is sent to the calling            process. <c><anno>MonitorRef</anno></c> returned by this function is @@ -745,7 +745,7 @@              <p>This parameter is the name of the driver  	      to be used in subsequent calls to function  	      <seealso marker="erts:erlang#open_port/2"><c>erlang:open_port</c></seealso> -	      in <c>ERTS</c>. +	      in ERTS.  	      The name can be specified as an <c>iolist()</c> or                an <c>atom()</c>. The name specified when loading is used                to find the object file (with the help of <c><anno>Path</anno></c> diff --git a/lib/kernel/doc/src/error_logger.xml b/lib/kernel/doc/src/error_logger.xml index a8273e59e2..814e8eac46 100644 --- a/lib/kernel/doc/src/error_logger.xml +++ b/lib/kernel/doc/src/error_logger.xml @@ -33,7 +33,7 @@    <description>      <p>The Erlang <em>error logger</em> is an event manager (see        <seealso marker="doc/design_principles:des_princ">OTP Design Principles</seealso> and -      <seealso marker="stdlib:gen_event"><c>stdlib:gen_event(3)</c></seealso>), +      <seealso marker="stdlib:gen_event"><c>gen_event(3)</c></seealso>),        registered as <c>error_logger</c>. Errors, warnings, and info events        are sent to the error logger from the Erlang runtime system and        the different Erlang/OTP applications. The events are, by default, @@ -44,12 +44,12 @@        executing.</p>      <p>Initially, <c>error_logger</c> has only a primitive event        handler, which buffers and prints the raw event messages. During -      system startup, the <c>Kernel</c> application replaces this with a +      system startup, the Kernel application replaces this with a        <em>standard event handler</em>, by default one that writes -      nicely formatted output to the terminal. <c>Kernel</c> can also be +      nicely formatted output to the terminal. Kernel can also be        configured so that events are logged to a file instead, or not logged at all,        see <seealso marker="kernel_app"><c>kernel(6)</c></seealso>.</p> -    <p>Also the <c>SASL</c> application, if started, adds its own event +    <p>Also the SASL application, if started, adds its own event        handler, which by default writes supervisor, crash, and progress        reports to the terminal. See        <seealso marker="sasl:sasl_app"><c>sasl(6)</c></seealso>.</p> @@ -58,9 +58,9 @@        User-defined event handlers can be added to handle application-specific        events, see        <seealso marker="#add_report_handler/1"><c>add_report_handler/1,2</c></seealso>. -      Also, a useful event handler is provided in <c>STDLIB</c> for multi-file +      Also, a useful event handler is provided in STDLIB for multi-file        logging of events, see -      <seealso marker="stdlib:log_mf_h"><c>stdlib:log_mf_h(3)</c></seealso>.</p> +      <seealso marker="stdlib:log_mf_h"><c>log_mf_h(3)</c></seealso>.</p>      <p>Warning events were introduced in Erlang/OTP R9C and are enabled        by default as from Erlang/OTP 18.0. To retain backwards compatibility        with existing user-defined event handlers, the warning events can be @@ -82,7 +82,7 @@          <p>Adds a new event handler to the error logger. The event            handler must be implemented as a <c>gen_event</c> callback            module, see -          <seealso marker="stdlib:gen_event"><c>stdlib:gen_event(3)</c></seealso>.</p> +          <seealso marker="stdlib:gen_event"><c>gen_event(3)</c></seealso>.</p>          <p><c><anno>Handler</anno></c> is typically the name of the callback module            and <c><anno>Args</anno></c> is an optional term (defaults to []) passed            to the initialization callback function <c><anno>Handler</anno>:init/1</c>. @@ -97,7 +97,7 @@        <desc>          <p>Deletes an event handler from the error logger by calling            <c>gen_event:delete_handler(error_logger, <anno>Handler</anno>, [])</c>, -          see <seealso marker="stdlib:gen_event"><c>stdlib:gen_event(3)</c></seealso>.</p> +          see <seealso marker="stdlib:gen_event"><c>gen_event(3)</c></seealso>.</p>        </desc>      </func>      <func> @@ -110,7 +110,7 @@            The <c><anno>Format</anno></c> and <c><anno>Data</anno></c> arguments  	  are the same as the arguments of  	  <seealso marker="stdlib:io#format/2"><c>io:format/2</c></seealso> -	  in <c>STDLIB</c>. +	  in STDLIB.  	  The event is handled by the standard event handler.</p>  	<p><em>Example:</em></p>          <pre> @@ -171,7 +171,7 @@ ok</pre>            The <c><anno>Format</anno></c> and <c><anno>Data</anno></c> arguments  	  are the same as the arguments of  	  <seealso marker="stdlib:io#format/2"><c>io:format/2</c></seealso> -	  in <c>STDLIB</c>. The event is handled by the standard event handler.</p> +	  in STDLIB. The event is handled by the standard event handler.</p>  	<p><em>Example:</em></p>          <pre>  1> <input>error_logger:info_msg("Something happened in ~p~n", [a_module]).</input> @@ -235,7 +235,7 @@ ok</pre>          <p>Enables or disables printout of standard events to a file.</p>          <p>This is done by adding or deleting the standard event handler            for output to file. Thus, calling this function overrides -          the value of the <c>Kernel</c> <c>error_logger</c> configuration +          the value of the Kernel <c>error_logger</c> configuration            parameter.</p>          <p>Enabling file logging can be used together with calling            <c>tty(false)</c>, to have a silent system where @@ -274,7 +274,7 @@ ok</pre>  	  to the terminal.</p>          <p>This is done by adding or deleting the standard event handler            for output to the terminal. Thus, calling this function overrides -          the value of the <c>Kernel</c> <c>error_logger</c> configuration parameter.</p> +          the value of the Kernel <c>error_logger</c> configuration parameter.</p>        </desc>      </func>      <func> @@ -323,7 +323,7 @@ ok</pre>            The <c><anno>Format</anno></c> and <c><anno>Data</anno></c> arguments  	  are the same as the arguments of  	  <seealso marker="stdlib:io#format/2"><c>io:format/2</c></seealso> -	  in <c>STDLIB</c>. +	  in STDLIB.  	  The event is handled by the standard event handler. It is tagged  	  as an error, warning, or info, see            <seealso marker="#warning_map/0"><c>warning_map/0</c></seealso>.</p> @@ -416,8 +416,8 @@ ok</pre>    </section>    <section>      <title>See Also</title> -    <p><seealso marker="stdlib:gen_event"><c>stdlib:gen_event(3)</c></seealso>, -       <seealso marker="stdlib:log_mf_h"><c>stdlib:log_mf_h(3)</c></seealso> +    <p><seealso marker="stdlib:gen_event"><c>gen_event(3)</c></seealso>, +       <seealso marker="stdlib:log_mf_h"><c>log_mf_h(3)</c></seealso>         <seealso marker="kernel_app"><c>kernel(6)</c></seealso>         <seealso marker="sasl:sasl_app"><c>sasl(6)</c></seealso></p>    </section> diff --git a/lib/kernel/doc/src/file.xml b/lib/kernel/doc/src/file.xml index 7d86c3ebcb..09497482cf 100644 --- a/lib/kernel/doc/src/file.xml +++ b/lib/kernel/doc/src/file.xml @@ -79,7 +79,7 @@      <seealso marker="#list_dir_all"><c>list_dir_all/1</c></seealso> and      <seealso marker="#read_link_all"><c>read_link_all/1</c></seealso>.</p> -    <p>See also section <seealso marker="stdlib:unicode_usage#notes-about-raw-filenames">Notes About Raw Filenames</seealso> in the <c>STDLIB</c> User“s Giude.</p> +    <p>See also section <seealso marker="stdlib:unicode_usage#notes-about-raw-filenames">Notes About Raw Filenames</seealso> in the STDLIB User's Guide.</p>    </description> @@ -277,7 +277,7 @@ f.txt:  {person, "kalle", 25}.  {ok,[{person,"kalle",25},{person,"pelle",30}]}</pre>          <p>The encoding of <c><anno>Filename</anno></c> can be set            by a comment, as described in -	  <seealso marker="stdlib:epp#encoding"><c>stdlib:epp(3)</c></seealso>.</p> +	  <seealso marker="stdlib:epp#encoding"><c>epp(3)</c></seealso>.</p>        </desc>      </func>      <func> @@ -445,7 +445,7 @@ f.txt:  {person, "kalle", 25}.          </taglist>          <p>The encoding of <c><anno>Filename</anno></c> can be set            by a comment, as described in -	  <seealso marker="stdlib:epp#encoding"><c>stdlib:epp(3)</c></seealso>.</p> +	  <seealso marker="stdlib:epp#encoding"><c>epp(3)</c></seealso>.</p>        </desc>      </func>      <func> @@ -455,7 +455,7 @@ f.txt:  {person, "kalle", 25}.          <p>The same as <c>eval/1</c>, but the variable bindings            <c><anno>Bindings</anno></c> are used in the evaluation. For information  	  about the variable bindings, see -          <seealso marker="stdlib:erl_eval"><c>stdlib:erl_eval(3)</c></seealso>.</p> +          <seealso marker="stdlib:erl_eval"><c>erl_eval(3)</c></seealso>.</p>        </desc>      </func>      <func> @@ -830,7 +830,7 @@ f.txt:  {person, "kalle", 25}.  	    this module (<c>file</c>) for reading and writing data as the interfaces  	    provided here work with byte-oriented data. Using other (Unicode)  	    encodings makes the -	    <seealso marker="stdlib:io"><c>stdlib:io(3)</c></seealso> functions +	    <seealso marker="stdlib:io"><c>io(3)</c></seealso> functions  	    <c>get_chars</c>, <c>get_line</c>, and <c>put_chars</c> more suitable,  	    as they can work with the full Unicode range.</p>  	    <p>If data is sent to an <c>io_device()</c> in a format that cannot be @@ -847,7 +847,7 @@ f.txt:  {person, "kalle", 25}.  	    that is,  	    <seealso marker="#read/2"><c>read/2</c></seealso> are  	    returned "as is". If module -	    <seealso marker="stdlib:io"><c>stdlib:io(3)</c></seealso> is used for +	    <seealso marker="stdlib:io"><c>io(3)</c></seealso> is used for  	    writing, the file can only cope with Unicode characters up to code point  	    255 (the ISO Latin-1 range).</p>  	    </item> @@ -861,7 +861,7 @@ f.txt:  {person, "kalle", 25}.  	    the file lies beyond the ISO Latin-1 range (0..255), but failure occurs  	    if the data contains Unicode code points beyond that range. The file is  	    best read with the functions in the Unicode aware module -	    <seealso marker="stdlib:io"><c>stdlib:io(3)</c></seealso>.</p> +	    <seealso marker="stdlib:io"><c>io(3)</c></seealso>.</p>  	    <p>Bytes written to the file by any means are translated to UTF-8 encoding  	    before being stored on the disk file.</p>  	    </item> @@ -891,7 +891,7 @@ f.txt:  {person, "kalle", 25}.  	    So a file can be analyzed in latin1 encoding for, for example, a BOM,  	    positioned beyond the BOM and then be set for the right encoding before  	    further reading. For functions identifying BOMs, see module -	    <seealso marker="stdlib:unicode"><c>stdlib:unicode(3)</c></seealso>. </p> +	    <seealso marker="stdlib:unicode"><c>unicode(3)</c></seealso>. </p>  	    <p>This option is not allowed on <c>raw</c> files.</p>            </item>            <tag><c>ram</c></tag> @@ -932,7 +932,7 @@ f.txt:  {person, "kalle", 25}.            closed and the process itself is terminated.            An <c><anno>IoDevice</anno></c> returned from this call can be used            as an argument to the I/O functions (see -          <seealso marker="stdlib:io"><c>stdlib:io(3)</c></seealso>).</p> +          <seealso marker="stdlib:io"><c>io(3)</c></seealso>).</p>          <note>            <p>In previous versions of <c>file</c>, modes were specified              as one of the atoms <c>read</c>, <c>write</c>, or @@ -1055,7 +1055,7 @@ f.txt:  {person, "kalle", 25}.          </taglist>          <p>The encoding of <c><anno>Filename</anno></c> can be set            by a comment as described in -	  <seealso marker="stdlib:epp#encoding"><c>stdlib:epp(3)</c></seealso>.</p> +	  <seealso marker="stdlib:epp#encoding"><c>epp(3)</c></seealso>.</p>        </desc>      </func>      <func> @@ -1128,7 +1128,7 @@ f.txt:  {person, "kalle", 25}.          </taglist>          <p>The encoding of <c><anno>Filename</anno></c> can be set            by a comment as described in -	  <seealso marker="stdlib:epp#encoding"><c>stdlib:epp(3)</c></seealso>.</p> +	  <seealso marker="stdlib:epp#encoding"><c>epp(3)</c></seealso>.</p>     </desc>      </func>      <func> @@ -1389,7 +1389,7 @@ f.txt:  {person, "kalle", 25}.            <c>{ok, <anno>FileInfo</anno>}</c> if successful, otherwise            <c>{error, <anno>Reason</anno>}</c>. <c><anno>FileInfo</anno></c>            is a record -          <c>file_info</c>, defined in the <c>Kernel</c> include file +          <c>file_info</c>, defined in the Kernel include file            <c>file.hrl</c>. Include the following directive in the module            from which the function is called:</p>          <code type="none"> @@ -1552,7 +1552,7 @@ f.txt:  {person, "kalle", 25}.  	  raw line-oriented reading.</p>  	  <p>If <c>encoding</c> is set to something else than <c>latin1</c>, the  	  <c>read_line/1</c> call fails if the data contains characters larger than 255, -	  why module <seealso marker="stdlib:io"><c>stdlib:io(3)</c></seealso> is to be +	  why module <seealso marker="stdlib:io"><c>io(3)</c></seealso> is to be  	  preferred when reading such a file.</p>  	  <p>The function returns:</p>          <taglist> @@ -1970,7 +1970,7 @@ f.txt:  {person, "kalle", 25}.          <p>Changes file information. Returns <c>ok</c> if successful,            otherwise <c>{error, <anno>Reason</anno>}</c>.            <c><anno>FileInfo</anno></c> is a record -          <c>file_info</c>, defined in the <c>Kernel</c> include file +          <c>file_info</c>, defined in the Kernel include file            <c>file.hrl</c>. Include the following directive in the module            from which the function is called:</p>          <code type="none"> diff --git a/lib/kernel/doc/src/gen_tcp.xml b/lib/kernel/doc/src/gen_tcp.xml index 83242c2df8..08454b9832 100644 --- a/lib/kernel/doc/src/gen_tcp.xml +++ b/lib/kernel/doc/src/gen_tcp.xml @@ -216,7 +216,7 @@ do_recv(Sock, Bs) ->            time-out in milliseconds. Defaults to <c>infinity</c>.</p>          <note>            <p>The default values for options specified to <c>connect</c> can -            be affected by the <c>Kernel</c> configuration parameter +            be affected by the Kernel configuration parameter              <c>inet_default_connect_options</c>. For details, see              <seealso marker="inet"><c>inet(3)</c></seealso>.</p>          </note> @@ -293,7 +293,7 @@ do_recv(Sock, Bs) ->            <seealso marker="#accept/1"><c>accept/1,2</c></seealso>.</p>          <note>            <p>The default values for options specified to <c>listen</c> can -            be affected by the <c>Kernel</c> configuration parameter +            be affected by the Kernel configuration parameter              <c>inet_default_listen_options</c>. For details, see              <seealso marker="inet"><c>inet(3)</c></seealso>.</p>          </note> @@ -307,7 +307,7 @@ do_recv(Sock, Bs) ->        <type_desc variable="HttpPacket">See the description of          <c>HttpPacket</c> in          <seealso marker="erts:erlang#decode_packet/3"><c>erlang:decode_packet/3</c></seealso> -      in <c>ERTS</c>. +      in ERTS.        </type_desc>        <desc>          <p>Receives a packet from a socket in passive diff --git a/lib/kernel/doc/src/heart.xml b/lib/kernel/doc/src/heart.xml index 864f8facac..59a046bf4d 100644 --- a/lib/kernel/doc/src/heart.xml +++ b/lib/kernel/doc/src/heart.xml @@ -83,7 +83,7 @@        <c><![CDATA[SIGKILL]]></c>:</p>      <pre>  % <input>erl -heart -env HEART_KILL_SIGNAL SIGABRT ...</input></pre> -  <p> If heart should <b>not</b> kill the Erlang runtime system, this can be indicated +  <p> If heart should <em>not</em> kill the Erlang runtime system, this can be indicated        using the environment variable <c><![CDATA[HEART_NO_KILL=TRUE]]></c>.        This can be useful if the command executed by heart takes care of this,        for example as part of a specific cleanup sequence.  diff --git a/lib/kernel/doc/src/inet.xml b/lib/kernel/doc/src/inet.xml index 8cc21bf3e2..d907cef7d3 100644 --- a/lib/kernel/doc/src/inet.xml +++ b/lib/kernel/doc/src/inet.xml @@ -36,7 +36,7 @@        <seealso marker="erts:inet_cfg">ERTS User's Guide:        Inet Configuration</seealso> for more information about how to        configure an Erlang runtime system for IP communication.</p> -    <p>The following two <c>Kernel</c> configuration parameters affect the +    <p>The following two Kernel configuration parameters affect the        behavior of all sockets opened on an Erlang node:</p>      <list type="bulleted">        <item><p><c>inet_default_connect_options</c> can contain a list of @@ -48,7 +48,7 @@      <p>When <c>accept</c> is issued, the values of the listening socket options        are inherited. No such application variable is therefore needed for        <c>accept</c>.</p> -    <p>Using the <c>Kernel</c> configuration parameters above, one +    <p>Using the Kernel configuration parameters above, one        can set default options for all TCP sockets on a node, but use this        with care. Options such as <c>{delay_send,true}</c> can be        specified in this way. The following is an example of starting an Erlang @@ -95,7 +95,7 @@ fe80::204:acff:fe17:bf38      <datatype>        <name name="hostent"/>        <desc> -        <p>The record is defined in the <c>Kernel</c> include file +        <p>The record is defined in the Kernel include file            <c>"inet.hrl"</c>.</p>          <p>Add the following directive to the module:</p>          <code> @@ -391,7 +391,7 @@ get_tcpi_sacked(Sock) ->      <<_:28/binary,TcpiSacked:32/native,_/binary>> = Info,      TcpiSacked.]]></code>          <p>Preferably, you would check the machine type, the operating system, -          and the <c>Kernel</c> version before executing anything similar to +          and the Kernel version before executing anything similar to            this code.</p>        </desc>      </func> @@ -661,7 +661,7 @@ get_tcpi_sacked(Sock) ->              <p>The size of the user-level software buffer used by                the driver. Not to be confused with options <c>sndbuf</c>                and <c>recbuf</c>, which correspond to the -              <c>Kernel</c> socket buffers. It is recommended +              Kernel socket buffers. It is recommended                to have <c>val(buffer) >= max(val(sndbuf),val(recbuf))</c> to                avoid performance issues because of unnecessary copying.                <c>val(buffer)</c> is automatically set to the above @@ -720,7 +720,7 @@ get_tcpi_sacked(Sock) ->  	    <p>The socket message queue is set to a busy  	      state when the amount of data on the message  	      queue reaches this limit. Notice that this limit only -	      concerns data that has not yet reached the <c>ERTS</c> internal +	      concerns data that has not yet reached the ERTS internal  	      socket implementation. Defaults to 8 kB.</p>  	    <p>Senders of data to the socket are suspended if  	      either the socket message queue is busy or the socket @@ -736,7 +736,7 @@ get_tcpi_sacked(Sock) ->            <tag><c>{high_watermark, Size}</c> (TCP/IP sockets)</tag>            <item>  	    <p>The socket is set to a busy state when the amount -	      of data queued internally by the <c>ERTS</c> socket implementation +	      of data queued internally by the ERTS socket implementation  	      reaches this limit. Defaults to 8 kB.</p>  	    <p>Senders of data to the socket are suspended if  	      either the socket message queue is busy or the socket @@ -816,7 +816,7 @@ get_tcpi_sacked(Sock) ->  	      socket message queue is set in a not busy state when  	      the amount of data queued in the message queue falls  	      below this limit. Notice that this limit only concerns data -	      that has not yet reached the <c>ERTS</c> internal socket +	      that has not yet reached the ERTS internal socket  	      implementation. Defaults to 4 kB.</p>  	    <p>Senders that are suspended because of either a  	      busy message queue or a busy socket are resumed @@ -834,7 +834,7 @@ get_tcpi_sacked(Sock) ->            <item>  	    <p>If the socket is in a busy state, the socket is  	      set in a not busy state when the amount of data -	      queued internally by the <c>ERTS</c> socket implementation +	      queued internally by the ERTS socket implementation  	      falls below this limit. Defaults to 4 kB.</p>  	    <p>Senders that are suspended because of a  	      busy message queue or a busy socket are resumed @@ -954,7 +954,7 @@ setcap cap_sys_admin,cap_sys_ptrace,cap_dac_read_search+epi beam.smp</code>                   are returned with the format according to <c>HttpPacket</c>                   described in                   <seealso marker="erts:erlang#decode_packet/3"> -                 <c>erlang:decode_packet/3</c></seealso> in <c>ERTS</c>. +                 <c>erlang:decode_packet/3</c></seealso> in ERTS.                   A socket in passive                   mode returns <c>{ok, HttpPacket}</c> from <c>gen_tcp:recv</c>                   while an active socket sends messages like @@ -1092,6 +1092,15 @@ setcap cap_sys_admin,cap_sys_ptrace,cap_dac_read_search+epi beam.smp</code>                The option is ignored on platforms where it is not                implemented. Use with caution.</p>            </item> +          <tag><c>{tclass, Integer}</c></tag> +          <item> +            <p> +	      Sets <c>IPV6_TCLASS IP</c> level options on platforms +	      where this is implemented. The behavior and allowed range +	      varies between different systems. +              The option is ignored on platforms where it is not +              implemented. Use with caution.</p> +          </item>          </taglist>          <p>In addition to these options, <em>raw</em>            option specifications can be used. The raw options are @@ -1130,7 +1139,7 @@ inet:setopts(Sock,[{raw,6,8,<<30:32/native>>}]),]]></code>            can respond differently to this kind of option            manipulation. Use with care.</p>          <p>Notice that the default options for TCP/IP sockets can be -          changed with the <c>Kernel</c> configuration parameters mentioned in +          changed with the Kernel configuration parameters mentioned in            the beginning of this manual page.</p>        </desc>      </func> diff --git a/lib/kernel/doc/src/init_stub.xml b/lib/kernel/doc/src/init_stub.xml index df89b174ca..1297c8264d 100644 --- a/lib/kernel/doc/src/init_stub.xml +++ b/lib/kernel/doc/src/init_stub.xml @@ -34,6 +34,6 @@    <modulesummary>Coordination of system startup.</modulesummary>    <description>    <p>This module is moved to the -    <seealso marker="erts:init"><c>ERTS</c></seealso> application.</p> +    <seealso marker="erts:init">ERTS</seealso> application.</p>    </description>  </erlref> diff --git a/lib/kernel/doc/src/kernel_app.xml b/lib/kernel/doc/src/kernel_app.xml index dc0291babe..df681a505f 100644 --- a/lib/kernel/doc/src/kernel_app.xml +++ b/lib/kernel/doc/src/kernel_app.xml @@ -31,12 +31,12 @@    <app>kernel</app>    <appsummary>The Kernel application.</appsummary>    <description> -    <p>The <c>Kernel</c> application has all the code necessary to run +    <p>The Kernel application has all the code necessary to run        the Erlang runtime system: file servers, code servers,        and so on.</p> -    <p>The <c>Kernel</c> application is the first application started. It is +    <p>The Kernel application is the first application started. It is        mandatory in the sense that the minimal system based on -      Erlang/OTP consists of <c>Kernel</c> and <c>STDLIB</c>. <c>Kernel</c> +      Erlang/OTP consists of Kernel and STDLIB. Kernel        contains the following functional areas:</p>      <list type="bulleted">        <item>Start, stop, supervision, configuration, and distribution of applications</item> @@ -53,13 +53,13 @@    <section>      <title>Error Logger Event Handlers</title>      <p>Two standard error logger event handlers are defined in -      the <c>Kernel</c> application. These are described in +      the Kernel application. These are described in        <seealso marker="error_logger"><c>error_logger(3)</c></seealso>.</p>    </section>    <section>      <title>Configuration</title> -    <p>The following configuration parameters are defined for the <c>Kernel</c> +    <p>The following configuration parameters are defined for the Kernel        application. For more information about configuration parameters,      see file <seealso marker="app"><c>app(4)</c></seealso>.</p>      <taglist> @@ -162,8 +162,8 @@          depth to which terms are printed by the error logger event          handlers included in OTP. This          configuration parameter is used by the two event handlers -        defined by the <c>Kernel</c> application and the two event -        handlers in the <c>SASL</c> application. +        defined by the Kernel application and the two event +        handlers in the SASL application.  	(If you have implemented your own error handlers, this configuration  	parameter has no effect on them.)</p> @@ -173,7 +173,7 @@  	<c>~P</c> and <c>~W</c>, respectively, and <c>Depth</c> is  	used as the depth parameter. For details, see  	<seealso marker="stdlib:io#format/2"><c>io:format/2</c></seealso> -	in <c>STDLIB</c>.</p> +	in STDLIB.</p>  	<note><p>A reasonable starting value for <c>Depth</c> is  	<c>30</c>. We recommend to test crashing various processes in your @@ -215,16 +215,16 @@          <p>Defines the <c>First..Last</c> port range for the listener            socket of a distributed Erlang node.</p>        </item> -      <marker id="inet_dist_listen_options"></marker>        <tag><c>{inet_dist_listen_options, Opts}</c></tag>        <item> +	<marker id="inet_dist_listen_options"></marker>          <p>Defines a list of extra socket options to be used when opening the  	  listening socket for a distributed Erlang node.  	  See <seealso marker="gen_tcp#listen/2"><c>gen_tcp:listen/2</c></seealso>.</p>        </item> -      <marker id="inet_dist_connect_options"></marker>        <tag><c>{inet_dist_connect_options, Opts}</c></tag>        <item> +	<marker id="inet_dist_connect_options"></marker>          <p>Defines a list of extra socket options to be used when connecting to  	  other distributed Erlang nodes.  	  See <seealso marker="gen_tcp#connect/4"><c>gen_tcp:connect/4</c></seealso>.</p> @@ -241,7 +241,7 @@          <p>The name (string) of an Inet user configuration file. For details,  	see section  	<seealso marker="erts:inet_cfg"><c>Inet Configuration</c></seealso> -	in the <c>ERTS</c> User's Guide.</p> +	in the ERTS User's Guide.</p>        </item>        <tag><c>net_setuptime = SetupTime</c></tag>        <item> @@ -360,7 +360,7 @@ MaxT = TickTime + TickTime / 4</code>        <tag><c>start_timer = true | false</c></tag>        <item>          <p>Starts the <c>timer_server</c> if the parameter is -          <c>true</c> (see <seealso marker="stdlib:timer"><c>stdlib:timer(3)</c></seealso>). +          <c>true</c> (see <seealso marker="stdlib:timer"><c>timer(3)</c></seealso>).  	  This parameter is to be set to <c>true</c> in an embedded system  	  using this service.</p>          <p>Defaults to <c>false</c>.</p> diff --git a/lib/kernel/doc/src/net_kernel.xml b/lib/kernel/doc/src/net_kernel.xml index 3c1b3d5190..4e2b0c69db 100644 --- a/lib/kernel/doc/src/net_kernel.xml +++ b/lib/kernel/doc/src/net_kernel.xml @@ -55,7 +55,7 @@ $ <input>erl -sname foobar</input></pre>        <seealso marker="erts:erl"><c>erl</c></seealso>.</p>      <p>Normally, connections are established automatically when        another node is referenced. This functionality can be disabled -      by setting <c>Kernel</c> configuration parameter +      by setting Kernel configuration parameter        <c>dist_auto_connect</c> to <c>false</c>, see        <seealso marker="kernel_app"><c>kernel(6)</c></seealso>. In this case,        connections must be established explicitly by calling @@ -146,7 +146,7 @@ $ <input>erl -sname foobar</input></pre>            are stopped. Two            option lists are considered the same if they contain the same            set of options.</p> -        <p>As from <c>Kernel</c> version 2.11.4, and <c>ERTS</c> version +        <p>As from Kernel version 2.11.4, and ERTS version            5.5.4, the following is guaranteed:</p>          <list type="bulleted">            <item><p><c>nodeup</c> messages are delivered before delivery @@ -156,13 +156,13 @@ $ <input>erl -sname foobar</input></pre>              messages from the remote node that have been passed              through the connection have been delivered.</p></item>          </list> -        <p>Notice that this is <em>not</em> guaranteed for <c>Kernel</c> +        <p>Notice that this is <em>not</em> guaranteed for Kernel            versions before 2.11.4.</p> -        <p>As from <c>Kernel</c> version 2.11.4, subscriptions can also be +        <p>As from Kernel version 2.11.4, subscriptions can also be            made before the <c>net_kernel</c> server is started, that is,            <c>net_kernel:monitor_nodes/[1,2]</c> does not return            <c>ignored</c>.</p> -        <p>As from <c>Kernel</c> version 2.13, and <c>ERTS</c> version +        <p>As from Kernel version 2.13, and ERTS version            5.7, the following is guaranteed:</p>          <list type="bulleted">            <item><p><c>nodeup</c> messages are delivered after the @@ -172,7 +172,7 @@ $ <input>erl -sname foobar</input></pre>  	    corresponding node has disappeared in results from  	    <c>erlang:nodes/X</c>.</p></item>          </list> -        <p>Notice that this is <em>not</em> guaranteed for <c>Kernel</c> +        <p>Notice that this is <em>not</em> guaranteed for Kernel            versions before 2.13.</p>          <p>The format of the node status change messages depends on            <c><anno>Options</anno></c>. If <c><anno>Options</anno></c> is diff --git a/lib/kernel/doc/src/notes.xml b/lib/kernel/doc/src/notes.xml index 3d35f6f57f..5bcc0b7c09 100644 --- a/lib/kernel/doc/src/notes.xml +++ b/lib/kernel/doc/src/notes.xml @@ -31,6 +31,74 @@    </header>    <p>This document describes the changes made to the Kernel application.</p> +<section><title>Kernel 5.1</title> + +    <section><title>Fixed Bugs and Malfunctions</title> +      <list> +        <item> +          <p> +	    Fix a memory leak when calling +	    seq_trace:get_system_tracer().</p> +          <p> +	    Own Id: OTP-13742</p> +        </item> +        <item> +          <p> +	    Fix for the problem that when adding the ebin directory +	    of an application to the code path, the +	    <c>code:priv_dir/1</c> function returns an incorrect path +	    to the priv directory of the same application.</p> +          <p> +	    Own Id: OTP-13758 Aux Id: ERL-195 </p> +        </item> +        <item> +          <p> +	    Fix code_server crash when adding code paths of two +	    levels.</p> +          <p> +	    Own Id: OTP-13765 Aux Id: ERL-194 </p> +        </item> +        <item> +          <p> +	    Respect -proto_dist switch while connection to EPMD</p> +          <p> +	    Own Id: OTP-13770 Aux Id: PR-1129 </p> +        </item> +        <item> +          <p> +	    Fixed a bug where init:stop could deadlock if a process +	    with infinite shutdown timeout (e.g. a supervisor) +	    attempted to load code while terminating.</p> +          <p> +	    Own Id: OTP-13802</p> +        </item> +        <item> +          <p> +	    Close stdin of commands run in os:cmd. This is a +	    backwards compatiblity fix that restores the behaviour of +	    pre 19.0 os:cmd.</p> +          <p> +	    Own Id: OTP-13867 Aux Id: seq13178 </p> +        </item> +      </list> +    </section> + + +    <section><title>Improvements and New Features</title> +      <list> +        <item> +          <p> +	    Add <c>net_kernel:setopts/2</c> and +	    <c>net_kernel:getopts/2</c> to control options for +	    distribution sockets in runtime.</p> +          <p> +	    Own Id: OTP-13564</p> +        </item> +      </list> +    </section> + +</section> +  <section><title>Kernel 5.0.2</title>      <section><title>Fixed Bugs and Malfunctions</title> @@ -3482,7 +3550,7 @@  	    types (for instance, <c>ensure_loaded/1</c> now only  	    accepts an atom as documented; it used to accept a string  	    too).</p> -	    <p><c>Dialyzer</c> will generally emit warnings for any +	    <p>Dialyzer will generally emit warnings for any  	    calls that use undocumented argument types. Even if the  	    call happens to still work in R12B, you should correct  	    your code. A future release will adhere to the diff --git a/lib/kernel/doc/src/rpc.xml b/lib/kernel/doc/src/rpc.xml index 8cad9fe4fc..5944e9321a 100644 --- a/lib/kernel/doc/src/rpc.xml +++ b/lib/kernel/doc/src/rpc.xml @@ -320,7 +320,7 @@        <fsummary>Information about a process.</fsummary>        <desc>          <p>Location transparent version of the BIF -          <seealso marker="erts:erlang#process_info/1"><c>erlang:process_info/1</c></seealso> in <c>ERTS</c>.</p> +          <seealso marker="erts:erlang#process_info/1"><c>erlang:process_info/1</c></seealso> in ERTS.</p>        </desc>      </func> @@ -330,7 +330,7 @@        <fsummary>Information about a process.</fsummary>        <desc>          <p>Location transparent version of the BIF -          <seealso marker="erts:erlang#process_info/2"><c>erlang:process_info/2</c></seealso> in <c>ERTS</c>.</p> +          <seealso marker="erts:erlang#process_info/2"><c>erlang:process_info/2</c></seealso> in ERTS.</p>        </desc>      </func> diff --git a/lib/kernel/doc/src/zlib_stub.xml b/lib/kernel/doc/src/zlib_stub.xml index b111581b10..9ab9c4eb62 100644 --- a/lib/kernel/doc/src/zlib_stub.xml +++ b/lib/kernel/doc/src/zlib_stub.xml @@ -34,6 +34,6 @@    <modulesummary>Zlib compression interface.</modulesummary>    <description>    <p>This module is moved to the -    <seealso marker="erts:zlib"><c>ERTS</c></seealso> application.</p> +    <seealso marker="erts:zlib">ERTS</seealso> application.</p>    </description>  </erlref> diff --git a/lib/kernel/src/code_server.erl b/lib/kernel/src/code_server.erl index 48541ec500..59b26176bf 100644 --- a/lib/kernel/src/code_server.erl +++ b/lib/kernel/src/code_server.erl @@ -811,7 +811,13 @@ clear_namedb([], _) ->  %% Dir must be a complete pathname (not only a name).  insert_dir(Dir, Db) ->      Splitted = filename:split(Dir), -    Name = get_name_from_splitted(Splitted), +    case get_name_from_splitted(Splitted) of +	Name when Name /= "ebin", Name /= "." -> +	    Name; +	_ -> +	    SplittedAbsName = filename:split(absname(Dir)), +	    Name = get_name_from_splitted(SplittedAbsName) +    end,      AppDir = filename:join(del_ebin_1(Splitted)),      do_insert_name(Name, AppDir, Db). @@ -952,6 +958,10 @@ del_ebin_1([Parent,App,"ebin"]) ->  		    [Archive]  	    end      end; +del_ebin_1(Path = [_App,"ebin"]) -> +    del_ebin_1(filename:split(absname(filename:join(Path)))); +del_ebin_1(["ebin"]) -> +    del_ebin_1(filename:split(absname("ebin")));  del_ebin_1([H|T]) ->      [H|del_ebin_1(T)];  del_ebin_1([]) -> @@ -1382,11 +1392,10 @@ finish_on_load(PidRef, OnLoadRes, #state{on_load=OnLoad0}=St0) ->  finish_on_load_1(Mod, OnLoadRes, Waiting, St) ->      Keep = OnLoadRes =:= ok, -    erlang:finish_after_on_load(Mod, Keep), +    erts_code_purger:finish_after_on_load(Mod, Keep),      Res = case Keep of  	      false ->  		  _ = finish_on_load_report(Mod, OnLoadRes), -		  _ = erts_code_purger:purge(Mod),  		  {error,on_load_failure};  	      true ->  		  {module,Mod} diff --git a/lib/kernel/src/inet.erl b/lib/kernel/src/inet.erl index 75dd800c6b..f5c13ecdd7 100644 --- a/lib/kernel/src/inet.erl +++ b/lib/kernel/src/inet.erl @@ -677,7 +677,7 @@ parse_strict_address(Addr) ->  %% Return a list of available options  options() ->      [ -     tos, priority, reuseaddr, keepalive, dontroute, linger, +     tos, tclass, priority, reuseaddr, keepalive, dontroute, linger,       broadcast, sndbuf, recbuf, nodelay, ipv6_v6only,       buffer, header, active, packet, deliver, mode,       multicast_if, multicast_ttl, multicast_loop, @@ -698,7 +698,7 @@ stats() ->  %% Available options for tcp:connect  %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%  connect_options() -> -    [tos, priority, reuseaddr, keepalive, linger, sndbuf, recbuf, nodelay, +    [tos, tclass, priority, reuseaddr, keepalive, linger, sndbuf, recbuf, nodelay,       header, active, packet, packet_size, buffer, mode, deliver, line_delimiter,       exit_on_close, high_watermark, low_watermark, high_msgq_watermark,       low_msgq_watermark, send_timeout, send_timeout_close, delay_send, raw, @@ -766,7 +766,7 @@ con_add(Name, Val, #connect_opts{} = R, Opts, AllOpts) ->  %% Available options for tcp:listen  %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%  listen_options() -> -    [tos, priority, reuseaddr, keepalive, linger, sndbuf, recbuf, nodelay, +    [tos, tclass, priority, reuseaddr, keepalive, linger, sndbuf, recbuf, nodelay,       header, active, packet, buffer, mode, deliver, backlog, ipv6_v6only,       exit_on_close, high_watermark, low_watermark, high_msgq_watermark,       low_msgq_watermark, send_timeout, send_timeout_close, delay_send, @@ -846,7 +846,7 @@ tcp_module_1(Opts, Address) ->  %% Available options for udp:open  %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%  udp_options() -> -    [tos, priority, reuseaddr, sndbuf, recbuf, header, active, buffer, mode,  +    [tos, tclass, priority, reuseaddr, sndbuf, recbuf, header, active, buffer, mode,       deliver, ipv6_v6only,       broadcast, dontroute, multicast_if, multicast_ttl, multicast_loop,       add_membership, drop_membership, read_packets,raw, @@ -917,7 +917,7 @@ udp_module(Opts) ->  %  (*) passing of open FDs ("fdopen") is not supported.  sctp_options() ->  [   % The following are generic inet options supported for SCTP sockets: -    mode, active, buffer, tos, priority, dontroute, reuseaddr, linger, sndbuf, +    mode, active, buffer, tos, tclass, priority, dontroute, reuseaddr, linger, sndbuf,      recbuf, ipv6_v6only, high_msgq_watermark, low_msgq_watermark,      % Other options are SCTP-specific (though they may be similar to their diff --git a/lib/kernel/src/inet_int.hrl b/lib/kernel/src/inet_int.hrl index c8a8962e78..4e8f59a3b9 100644 --- a/lib/kernel/src/inet_int.hrl +++ b/lib/kernel/src/inet_int.hrl @@ -153,6 +153,7 @@  -define(INET_LOPT_NETNS,          38).  -define(INET_LOPT_TCP_SHOW_ECONNRESET, 39).  -define(INET_LOPT_LINE_DELIM,     40). +-define(INET_OPT_TCLASS,          41).  % Specific SCTP options: separate range:  -define(SCTP_OPT_RTOINFO,	 	100).  -define(SCTP_OPT_ASSOCINFO,	 	101). diff --git a/lib/kernel/src/kernel.appup.src b/lib/kernel/src/kernel.appup.src index d16e200cb3..82cf73cbda 100644 --- a/lib/kernel/src/kernel.appup.src +++ b/lib/kernel/src/kernel.appup.src @@ -18,9 +18,9 @@  %% %CopyrightEnd%  {"%VSN%",   %% Up from - max one major revision back - [{<<"5\\.0(\\.[0-9]+)*">>,[restart_new_emulator]},       % OTP-19.* + [{<<"5\\.[0-1](\\.[0-9]+)*">>,[restart_new_emulator]},   % OTP-19.*    {<<"4\\.[0-2](\\.[0-9]+)*">>,[restart_new_emulator]}],  % OTP-18.*   %% Down to - max one major revision back - [{<<"5\\.0(\\.[0-9]+)*">>,[restart_new_emulator]},      % OTP-19.* + [{<<"5\\.[0-1](\\.[0-9]+)*">>,[restart_new_emulator]},  % OTP-19.*    {<<"4\\.[0-2](\\.[0-9]+)*">>,[restart_new_emulator]}]  % OTP-18.*  }. diff --git a/lib/kernel/src/os.erl b/lib/kernel/src/os.erl index 05bbf1069e..f8519d3a5e 100644 --- a/lib/kernel/src/os.erl +++ b/lib/kernel/src/os.erl @@ -254,7 +254,19 @@ mk_cmd(_,Cmd) ->      {"/bin/sh -s unix:cmd", [out],       %% We insert a new line after the command, in case the command       %% contains a comment character. -     ["(", unicode:characters_to_binary(Cmd), "\n); echo \"\^D\"\n"], +     %% +     %% The </dev/null closes stdin, which means that programs +     %% that use a closed stdin as an termination indicator works. +     %% An example of such a program is 'more'. +     %% +     %% The "echo ^D" is used to indicate that the program has executed +     %% and we should return any output we have gotten. We cannot use +     %% termination of the child or closing of stdin/stdout as then +     %% starting background jobs from os:cmd will block os:cmd. +     %% +     %% I tried changing this to be "better", but got bombarded with +     %% backwards incompatibility bug reports, so leave this as it is. +     ["(", unicode:characters_to_binary(Cmd), "\n) </dev/null; echo \"\^D\"\n"],       <<$\^D>>}.  validate(Atom) when is_atom(Atom) -> diff --git a/lib/kernel/test/code_SUITE.erl b/lib/kernel/test/code_SUITE.erl index 8da67c89f8..c5167efa56 100644 --- a/lib/kernel/test/code_SUITE.erl +++ b/lib/kernel/test/code_SUITE.erl @@ -36,6 +36,7 @@  	 code_archive/1, code_archive2/1, on_load/1, on_load_binary/1,  	 on_load_embedded/1, on_load_errors/1, on_load_update/1,  	 on_load_purge/1, on_load_self_call/1, on_load_pending/1, +	 on_load_deleted/1,  	 big_boot_embedded/1,  	 native_early_modules/1, get_mode/1,  	 normalized_paths/1]). @@ -66,6 +67,7 @@ all() ->       bad_erl_libs, code_archive, code_archive2, on_load,       on_load_binary, on_load_embedded, on_load_errors, on_load_update,       on_load_purge, on_load_self_call, on_load_pending, +     on_load_deleted,       big_boot_embedded, native_early_modules, get_mode, normalized_paths].  groups() -> @@ -1602,6 +1604,98 @@ on_load_pending(_Config) ->      ok = Mod:t(),      ok. +on_load_deleted(_Config) -> +    Mod = ?FUNCTION_NAME, + +    R0 = fun() -> +		 Tree = ?Q(["-module('@Mod@').\n", +			    "-on_load(f/0).\n", +			    "f() -> ok.\n"]), +		 merl:print(Tree), +		 {ok,Mod,Code} = merl:compile(Tree), +		 {module,Mod} = code:load_binary(Mod, "", Code) +	 end, +    delete_before_reload(Mod, R0), +    delete_before_reload(Mod, R0), + +    R1 = fun() -> +		 Tree = ?Q(["-module('@Mod@').\n", +			    "-on_load(f/0).\n", +			    "f() -> fail.\n"]), +		 merl:print(Tree), +		 {ok,Mod,Code} = merl:compile(Tree), +		 {error,on_load_failure} = code:load_binary(Mod, "", Code) +	 end, +    delete_before_reload(Mod, R1), +    delete_before_reload(Mod, R1), + +    OtherMod = list_to_atom(lists:concat([Mod,"_42"])), +    OtherTree = ?Q(["-module('@OtherMod@').\n"]), +    merl:print(OtherTree), +    {ok,OtherMod,OtherCode} = merl:compile(OtherTree), + +    R2 = fun() -> +		 RegName = 'on_load__registered_name', +		 Tree = ?Q(["-module('@Mod@').\n", +			    "-on_load(f/0).\n", +			    "f() ->\n", +			    "  register('@RegName@', self()),\n", +			    "  receive _ -> ok end.\n"]), +		 merl:print(Tree), +		 {ok,Mod,Code} = merl:compile(Tree), +		 spawn(fun() -> +			       {module,Mod} = code:load_binary(Mod, "", Code) +		       end), +		 receive after 1 -> ok end, +		 {module,OtherMod} = code:load_binary(OtherMod, "", +						      OtherCode), +		 RegName ! stop +	 end, +    delete_before_reload(Mod, R2), + +    ok. + +delete_before_reload(Mod, Reload) -> +    false = check_old_code(Mod), + +    Tree1 = ?Q(["-module('@Mod@').\n", +		"-export([f/1]).\n", +		"f(Parent) ->\n", +		"  register('@Mod@', self()),\n", +		"  Parent ! started,\n", +		"  receive _ -> ok end.\n"]), +    merl:print(Tree1), +    {ok,Mod,Code1} = merl:compile(Tree1), + +    Self = self(), +    spawn(fun() -> +		  {module,Mod} = code:load_binary(Mod, "", Code1), +		  Mod:f(Self) +	  end), +    receive started -> ok end, + +    true = code:delete(Mod), +    true = check_old_code(Mod), + +    Reload(), + +    %% When loading the the module with the -on_load() function, +    %% the reference to the old code would be lost. Make sure that +    %% the old code is remembered and is still preventing the +    %% purge. +    false = code:soft_purge(Mod), + +    %% Get rid of the old code. +    Mod ! stop, +    receive after 1 -> ok end, +    true = code:soft_purge(Mod), + +    %% Unload the version of the module with the -on_load() function. +    true = code:delete(Mod), +    true = code:soft_purge(Mod), + +    ok. +  %% Test that the native code of early loaded modules is loaded.  native_early_modules(Config) when is_list(Config) -> diff --git a/lib/kernel/test/file_SUITE.erl b/lib/kernel/test/file_SUITE.erl index 5f049c6f99..c37d114a58 100644 --- a/lib/kernel/test/file_SUITE.erl +++ b/lib/kernel/test/file_SUITE.erl @@ -493,22 +493,13 @@ read_write_file(Config) when is_list(Config) ->      %% Try writing and reading back some term      SomeTerm = {"This term",{will,be},[written,$t,$o],1,file,[]}, -    ok = ?FILE_MODULE:write_file(Name,term_to_binary(SomeTerm)), -    {ok,Bin1} = ?FILE_MODULE:read_file(Name), -    SomeTerm = binary_to_term(Bin1), +    Bin1 = term_to_binary(SomeTerm), +    ok = do_read_write_file(Name, Bin1),      %% Try a "null" term      NullTerm = [], -    ok = ?FILE_MODULE:write_file(Name,term_to_binary(NullTerm)), -    {ok,Bin2} = ?FILE_MODULE:read_file(Name), -    NullTerm = binary_to_term(Bin2), - -    %% Try some "complicated" types -    BigNum = 123456789012345678901234567890, -    ComplTerm = {self(),make_ref(),BigNum,3.14159}, -    ok = ?FILE_MODULE:write_file(Name,term_to_binary(ComplTerm)), -    {ok,Bin3} = ?FILE_MODULE:read_file(Name), -    ComplTerm = binary_to_term(Bin3), +    Bin2 = term_to_binary(NullTerm), +    ok = do_read_write_file(Name, Bin2),      %% Try reading a nonexistent file      Name2 = filename:join(RootDir, @@ -519,25 +510,42 @@ read_write_file(Config) when is_list(Config) ->      {error, enoent} = ?FILE_MODULE:read_file(''),      %% Try writing to a bad filename -    {error, enoent} = -	?FILE_MODULE:write_file("",term_to_binary(NullTerm)), +    {error, enoent} = do_read_write_file("", Bin2),      %% Try writing something else than a binary -    {error, badarg} = ?FILE_MODULE:write_file(Name,{1,2,3}), -    {error, badarg} = ?FILE_MODULE:write_file(Name,self()), +    {error, badarg} = do_read_write_file(Name, {1,2,3}), +    {error, badarg} = do_read_write_file(Name, self()),      %% Some non-term binaries -    ok = ?FILE_MODULE:write_file(Name,[]), -    {ok,Bin4} = ?FILE_MODULE:read_file(Name), -    0 = byte_size(Bin4), +    ok = do_read_write_file(Name, []), -    ok = ?FILE_MODULE:write_file(Name,[Bin1,[],[[Bin2]]]), -    {ok,Bin5} = ?FILE_MODULE:read_file(Name), -    {Bin1,Bin2} = split_binary(Bin5,byte_size(Bin1)), +    %% Write some iolists +    ok = do_read_write_file(Name, [Bin1,[],[[Bin2]]]), +    ok = do_read_write_file(Name, ["string",<<"binary">>]), +    ok = do_read_write_file(Name, "pure string"),      [] = flush(),      ok. +do_read_write_file(Name, Data) -> +    case ?FILE_MODULE:write_file(Name, Data) of +	ok -> +	    BinData = iolist_to_binary(Data), +	    {ok,BinData} = ?FILE_MODULE:read_file(Name), + +	    ok = ?FILE_MODULE:write_file(Name, Data, []), +	    {ok,BinData} = ?FILE_MODULE:read_file(Name), + +	    ok = ?FILE_MODULE:write_file(Name, Data, [raw]), +	    {ok,BinData} = ?FILE_MODULE:read_file(Name), + +	    ok; +	{error,_}=Res -> +	    Res = ?FILE_MODULE:write_file(Name, Data, []), +	    Res = ?FILE_MODULE:write_file(Name, Data, [raw]), +	    Res +    end. +  %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% diff --git a/lib/kernel/test/gen_tcp_api_SUITE.erl b/lib/kernel/test/gen_tcp_api_SUITE.erl index 77ec89b4f4..92a74465b7 100644 --- a/lib/kernel/test/gen_tcp_api_SUITE.erl +++ b/lib/kernel/test/gen_tcp_api_SUITE.erl @@ -38,7 +38,7 @@  	 t_local_basic/1, t_local_unbound/1, t_local_fdopen/1,  	 t_local_fdopen_listen/1, t_local_fdopen_listen_unbound/1,  	 t_local_fdopen_connect/1, t_local_fdopen_connect_unbound/1, -	 t_local_abstract/1]). +	 t_local_abstract/1, t_accept_inet6_tclass/1]).  -export([getsockfd/0,closesockfd/1]). @@ -50,6 +50,7 @@ all() ->      [{group, t_accept}, {group, t_connect}, {group, t_recv},       t_shutdown_write, t_shutdown_both, t_shutdown_error,       t_shutdown_async, t_fdopen, t_fdconnect, t_implicit_inet6, +     t_accept_inet6_tclass,       {group, t_local}].  groups() ->  @@ -521,6 +522,24 @@ local_handshake(S, SAddr, C, CAddr) ->      SData = ok(gen_tcp:recv(C, length(SData))),      ok. +t_accept_inet6_tclass(Config) when is_list(Config) -> +    TClassOpt = {tclass,8#56 bsl 2}, % Expedited forwarding +    case gen_tcp:listen(0, [inet6,TClassOpt]) of +	{ok,L} -> +	    LPort = ok(inet:port(L)), +	    Loopback = {0,0,0,0,0,0,0,1}, +	    Sa = ok(gen_tcp:connect(Loopback, LPort, [])), +	    Sb = ok(gen_tcp:accept(L)), +	    [TClassOpt] = ok(inet:getopts(Sb, [tclass])), +	    ok = gen_tcp:close(Sb), +	    ok = gen_tcp:close(Sa), +	    ok = gen_tcp:close(L), +	    ok; +	{error,_} -> +	    {skip,"IPv6 TCLASS not supported"} +    end. + +  %%% Utilities  %% Calls M:F/length(A), which should return a timeout error, and complete diff --git a/lib/kernel/test/init_SUITE.erl b/lib/kernel/test/init_SUITE.erl index 1370e23195..2b59eb2bfe 100644 --- a/lib/kernel/test/init_SUITE.erl +++ b/lib/kernel/test/init_SUITE.erl @@ -27,7 +27,8 @@  -export([get_arguments/1, get_argument/1, boot_var/1, restart/1,  	 many_restarts/0, many_restarts/1,  	 get_plain_arguments/1, -	 reboot/1, stop_status/1, stop/1, get_status/1, script_id/1]). +	 reboot/1, stop_status/1, stop/1, get_status/1, script_id/1, +	 find_system_processes/0]).  -export([boot1/1, boot2/1]).  -export([init_per_testcase/2, end_per_testcase/2]). @@ -355,12 +356,16 @@ wait_for(N,Node,EHPid) ->  restart(Config) when is_list(Config) ->      Args = args(), +    Pa = " -pa " ++ filename:dirname(code:which(?MODULE)), +      %% Currently test_server:start_node cannot be used. The restarted      %% node immediately halts due to the implementation of      %% test_server:start_node. -    {ok, Node} = loose_node:start(init_test, Args, ?DEFAULT_TIMEOUT_SEC), +    {ok, Node} = loose_node:start(init_test, Args ++ Pa, ?DEFAULT_TIMEOUT_SEC),      %% Ok, the node is up, now the real test test begins.      erlang:monitor_node(Node, true), +    SysProcs0 = rpc:call(Node, ?MODULE, find_system_processes, []), +    [InitPid, PurgerPid, LitCollectorPid, DirtyCodePid] = SysProcs0,      InitPid = rpc:call(Node, erlang, whereis, [init]),      PurgerPid = rpc:call(Node, erlang, whereis, [erts_code_purger]),      Procs = rpc:call(Node, erlang, processes, []), @@ -375,6 +380,9 @@ restart(Config) when is_list(Config) ->      end,      ok = wait_restart(30, Node), +    SysProcs1 = rpc:call(Node, ?MODULE, find_system_processes, []), +    [InitPid1, PurgerPid1, LitCollectorPid1, DirtyCodePid1] = SysProcs1, +      %% Still the same init process!      InitPid1 = rpc:call(Node, erlang, whereis, [init]),      InitP = pid_to_list(InitPid), @@ -385,8 +393,24 @@ restart(Config) when is_list(Config) ->      PurgerP = pid_to_list(PurgerPid),      PurgerP = pid_to_list(PurgerPid1), +    %% and same literal area collector process! +    case LitCollectorPid of +	undefined -> undefined = LitCollectorPid1; +	_ -> +	    LitCollectorP = pid_to_list(LitCollectorPid), +	    LitCollectorP = pid_to_list(LitCollectorPid1) +    end, + +    %% and same dirty process code checker process! +    case DirtyCodePid of +	undefined -> undefined = DirtyCodePid1; +	_ -> +	    DirtyCodeP = pid_to_list(DirtyCodePid), +	    DirtyCodeP = pid_to_list(DirtyCodePid1) +    end, +      NewProcs0 = rpc:call(Node, erlang, processes, []), -    NewProcs = NewProcs0 -- [InitPid1, PurgerPid1], +    NewProcs = NewProcs0 -- SysProcs1,      case check_processes(NewProcs, MaxPid) of  	true ->  	    ok; @@ -406,6 +430,37 @@ restart(Config) when is_list(Config) ->      loose_node:stop(Node),      ok. +-record(sys_procs, {init, +		    code_purger, +		    literal_collector, +		    dirty_proc_checker}). + +find_system_processes() -> +    find_system_procs(processes(), #sys_procs{}). + +find_system_procs([], SysProcs) -> +    [SysProcs#sys_procs.init, +     SysProcs#sys_procs.code_purger, +     SysProcs#sys_procs.literal_collector, +     SysProcs#sys_procs.dirty_proc_checker]; +find_system_procs([P|Ps], SysProcs) -> +    case process_info(P, initial_call) of +	{initial_call,{otp_ring0,start,2}} -> +	    undefined = SysProcs#sys_procs.init, +	    find_system_procs(Ps, SysProcs#sys_procs{init = P}); +	{initial_call,{erts_code_purger,start,0}} -> +	    undefined = SysProcs#sys_procs.code_purger, +	    find_system_procs(Ps, SysProcs#sys_procs{code_purger = P}); +	{initial_call,{erts_literal_area_collector,start,0}} -> +	    undefined = SysProcs#sys_procs.literal_collector, +	    find_system_procs(Ps, SysProcs#sys_procs{literal_collector = P}); +	{initial_call,{erts_dirty_process_code_checker,start,0}} -> +	    undefined = SysProcs#sys_procs.dirty_proc_checker, +	    find_system_procs(Ps, SysProcs#sys_procs{dirty_proc_checker = P}); +	_ -> +	    find_system_procs(Ps, SysProcs) +    end. +  wait_restart(0, _Node) ->      ct:fail(not_restarted);  wait_restart(N, Node) -> diff --git a/lib/kernel/test/os_SUITE.erl b/lib/kernel/test/os_SUITE.erl index 19ab3713a1..e76d6ec482 100644 --- a/lib/kernel/test/os_SUITE.erl +++ b/lib/kernel/test/os_SUITE.erl @@ -25,7 +25,7 @@  -export([space_in_cwd/1, quoting/1, cmd_unicode/1, space_in_name/1, bad_command/1,  	 find_executable/1, unix_comment_in_command/1, deep_list_command/1,           large_output_command/1, background_command/0, background_command/1, -         message_leak/1, perf_counter_api/1]). +         message_leak/1, close_stdin/0, close_stdin/1, perf_counter_api/1]).  -include_lib("common_test/include/ct.hrl"). @@ -37,7 +37,7 @@ all() ->      [space_in_cwd, quoting, cmd_unicode, space_in_name, bad_command,       find_executable, unix_comment_in_command, deep_list_command,       large_output_command, background_command, message_leak, -     perf_counter_api]. +     close_stdin, perf_counter_api].  groups() ->      []. @@ -54,7 +54,8 @@ init_per_group(_GroupName, Config) ->  end_per_group(_GroupName, Config) ->      Config. -init_per_testcase(background_command, Config) -> +init_per_testcase(TC, Config) +  when TC =:= background_command; TC =:= close_stdin ->      case os:type() of          {win32, _} ->              {skip,"Should not work on windows"}; @@ -294,7 +295,7 @@ message_leak(_Config) ->      case os:type() of          {unix, _} -> -            os:cmd("while true; do echo hello; done&"), +            os:cmd("for i in $(seq 1 100); do echo hello; done&"),              [] = receive_all();          _ ->              ok % Cannot background on non-unix @@ -302,6 +303,16 @@ message_leak(_Config) ->      process_flag(trap_exit, false). +%% Test that os:cmd closes stdin of the program that is executed +close_stdin() -> +    [{timetrap, {seconds, 5}}]. +close_stdin(Config) -> +    DataDir = proplists:get_value(data_dir, Config), +    Fds = filename:join(DataDir, "my_fds"), + +    "-1" = os:cmd(Fds). + +  %% Test that the os:perf_counter api works as expected  perf_counter_api(_Config) -> diff --git a/lib/kernel/test/os_SUITE_data/Makefile.src b/lib/kernel/test/os_SUITE_data/Makefile.src index 912d0cbcb1..f83f781411 100644 --- a/lib/kernel/test/os_SUITE_data/Makefile.src +++ b/lib/kernel/test/os_SUITE_data/Makefile.src @@ -3,7 +3,7 @@ LD = @LD@  CFLAGS = @CFLAGS@ -I@erl_include@ @DEFS@  CROSSLDFLAGS = @CROSSLDFLAGS@ -PROGS = my_echo@exe@ +PROGS = my_echo@exe@ my_fds@exe@  all: $(PROGS) @@ -12,3 +12,9 @@ my_echo@exe@: my_echo@obj@  my_echo@obj@: my_echo.c  	$(CC) -c -o my_echo@obj@ $(CFLAGS) my_echo.c + +my_fds@exe@: my_fds@obj@ +	$(LD) $(CROSSLDFLAGS) -o my_fds my_fds@obj@ @LIBS@ + +my_fds@obj@: my_fds.c +	$(CC) -c -o my_fds@obj@ $(CFLAGS) my_fds.c diff --git a/lib/kernel/test/os_SUITE_data/my_fds.c b/lib/kernel/test/os_SUITE_data/my_fds.c new file mode 100644 index 0000000000..704a4d1e1d --- /dev/null +++ b/lib/kernel/test/os_SUITE_data/my_fds.c @@ -0,0 +1,9 @@ +#include <stdio.h> + +int +main(int argc, char** argv) +{ +    char buff[1]; +    int res = read(stdin, buff, 1); +    printf("%d", res); +} diff --git a/lib/kernel/vsn.mk b/lib/kernel/vsn.mk index cdd200a234..d3b2d18ae5 100644 --- a/lib/kernel/vsn.mk +++ b/lib/kernel/vsn.mk @@ -1 +1 @@ -KERNEL_VSN = 5.0.2 +KERNEL_VSN = 5.1 | 
