Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(47)

Side by Side Diff: src/assembler.h

Issue 19562003: Add support for IncrementCounter in Hydrogen. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Using HConstant, HLoadKeyed, HAdd and HStoreKeyed. Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 1994-2006 Sun Microsystems Inc. 1 // Copyright (c) 1994-2006 Sun Microsystems Inc.
2 // All Rights Reserved. 2 // All Rights Reserved.
3 // 3 //
4 // Redistribution and use in source and binary forms, with or without 4 // Redistribution and use in source and binary forms, with or without
5 // modification, are permitted provided that the following conditions are 5 // modification, are permitted provided that the following conditions are
6 // met: 6 // met:
7 // 7 //
8 // - Redistributions of source code must retain the above copyright notice, 8 // - Redistributions of source code must retain the above copyright notice,
9 // this list of conditions and the following disclaimer. 9 // this list of conditions and the following disclaimer.
10 // 10 //
(...skipping 811 matching lines...) Expand 10 before | Expand all | Expand 10 after
822 822
823 static ExternalReference math_exp_constants(int constant_index); 823 static ExternalReference math_exp_constants(int constant_index);
824 static ExternalReference math_exp_log_table(); 824 static ExternalReference math_exp_log_table();
825 825
826 static ExternalReference page_flags(Page* page); 826 static ExternalReference page_flags(Page* page);
827 827
828 static ExternalReference ForDeoptEntry(Address entry); 828 static ExternalReference ForDeoptEntry(Address entry);
829 829
830 static ExternalReference cpu_features(); 830 static ExternalReference cpu_features();
831 831
832 Address address() const {return reinterpret_cast<Address>(address_);} 832 Address address() const { return reinterpret_cast<Address>(address_); }
833 833
834 #ifdef ENABLE_DEBUGGER_SUPPORT 834 #ifdef ENABLE_DEBUGGER_SUPPORT
835 // Function Debug::Break() 835 // Function Debug::Break()
836 static ExternalReference debug_break(Isolate* isolate); 836 static ExternalReference debug_break(Isolate* isolate);
837 837
838 // Used to check if single stepping is enabled in generated code. 838 // Used to check if single stepping is enabled in generated code.
839 static ExternalReference debug_step_in_fp_address(Isolate* isolate); 839 static ExternalReference debug_step_in_fp_address(Isolate* isolate);
840 #endif 840 #endif
841 841
842 #ifndef V8_INTERPRETED_REGEXP 842 #ifndef V8_INTERPRETED_REGEXP
(...skipping 18 matching lines...) Expand all
861 static void set_redirector(Isolate* isolate, 861 static void set_redirector(Isolate* isolate,
862 ExternalReferenceRedirector* redirector) { 862 ExternalReferenceRedirector* redirector) {
863 // We can't stack them. 863 // We can't stack them.
864 ASSERT(isolate->external_reference_redirector() == NULL); 864 ASSERT(isolate->external_reference_redirector() == NULL);
865 isolate->set_external_reference_redirector( 865 isolate->set_external_reference_redirector(
866 reinterpret_cast<ExternalReferenceRedirectorPointer*>(redirector)); 866 reinterpret_cast<ExternalReferenceRedirectorPointer*>(redirector));
867 } 867 }
868 868
869 static ExternalReference stress_deopt_count(Isolate* isolate); 869 static ExternalReference stress_deopt_count(Isolate* isolate);
870 870
871 static ExternalReference null();
872
873 bool operator==(const ExternalReference& other) const {
874 return address_ == other.address_;
875 }
876
877 bool operator!=(const ExternalReference& other) const {
878 return !(*this == other);
879 }
880
871 private: 881 private:
872 explicit ExternalReference(void* address) 882 explicit ExternalReference(void* address)
873 : address_(address) {} 883 : address_(address) {}
874 884
875 static void* Redirect(Isolate* isolate, 885 static void* Redirect(Isolate* isolate,
876 void* address, 886 void* address,
877 Type type = ExternalReference::BUILTIN_CALL) { 887 Type type = ExternalReference::BUILTIN_CALL) {
878 ExternalReferenceRedirector* redirector = 888 ExternalReferenceRedirector* redirector =
879 reinterpret_cast<ExternalReferenceRedirector*>( 889 reinterpret_cast<ExternalReferenceRedirector*>(
880 isolate->external_reference_redirector()); 890 isolate->external_reference_redirector());
(...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after
1064 public: 1074 public:
1065 NullCallWrapper() { } 1075 NullCallWrapper() { }
1066 virtual ~NullCallWrapper() { } 1076 virtual ~NullCallWrapper() { }
1067 virtual void BeforeCall(int call_size) const { } 1077 virtual void BeforeCall(int call_size) const { }
1068 virtual void AfterCall() const { } 1078 virtual void AfterCall() const { }
1069 }; 1079 };
1070 1080
1071 } } // namespace v8::internal 1081 } } // namespace v8::internal
1072 1082
1073 #endif // V8_ASSEMBLER_H_ 1083 #endif // V8_ASSEMBLER_H_
OLDNEW
« no previous file with comments | « src/arm/lithium-codegen-arm.cc ('k') | src/assembler.cc » ('j') | src/hydrogen-instructions.h » ('J')

Powered by Google App Engine
This is Rietveld 408576698