diff options
Diffstat (limited to 'lib/kernel/src')
| -rw-r--r-- | lib/kernel/src/Makefile | 14 | ||||
| -rw-r--r-- | lib/kernel/src/code.erl | 13 | ||||
| -rw-r--r-- | lib/kernel/src/code_server.erl | 4 | ||||
| -rw-r--r-- | lib/kernel/src/disk_log.erl | 7 | ||||
| -rw-r--r-- | lib/kernel/src/disk_log.hrl | 4 | ||||
| -rw-r--r-- | lib/kernel/src/file.erl | 2 | ||||
| -rw-r--r-- | lib/kernel/src/gen_sctp.erl | 5 | ||||
| -rw-r--r-- | lib/kernel/src/gen_tcp.erl | 2 | ||||
| -rw-r--r-- | lib/kernel/src/gen_udp.erl | 5 | ||||
| -rw-r--r-- | lib/kernel/src/heart.erl | 4 | ||||
| -rw-r--r-- | lib/kernel/src/hipe_unified_loader.erl | 7 | ||||
| -rw-r--r-- | lib/kernel/src/inet.erl | 46 | ||||
| -rw-r--r-- | lib/kernel/src/rpc.erl | 2 | 
13 files changed, 82 insertions, 33 deletions
| diff --git a/lib/kernel/src/Makefile b/lib/kernel/src/Makefile index 54f21eb2b8..a39864d6b7 100644 --- a/lib/kernel/src/Makefile +++ b/lib/kernel/src/Makefile @@ -198,13 +198,13 @@ $(EBIN)/erl_epmd.beam: $(ESRC)/erl_epmd.erl  include $(ERL_TOP)/make/otp_release_targets.mk  release_spec: opt -	$(INSTALL_DIR) $(RELSYSDIR)/src -	$(INSTALL_DATA) $(ERL_FILES) $(RELSYSDIR)/src -	$(INSTALL_DATA) $(INTERNAL_HRL_FILES) $(RELSYSDIR)/src -	$(INSTALL_DIR) $(RELSYSDIR)/include -	$(INSTALL_DATA) $(HRL_FILES) $(RELSYSDIR)/include -	$(INSTALL_DIR) $(RELSYSDIR)/ebin -	$(INSTALL_DATA) $(TARGET_FILES) $(RELSYSDIR)/ebin +	$(INSTALL_DIR) "$(RELSYSDIR)/src" +	$(INSTALL_DATA) $(ERL_FILES) "$(RELSYSDIR)/src" +	$(INSTALL_DATA) $(INTERNAL_HRL_FILES) "$(RELSYSDIR)/src" +	$(INSTALL_DIR) "$(RELSYSDIR)/include" +	$(INSTALL_DATA) $(HRL_FILES) "$(RELSYSDIR)/include" +	$(INSTALL_DIR) "$(RELSYSDIR)/ebin" +	$(INSTALL_DATA) $(TARGET_FILES) "$(RELSYSDIR)/ebin"  release_docs_spec: diff --git a/lib/kernel/src/code.erl b/lib/kernel/src/code.erl index b7fda69ce0..363072951e 100644 --- a/lib/kernel/src/code.erl +++ b/lib/kernel/src/code.erl @@ -63,7 +63,7 @@  	 which/1,  	 where_is_file/1,  	 where_is_file/2, -	 set_primary_archive/3, +	 set_primary_archive/4,  	 clash/0]).  -export_type([load_error_rsn/0, load_ret/0]). @@ -107,7 +107,7 @@  %% unstick_mod(Module)           -> true  %% is_sticky(Module)             -> boolean()  %% which(Module)                 -> Filename | loaded_ret_atoms() | non_existing -%% set_primary_archive((FileName, Bin, FileInfo) -> ok | {error, Reason} +%% set_primary_archive((FileName, ArchiveBin, FileInfo, ParserFun) -> ok | {error, Reason}  %% clash()                       -> ok         prints out number of clashes  %%---------------------------------------------------------------------------- @@ -481,13 +481,16 @@ where_is_file(Path, File) when is_list(Path), is_list(File) ->  -spec set_primary_archive(ArchiveFile :: file:filename(),  			  ArchiveBin :: binary(), -			  FileInfo :: file:file_info()) +			  FileInfo :: file:file_info(), +			  ParserFun :: fun())  			 -> 'ok' | {'error', atom()}. -set_primary_archive(ArchiveFile0, ArchiveBin, #file_info{} = FileInfo) +set_primary_archive(ArchiveFile0, ArchiveBin, #file_info{} = FileInfo, +		    ParserFun)    when is_list(ArchiveFile0), is_binary(ArchiveBin) ->      ArchiveFile = filename:absname(ArchiveFile0), -    case call({set_primary_archive, ArchiveFile, ArchiveBin, FileInfo}) of +    case call({set_primary_archive, ArchiveFile, ArchiveBin, FileInfo, +	       ParserFun}) of  	{ok, []} ->  	    ok;  	{ok, _Mode, Ebins} -> diff --git a/lib/kernel/src/code_server.erl b/lib/kernel/src/code_server.erl index a2db7c9790..00ad923466 100644 --- a/lib/kernel/src/code_server.erl +++ b/lib/kernel/src/code_server.erl @@ -394,8 +394,8 @@ handle_call(stop,{_From,_Tag}, S) ->  handle_call({is_cached,_File}, {_From,_Tag}, S=#state{cache=no_cache}) ->      {reply, no, S}; -handle_call({set_primary_archive, File, ArchiveBin, FileInfo}, {_From,_Tag}, S=#state{mode=Mode}) -> -    case erl_prim_loader:set_primary_archive(File, ArchiveBin, FileInfo) of +handle_call({set_primary_archive, File, ArchiveBin, FileInfo, ParserFun}, {_From,_Tag}, S=#state{mode=Mode}) -> +    case erl_prim_loader:set_primary_archive(File, ArchiveBin, FileInfo, ParserFun) of  	{ok, Files} ->  	    {reply, {ok, Mode, Files}, S};  	{error, _Reason} = Error -> diff --git a/lib/kernel/src/disk_log.erl b/lib/kernel/src/disk_log.erl index f5f972c112..5b1efcd395 100644 --- a/lib/kernel/src/disk_log.erl +++ b/lib/kernel/src/disk_log.erl @@ -282,7 +282,8 @@ change_notify(Log, Pid, NewNotify) ->  -spec change_header(Log, Header) -> 'ok' | {'error', Reason} when        Log :: log(), -      Header :: {head, dlog_head_opt()} | {head_func, mfa()}, +      Header :: {head, dlog_head_opt()} +              | {head_func, MFA :: {atom(), atom(), list()}},        Reason :: no_such_log | nonode | {read_only_mode, Log}                | {blocked_log, Log} | {badarg, head}.  change_header(Log, NewHead) -> @@ -336,7 +337,9 @@ format_error(Error) ->                          ok | {blocked, QueueLogRecords :: boolean()}}                     | {node, Node :: node()}                     | {distributed, Dist :: local | [node()]} -                   | {head, Head :: none | {head, term()} | mfa()} +                   | {head, Head :: none +                                  | {head, term()} +                                  | (MFA :: {atom(), atom(), list()})}                     | {no_written_items, NoWrittenItems ::non_neg_integer()}                     | {full, Full :: boolean}                     | {no_current_bytes, non_neg_integer()} diff --git a/lib/kernel/src/disk_log.hrl b/lib/kernel/src/disk_log.hrl index 259967650f..242a25a7a6 100644 --- a/lib/kernel/src/disk_log.hrl +++ b/lib/kernel/src/disk_log.hrl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %% -%% Copyright Ericsson AB 1997-2011. All Rights Reserved. +%% Copyright Ericsson AB 1997-2012. All Rights Reserved.  %%  %% The contents of this file are subject to the Erlang Public License,  %% Version 1.1, (the "License"); you may not use this file except in @@ -74,7 +74,7 @@                            | {distributed, Nodes :: [node()]}                            | {notify, boolean()}                            | {head, Head :: dlog_head_opt()} -                          | {head_func, mfa()} +                          | {head_func, MFA :: {atom(), atom(), list()}}                            | {mode, Mode :: dlog_mode()}.  -type dlog_options()     :: [dlog_option()].  -type dlog_repair()      :: 'truncate' | boolean(). diff --git a/lib/kernel/src/file.erl b/lib/kernel/src/file.erl index d8033ee192..cdb984c333 100644 --- a/lib/kernel/src/file.erl +++ b/lib/kernel/src/file.erl @@ -1258,7 +1258,7 @@ sendfile_fallback_int(File, Sock, Bytes, ChunkSize, BytesSent)    when Bytes > BytesSent; Bytes == 0 ->      Size = if Bytes == 0 ->  		   ChunkSize; -	       (Bytes - BytesSent + ChunkSize) > 0 -> +	       (Bytes - BytesSent) < ChunkSize ->  		   Bytes - BytesSent;  	      true ->  		   ChunkSize diff --git a/lib/kernel/src/gen_sctp.erl b/lib/kernel/src/gen_sctp.erl index d8954f0cf7..8fa963ec78 100644 --- a/lib/kernel/src/gen_sctp.erl +++ b/lib/kernel/src/gen_sctp.erl @@ -425,9 +425,10 @@ error_string(X) ->      erlang:error(badarg, [X]). --spec controlling_process(Socket, Pid) -> ok when +-spec controlling_process(Socket, Pid) -> ok | {error, Reason} when        Socket :: sctp_socket(), -      Pid :: pid(). +      Pid :: pid(), +      Reason :: closed | not_owner | inet:posix().  controlling_process(S, Pid) when is_port(S), is_pid(Pid) ->      inet:udp_controlling_process(S, Pid); diff --git a/lib/kernel/src/gen_tcp.erl b/lib/kernel/src/gen_tcp.erl index ef6bfdf7f4..e6dfdadb03 100644 --- a/lib/kernel/src/gen_tcp.erl +++ b/lib/kernel/src/gen_tcp.erl @@ -31,7 +31,6 @@  -type option() ::          {active,          true | false | once} | -        {bit8,            clear | set | on | off} |          {buffer,          non_neg_integer()} |          {delay_send,      boolean()} |          {deliver,         port | term} | @@ -61,7 +60,6 @@          {tos,             non_neg_integer()}.  -type option_name() ::          active | -        bit8 |          buffer |          delay_send |          deliver | diff --git a/lib/kernel/src/gen_udp.erl b/lib/kernel/src/gen_udp.erl index 8688799ae9..914854c65c 100644 --- a/lib/kernel/src/gen_udp.erl +++ b/lib/kernel/src/gen_udp.erl @@ -185,9 +185,10 @@ connect(S, Address, Port) when is_port(S) ->  	    Error      end. --spec controlling_process(Socket, Pid) -> ok when +-spec controlling_process(Socket, Pid) -> ok | {error, Reason} when        Socket :: socket(), -      Pid :: pid(). +      Pid :: pid(), +      Reason :: closed | not_owner | inet:posix().  controlling_process(S, NewOwner) ->      inet:udp_controlling_process(S, NewOwner). diff --git a/lib/kernel/src/heart.erl b/lib/kernel/src/heart.erl index 255ae4e51b..218be964a0 100644 --- a/lib/kernel/src/heart.erl +++ b/lib/kernel/src/heart.erl @@ -18,6 +18,10 @@  %%  -module(heart).  +-compile(no_native). +% 'no_native' as part of a crude fix to make init:restart/0 work by clearing +% all hipe inter-module information (hipe_mfa_info's in hipe_bif0.c). +  %%%--------------------------------------------------------------------  %%% This is a rewrite of pre_heart from BS.3.  %%% diff --git a/lib/kernel/src/hipe_unified_loader.erl b/lib/kernel/src/hipe_unified_loader.erl index 8b3aa0286d..514c002d87 100644 --- a/lib/kernel/src/hipe_unified_loader.erl +++ b/lib/kernel/src/hipe_unified_loader.erl @@ -34,6 +34,13 @@  -module(hipe_unified_loader). +-compile(no_native). +% 'no_native' is a workaround to avoid "The code server called unloaded module" +% caused by Mod:module_info(exports) in patch_to_emu_step1() called by post_beam_load. +% Reproducable with hipelibs and asn1_SUITE. +% I think the real solution would be to let BIF erlang:load_module/2 redirect all +% hipe calls to the module and thereby remove post_beam_load. +  -export([chunk_name/1,  	 %% Only the code and code_server modules may call the entries below!  	 load_native_code/2, diff --git a/lib/kernel/src/inet.erl b/lib/kernel/src/inet.erl index abaf4486dc..1a03424f88 100644 --- a/lib/kernel/src/inet.erl +++ b/lib/kernel/src/inet.erl @@ -763,8 +763,12 @@ sctp_opt([Opt|Opts], Mod, R, As) ->  	{Name,Val}	-> sctp_opt (Opts, Mod, R, As, Name, Val);  	_ -> {error,badarg}      end; -sctp_opt([], _Mod, R, _SockOpts) -> -    {ok, R}. +sctp_opt([], _Mod, #sctp_opts{ifaddr=IfAddr}=R, _SockOpts) -> +    if is_list(IfAddr) -> +	    {ok, R#sctp_opts{ifaddr=lists:reverse(IfAddr)}}; +       true -> +	    {ok, R} +    end.  sctp_opt(Opts, Mod, R, As, Name, Val) ->      case add_opt(Name, Val, R#sctp_opts.opts, As) of @@ -1015,11 +1019,7 @@ open(Fd, Addr, Port, Opts, Protocol, Family, Type, Module) when Fd < 0 ->  	    case prim_inet:setopts(S, Opts) of  		ok ->  		    case if is_list(Addr) -> -				 prim_inet:bind(S, add, -						[case A of -						     {_,_} -> A; -						     _     -> {A,Port} -						 end || A <- Addr]); +				 bindx(S, Addr, Port);  			    true ->  				 prim_inet:bind(S, Addr, Port)  			 end of @@ -1040,6 +1040,34 @@ open(Fd, Addr, Port, Opts, Protocol, Family, Type, Module) when Fd < 0 ->  open(Fd, _Addr, _Port, Opts, Protocol, Family, Type, Module) ->      fdopen(Fd, Opts, Protocol, Family, Type, Module). +bindx(S, [Addr], Port0) -> +    {IP, Port} = set_bindx_port(Addr, Port0), +    prim_inet:bind(S, IP, Port); +bindx(S, Addrs, Port0) -> +    [{IP, Port} | Rest] = [set_bindx_port(Addr, Port0) || Addr <- Addrs], +    case prim_inet:bind(S, IP, Port) of +	{ok, AssignedPort} when Port =:= 0 -> +	    %% On newer Linux kernels, Solaris and FreeBSD, calling +	    %% bindx with port 0 is ok, but on SuSE 10, it results in einval +	    Rest2 = [change_bindx_0_port(Addr, AssignedPort) || Addr <- Rest], +	    prim_inet:bind(S, add, Rest2); +	{ok, _} -> +	    prim_inet:bind(S, add, Rest); +	Error -> +	    Error +    end. + +set_bindx_port({_IP, _Port}=Addr, _OtherPort) -> +    Addr; +set_bindx_port(IP, Port) -> +    {IP, Port}. + +change_bindx_0_port({IP, 0}, AssignedPort) -> +    {IP, AssignedPort}; +change_bindx_0_port({_IP, _Port}=Addr, _AssignedPort) -> +    Addr. + +  -spec fdopen(Fd :: non_neg_integer(),  	     Opts :: [socket_setopt()],  	     Protocol :: socket_protocol(), @@ -1246,6 +1274,8 @@ udp_close(S) when is_port(S) ->  %% Set controlling process for TCP socket.  tcp_controlling_process(S, NewOwner) when is_port(S), is_pid(NewOwner) ->      case erlang:port_info(S, connected) of +	{connected, NewOwner} -> +	    ok;  	{connected, Pid} when Pid =/= self() ->  	    {error, not_owner};  	undefined -> @@ -1297,6 +1327,8 @@ tcp_sync_input(S, Owner, Flag) ->  %% Set controlling process for UDP or SCTP socket.  udp_controlling_process(S, NewOwner) when is_port(S), is_pid(NewOwner) ->      case erlang:port_info(S, connected) of +	{connected, NewOwner} -> +	    ok;  	{connected, Pid} when Pid =/= self() ->  	    {error, not_owner};  	_ -> diff --git a/lib/kernel/src/rpc.erl b/lib/kernel/src/rpc.erl index e214ffa404..a3fc57a124 100644 --- a/lib/kernel/src/rpc.erl +++ b/lib/kernel/src/rpc.erl @@ -286,7 +286,7 @@ call(N,M,F,A) ->        Reason :: term(),        Timeout :: timeout(). -call(N,M,F,A,_Timeout) when node() =:= N ->  %% Optimize local call +call(N,M,F,A,infinity) when node() =:= N ->  %% Optimize local call      local_call(M,F,A);  call(N,M,F,A,infinity) ->      do_call(N, {call,M,F,A,group_leader()}, infinity); | 
