diff options
Diffstat (limited to 'lib/compiler/src')
| -rw-r--r-- | lib/compiler/src/beam_asm.erl | 9 | ||||
| -rw-r--r-- | lib/compiler/src/beam_listing.erl | 14 | ||||
| -rw-r--r-- | lib/compiler/src/compile.erl | 6 | 
3 files changed, 23 insertions, 6 deletions
| diff --git a/lib/compiler/src/beam_asm.erl b/lib/compiler/src/beam_asm.erl index c35efdfc9d..f7c838e392 100644 --- a/lib/compiler/src/beam_asm.erl +++ b/lib/compiler/src/beam_asm.erl @@ -182,7 +182,8 @@ build_file(Code, Attr, Dict, NumLabels, NumFuncs, ExtraChunks, SourceFile, Opts,      Essentials1 = [iolist_to_binary(C) || C <- Essentials0],      MD5 = module_md5(Essentials1),      Essentials = finalize_fun_table(Essentials1, MD5), -    {Attributes,Compile} = build_attributes(Opts, SourceFile, Attr, MD5), +    {Attributes,Compile} = build_attributes(Opts, CompilerOpts, SourceFile, +                                            Attr, MD5),      AttrChunk = chunk(<<"Attr">>, Attributes),      CompileChunk = chunk(<<"CInf">>, Compile), @@ -264,16 +265,16 @@ flatten_exports(Exps) ->  flatten_imports(Imps) ->      list_to_binary(map(fun({M,F,A}) -> <<M:32,F:32,A:32>> end, Imps)). -build_attributes(Opts, SourceFile, Attr, MD5) -> +build_attributes(Opts, CompilerOpts, SourceFile, Attr, MD5) ->      Misc0 = case SourceFile of  		[] -> [];  		[_|_] -> [{source,SourceFile}]  	    end, -    Misc = case member(slim, Opts) of +    Misc = case member(slim, CompilerOpts) of  	       false -> Misc0;  	       true -> []  	   end, -    Compile = case member(deterministic, Opts) of +    Compile = case member(deterministic, CompilerOpts) of  		  false ->  		      [{options,Opts},{version,?COMPILER_VSN}|Misc];  		  true -> diff --git a/lib/compiler/src/beam_listing.erl b/lib/compiler/src/beam_listing.erl index 94b47cf568..836378727b 100644 --- a/lib/compiler/src/beam_listing.erl +++ b/lib/compiler/src/beam_listing.erl @@ -24,6 +24,7 @@  -include("core_parse.hrl").  -include("v3_kernel.hrl").  -include("v3_life.hrl"). +-include("beam_disasm.hrl").  -import(lists, [foreach/2]). @@ -59,6 +60,19 @@ module(Stream, {Mod,Exp,Attr,Code,NumLabels}) ->  			[Name, Arity, Entry]),  	      io:put_chars(Stream, format_asm(Asm))        end, Code); +module(Stream, Code) when is_binary(Code) -> +    #beam_file{ module = Module, compile_info = CInfo } = beam_disasm:file(Code), +    Loaded = code:is_loaded(Module), +    Sticky = code:is_sticky(Module), +    [code:unstick_mod(Module) || Sticky], + +    {module, Module} = code:load_binary(Module, proplists:get_value(source, CInfo), Code), +    ok = erts_debug:df(Stream, Module), + +    %% Restore loaded module +    _ = [{module, Module} = code:load_file(Module) || Loaded =/= false], +    [code:stick_mod(Module) || Sticky], +    ok;  module(Stream, [_|_]=Fs) ->      %% Form-based abstract format.      foreach(fun (F) -> io:format(Stream, "~p.\n", [F]) end, Fs). diff --git a/lib/compiler/src/compile.erl b/lib/compiler/src/compile.erl index aa2d224bb4..50b0ba76f8 100644 --- a/lib/compiler/src/compile.erl +++ b/lib/compiler/src/compile.erl @@ -787,8 +787,10 @@ asm_passes() ->       | binary_passes()].  binary_passes() -> -    [{native_compile,fun test_native/1,fun native_compile/2}, -     {unless,binary,?pass(save_binary,not_werror)}]. +    [{iff,'to_dis',{listing,"dis"}}, +     {native_compile,fun test_native/1,fun native_compile/2}, +     {unless,binary,?pass(save_binary,not_werror)} +    ].  %%%  %%% Compiler passes. | 
