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

Side by Side Diff: src/IceTranslator.cpp

Issue 1834473002: Allow Subzero to parse function blocks in parallel. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Clean up code. Created 4 years, 9 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
OLDNEW
1 //===- subzero/src/IceTranslator.cpp - ICE to machine code ------*- C++ -*-===// 1 //===- subzero/src/IceTranslator.cpp - ICE to machine code ------*- C++ -*-===//
2 // 2 //
3 // The Subzero Code Generator 3 // The Subzero Code Generator
4 // 4 //
5 // This file is distributed under the University of Illinois Open Source 5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details. 6 // License. See LICENSE.TXT for details.
7 // 7 //
8 //===----------------------------------------------------------------------===// 8 //===----------------------------------------------------------------------===//
9 /// 9 ///
10 /// \file 10 /// \file
11 /// \brief Defines the general driver class for translating ICE to machine code. 11 /// \brief Defines the general driver class for translating ICE to machine code.
12 /// 12 ///
13 //===----------------------------------------------------------------------===// 13 //===----------------------------------------------------------------------===//
14 14
15 #include "IceTranslator.h" 15 #include "IceTranslator.h"
16 16
17 #include "IceDefs.h" 17 #include "IceDefs.h"
18 #include "IceCfg.h" 18 #include "IceCfg.h"
19 #include "IceClFlags.h" 19 #include "IceClFlags.h"
20 #include "IceGlobalInits.h" 20 #include "IceGlobalInits.h"
21 #include "IceTargetLowering.h" 21 #include "IceTargetLowering.h"
22 22
23 #include <utility> 23 #include <utility>
24 24
25 namespace {
John 2016/03/24 17:32:35 enclose this namespace in Ice, and then remove the
Karl 2016/03/24 22:35:25 Done.
26
27 class CfgOptWorkItem : public Ice::OptWorkItem {
28 CfgOptWorkItem() = delete;
29 CfgOptWorkItem(const CfgOptWorkItem &) = delete;
30 CfgOptWorkItem &operator=(const CfgOptWorkItem &) = delete;
31
32 public:
33 CfgOptWorkItem(std::unique_ptr<Ice::Cfg> Func) : Func(std::move(Func)) {}
34 std::unique_ptr<Ice::Cfg> getParsedCfg() final { return std::move(Func); }
John 2016/03/24 17:32:34 final is better off when used in the class declara
Karl 2016/03/24 22:35:25 On 2016/03/24 17:32:34, John wrote: > final is bet
35 ~CfgOptWorkItem() final {}
John 2016/03/24 17:32:35 ~CfgOptWorkItem() override = default;
Karl 2016/03/24 22:35:25 Done.
36
37 private:
38 std::unique_ptr<Ice::Cfg> Func;
39 };
40
41 } // end of anonymous namespace
42
25 namespace Ice { 43 namespace Ice {
26 44
27 Translator::Translator(GlobalContext *Ctx) 45 Translator::Translator(GlobalContext *Ctx)
28 : Ctx(Ctx), NextSequenceNumber(GlobalContext::getFirstSequenceNumber()), 46 : Ctx(Ctx), NextSequenceNumber(GlobalContext::getFirstSequenceNumber()),
29 ErrorStatus() {} 47 ErrorStatus() {}
30 48
31 IceString Translator::createUnnamedName(const IceString &Prefix, SizeT Index) { 49 IceString Translator::createUnnamedName(const IceString &Prefix, SizeT Index) {
32 if (Index == 0) 50 if (Index == 0)
33 return Prefix; 51 return Prefix;
34 std::string Buffer; 52 std::string Buffer;
(...skipping 13 matching lines...) Expand all
48 OstreamLocker L(Ctx); 66 OstreamLocker L(Ctx);
49 Ostream &Stream = Ctx->getStrDump(); 67 Ostream &Stream = Ctx->getStrDump();
50 Stream << "Warning : Default " << Kind << " prefix '" << Prefix 68 Stream << "Warning : Default " << Kind << " prefix '" << Prefix
51 << "' potentially conflicts with name '" << Name << "'.\n"; 69 << "' potentially conflicts with name '" << Name << "'.\n";
52 return true; 70 return true;
53 } 71 }
54 return false; 72 return false;
55 } 73 }
56 74
57 void Translator::translateFcn(std::unique_ptr<Cfg> Func) { 75 void Translator::translateFcn(std::unique_ptr<Cfg> Func) {
58 Ctx->optQueueBlockingPush(std::move(Func)); 76 Ctx->optQueueBlockingPush(makeUnique<CfgOptWorkItem>(std::move(Func)));
59 } 77 }
60 78
61 void Translator::lowerGlobals( 79 void Translator::lowerGlobals(
62 std::unique_ptr<VariableDeclarationList> VariableDeclarations) { 80 std::unique_ptr<VariableDeclarationList> VariableDeclarations) {
63 Ctx->emitQueueBlockingPush(makeUnique<EmitterWorkItem>( 81 Ctx->emitQueueBlockingPush(makeUnique<EmitterWorkItem>(
64 getNextSequenceNumber(), std::move(VariableDeclarations))); 82 getNextSequenceNumber(), std::move(VariableDeclarations)));
65 } 83 }
66 84
67 } // end of namespace Ice 85 } // end of namespace Ice
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698