OLD | NEW |
---|---|
1 // Copyright 2009 the V8 project authors. All rights reserved. | 1 // Copyright 2009 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 816 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
827 } | 827 } |
828 | 828 |
829 | 829 |
830 bool CompileLazyShared(Handle<SharedFunctionInfo> shared, | 830 bool CompileLazyShared(Handle<SharedFunctionInfo> shared, |
831 ClearExceptionFlag flag) { | 831 ClearExceptionFlag flag) { |
832 CompilationInfo info(shared); | 832 CompilationInfo info(shared); |
833 return CompileLazyHelper(&info, flag); | 833 return CompileLazyHelper(&info, flag); |
834 } | 834 } |
835 | 835 |
836 | 836 |
837 bool CompileLazy(Handle<JSFunction> function, | 837 static bool CompileLazyFunction(Handle<JSFunction> function, |
838 ClearExceptionFlag flag) { | 838 ClearExceptionFlag flag, |
839 bool in_loop) { | |
839 bool result = true; | 840 bool result = true; |
840 if (function->shared()->is_compiled()) { | 841 if (function->shared()->is_compiled()) { |
841 function->ReplaceCode(function->shared()->code()); | 842 function->ReplaceCode(function->shared()->code()); |
842 function->shared()->set_code_age(0); | 843 function->shared()->set_code_age(0); |
843 } else { | 844 } else { |
844 CompilationInfo info(function); | 845 CompilationInfo info(function); |
846 if (in_loop) info.MarkAsInLoop(); | |
845 result = CompileLazyHelper(&info, flag); | 847 result = CompileLazyHelper(&info, flag); |
846 ASSERT(!result || function->is_compiled()); | 848 ASSERT(!result || function->is_compiled()); |
847 } | 849 } |
848 if (result && function->is_compiled()) { | 850 if (result && function->is_compiled()) { |
849 PROFILE(FunctionCreateEvent(*function)); | 851 PROFILE(FunctionCreateEvent(*function)); |
850 } | 852 } |
851 return result; | 853 return result; |
852 } | 854 } |
853 | 855 |
854 | 856 |
857 bool CompileLazy(Handle<JSFunction> function, | |
858 ClearExceptionFlag flag) { | |
859 return CompileLazyFunction(function, flag, false /* in loop */); | |
Kevin Millikin (Chromium)
2011/02/18 16:16:58
The C style comment is OK, but I don't think we ha
antonm
2011/02/21 18:27:58
(And responding to Slava too): I didn't want to in
| |
860 } | |
861 | |
862 | |
855 bool CompileLazyInLoop(Handle<JSFunction> function, | 863 bool CompileLazyInLoop(Handle<JSFunction> function, |
856 ClearExceptionFlag flag) { | 864 ClearExceptionFlag flag) { |
857 bool result = true; | 865 return CompileLazyFunction(function, flag, true /* in loop */); |
858 if (function->shared()->is_compiled()) { | |
859 function->ReplaceCode(function->shared()->code()); | |
860 function->shared()->set_code_age(0); | |
861 } else { | |
862 CompilationInfo info(function); | |
863 info.MarkAsInLoop(); | |
864 result = CompileLazyHelper(&info, flag); | |
865 ASSERT(!result || function->is_compiled()); | |
866 } | |
867 if (result && function->is_compiled()) { | |
868 PROFILE(FunctionCreateEvent(*function)); | |
869 } | |
870 return result; | |
871 } | 866 } |
872 | 867 |
873 | 868 |
874 bool CompileOptimized(Handle<JSFunction> function, int osr_ast_id) { | 869 bool CompileOptimized(Handle<JSFunction> function, int osr_ast_id) { |
875 CompilationInfo info(function); | 870 CompilationInfo info(function); |
876 info.SetOptimizing(osr_ast_id); | 871 info.SetOptimizing(osr_ast_id); |
877 bool result = CompileLazyHelper(&info, KEEP_EXCEPTION); | 872 bool result = CompileLazyHelper(&info, KEEP_EXCEPTION); |
878 if (result) PROFILE(FunctionCreateEvent(*function)); | 873 if (result) PROFILE(FunctionCreateEvent(*function)); |
879 return result; | 874 return result; |
880 } | 875 } |
(...skipping 22 matching lines...) Expand all Loading... | |
903 | 898 |
904 OptimizedObjectForAddingMultipleProperties:: | 899 OptimizedObjectForAddingMultipleProperties:: |
905 ~OptimizedObjectForAddingMultipleProperties() { | 900 ~OptimizedObjectForAddingMultipleProperties() { |
906 // Reoptimize the object to allow fast property access. | 901 // Reoptimize the object to allow fast property access. |
907 if (has_been_transformed_) { | 902 if (has_been_transformed_) { |
908 TransformToFastProperties(object_, unused_property_fields_); | 903 TransformToFastProperties(object_, unused_property_fields_); |
909 } | 904 } |
910 } | 905 } |
911 | 906 |
912 } } // namespace v8::internal | 907 } } // namespace v8::internal |
OLD | NEW |