-
Notifications
You must be signed in to change notification settings - Fork 3.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Diagnostics][Relay][InferType] Refactor InferType to work on whole module, and use new diagnostics. #6274
Merged
Merged
[Diagnostics][Relay][InferType] Refactor InferType to work on whole module, and use new diagnostics. #6274
Changes from all commits
Commits
Show all changes
40 commits
Select commit
Hold shift + click to select a range
6361efc
Refactor the type checker to use diagnostics
jroesch 876332b
Apply suggestions from code review
jroesch 2e1627e
Apply suggestions from code review
jroesch 59171bd
Clean up parser
jroesch 781f550
CR feedback
jroesch c31538e
Apply Bobs suggestions
jroesch a36a591
Fix up Python interface for diagnostics
jroesch 0540238
Fix test_ir_parser and formatting
jroesch c378954
Fix cpplint
jroesch bdbada8
Fix lint
jroesch e767be3
Fix format
jroesch df5fe25
More lint
jroesch 5870cbc
Fix format
jroesch 236b39e
Kill dead doc comment
jroesch 84ae8ea
Fix documentation comment
jroesch 9c4c5fd
Rebase fixups
jroesch 2f94a64
Add docs for type.h
jroesch b81b7a0
Fix parser.cc
jroesch 05b4c7e
Fix unittests
jroesch 58d4dd4
Fix black
jroesch 33847e6
Skip previously typechecked functions
jroesch e0c1de2
fix ACL
comaniac b080eac
Fix numerous issues
jroesch 743bbff
Add repr method
jroesch 0281041
Fix issue with Pytest, I am ready to cry
jroesch 987e92a
Fix the rest of tests
jroesch f829028
Kill dead code
jroesch 2209b08
Fix dignostic tests
jroesch 222b7c1
Fix more tests
jroesch 433deeb
fix more tests (#11)
zhiics e81eadb
Fix diagnostic.py deinit bug
jroesch f81e85e
Fix deinit issue
jroesch ca065d8
Format
jroesch 46f9658
Tweak disabling of override
jroesch 885e404
Format
jroesch f6c0524
Fix BYOC
jroesch b32cf3a
Fix TensorArray stuff
jroesch d8c85b5
Fix PyTorch
jroesch 9e22dbd
Format
jroesch c2f368b
Format
jroesch File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -57,4 +57,3 @@ git checkout "$repo_revision" | |
|
||
cd "driver" | ||
scons install_prefix="$install_path" install | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,262 @@ | ||
/* | ||
* Licensed to the Apache Software Foundation (ASF) under one | ||
* or more contributor license agreements. See the NOTICE file | ||
* distributed with this work for additional information | ||
* regarding copyright ownership. The ASF licenses this file | ||
* to you under the Apache License, Version 2.0 (the | ||
* "License"); you may not use this file except in compliance | ||
* with the License. You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, | ||
* software distributed under the License is distributed on an | ||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||
* KIND, either express or implied. See the License for the | ||
* specific language governing permissions and limitations | ||
* under the License. | ||
*/ | ||
|
||
/*! | ||
* \file diagnostic.h | ||
* \brief A new diagnostic interface for TVM error reporting. | ||
* | ||
* A prototype of the new diagnostic reporting interface for TVM. | ||
* | ||
* Eventually we hope to promote this file to the top-level and | ||
* replace the existing errors.h. | ||
*/ | ||
|
||
#ifndef TVM_IR_DIAGNOSTIC_H_ | ||
#define TVM_IR_DIAGNOSTIC_H_ | ||
|
||
#include <tvm/ir/module.h> | ||
#include <tvm/ir/span.h> | ||
#include <tvm/parser/source_map.h> | ||
#include <tvm/runtime/container.h> | ||
#include <tvm/runtime/object.h> | ||
#include <tvm/support/logging.h> | ||
|
||
#include <fstream> | ||
#include <string> | ||
#include <utility> | ||
#include <vector> | ||
|
||
namespace tvm { | ||
|
||
using tvm::parser::SourceMap; | ||
using tvm::runtime::TypedPackedFunc; | ||
|
||
extern const char* kTVM_INTERNAL_ERROR_MESSAGE; | ||
|
||
#define ICHECK_INDENT " " | ||
|
||
#define ICHECK_BINARY_OP(name, op, x, y) \ | ||
if (dmlc::LogCheckError _check_err = dmlc::LogCheck##name(x, y)) \ | ||
dmlc::LogMessageFatal(__FILE__, __LINE__).stream() \ | ||
<< kTVM_INTERNAL_ERROR_MESSAGE << std::endl \ | ||
<< ICHECK_INDENT << "Check failed: " << #x " " #op " " #y << *(_check_err.str) << ": " | ||
|
||
#define ICHECK(x) \ | ||
if (!(x)) \ | ||
dmlc::LogMessageFatal(__FILE__, __LINE__).stream() \ | ||
<< kTVM_INTERNAL_ERROR_MESSAGE << ICHECK_INDENT << "Check failed: " #x << " == false: " | ||
|
||
#define ICHECK_LT(x, y) ICHECK_BINARY_OP(_LT, <, x, y) | ||
#define ICHECK_GT(x, y) ICHECK_BINARY_OP(_GT, >, x, y) | ||
#define ICHECK_LE(x, y) ICHECK_BINARY_OP(_LE, <=, x, y) | ||
#define ICHECK_GE(x, y) ICHECK_BINARY_OP(_GE, >=, x, y) | ||
#define ICHECK_EQ(x, y) ICHECK_BINARY_OP(_EQ, ==, x, y) | ||
#define ICHECK_NE(x, y) ICHECK_BINARY_OP(_NE, !=, x, y) | ||
#define ICHECK_NOTNULL(x) \ | ||
((x) == nullptr ? dmlc::LogMessageFatal(__FILE__, __LINE__).stream() \ | ||
<< kTVM_INTERNAL_ERROR_MESSAGE << __INDENT << "Check not null: " #x \ | ||
<< ' ', \ | ||
(x) : (x)) // NOLINT(*) | ||
|
||
/*! \brief The diagnostic level, controls the printing of the message. */ | ||
enum class DiagnosticLevel : int { | ||
kBug = 10, | ||
kError = 20, | ||
kWarning = 30, | ||
kNote = 40, | ||
kHelp = 50, | ||
}; | ||
|
||
class DiagnosticBuilder; | ||
|
||
/*! \brief A compiler diagnostic. */ | ||
class Diagnostic; | ||
|
||
/*! \brief A compiler diagnostic message. */ | ||
class DiagnosticNode : public Object { | ||
public: | ||
/*! \brief The level. */ | ||
DiagnosticLevel level; | ||
/*! \brief The span at which to report an error. */ | ||
Span span; | ||
/*! \brief The diagnostic message. */ | ||
String message; | ||
|
||
// override attr visitor | ||
void VisitAttrs(AttrVisitor* v) { | ||
v->Visit("level", &level); | ||
v->Visit("span", &span); | ||
v->Visit("message", &message); | ||
} | ||
|
||
bool SEqualReduce(const DiagnosticNode* other, SEqualReducer equal) const { | ||
return equal(this->level, other->level) && equal(this->span, other->span) && | ||
equal(this->message, other->message); | ||
} | ||
|
||
static constexpr const char* _type_key = "Diagnostic"; | ||
TVM_DECLARE_FINAL_OBJECT_INFO(DiagnosticNode, Object); | ||
}; | ||
|
||
class Diagnostic : public ObjectRef { | ||
public: | ||
TVM_DLL Diagnostic(DiagnosticLevel level, Span span, const std::string& message); | ||
jroesch marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
static DiagnosticBuilder Bug(Span span); | ||
static DiagnosticBuilder Error(Span span); | ||
static DiagnosticBuilder Warning(Span span); | ||
static DiagnosticBuilder Note(Span span); | ||
static DiagnosticBuilder Help(Span span); | ||
|
||
TVM_DEFINE_NOTNULLABLE_OBJECT_REF_METHODS(Diagnostic, ObjectRef, DiagnosticNode); | ||
}; | ||
|
||
/*! | ||
* \brief A wrapper around std::stringstream to build a diagnostic. | ||
*/ | ||
class DiagnosticBuilder { | ||
public: | ||
/*! \brief The level. */ | ||
DiagnosticLevel level; | ||
|
||
/*! \brief The source name. */ | ||
SourceName source_name; | ||
|
||
/*! \brief The span of the diagnostic. */ | ||
Span span; | ||
|
||
template <typename T> | ||
DiagnosticBuilder& operator<<(const T& val) { // NOLINT(*) | ||
stream_ << val; | ||
return *this; | ||
} | ||
|
||
DiagnosticBuilder() : level(DiagnosticLevel::kError), source_name(), span(Span()) {} | ||
|
||
DiagnosticBuilder(const DiagnosticBuilder& builder) | ||
: level(builder.level), source_name(builder.source_name), span(builder.span) {} | ||
|
||
DiagnosticBuilder(DiagnosticLevel level, Span span) : level(level), span(span) {} | ||
|
||
operator Diagnostic() { return Diagnostic(this->level, this->span, this->stream_.str()); } | ||
|
||
private: | ||
std::stringstream stream_; | ||
friend class Diagnostic; | ||
}; | ||
|
||
/*! | ||
* \brief A diagnostic context for recording errors against a source file. | ||
*/ | ||
class DiagnosticContext; | ||
|
||
/*! \brief Display diagnostics in a given display format. | ||
* | ||
* A diagnostic renderer is responsible for converting the | ||
* raw diagnostics into consumable output. | ||
* | ||
* For example the terminal renderer will render a sequence | ||
* of compiler diagnostics to std::out and std::err in | ||
* a human readable form. | ||
*/ | ||
class DiagnosticRendererNode : public Object { | ||
public: | ||
TypedPackedFunc<void(DiagnosticContext ctx)> renderer; | ||
|
||
// override attr visitor | ||
void VisitAttrs(AttrVisitor* v) {} | ||
|
||
static constexpr const char* _type_key = "DiagnosticRenderer"; | ||
TVM_DECLARE_FINAL_OBJECT_INFO(DiagnosticRendererNode, Object); | ||
}; | ||
|
||
class DiagnosticRenderer : public ObjectRef { | ||
public: | ||
TVM_DLL DiagnosticRenderer(TypedPackedFunc<void(DiagnosticContext ctx)> render); | ||
TVM_DLL DiagnosticRenderer() | ||
: DiagnosticRenderer(TypedPackedFunc<void(DiagnosticContext ctx)>()) {} | ||
|
||
void Render(const DiagnosticContext& ctx); | ||
|
||
DiagnosticRendererNode* operator->() { | ||
CHECK(get() != nullptr); | ||
return static_cast<DiagnosticRendererNode*>(get_mutable()); | ||
} | ||
|
||
TVM_DEFINE_NOTNULLABLE_OBJECT_REF_METHODS(DiagnosticRenderer, ObjectRef, DiagnosticRendererNode); | ||
}; | ||
|
||
class DiagnosticContextNode : public Object { | ||
public: | ||
/*! \brief The Module to report against. */ | ||
IRModule module; | ||
|
||
/*! \brief The set of diagnostics to report. */ | ||
Array<Diagnostic> diagnostics; | ||
|
||
/*! \brief The renderer set for the context. */ | ||
DiagnosticRenderer renderer; | ||
|
||
void VisitAttrs(AttrVisitor* v) { | ||
v->Visit("module", &module); | ||
v->Visit("diagnostics", &diagnostics); | ||
} | ||
|
||
bool SEqualReduce(const DiagnosticContextNode* other, SEqualReducer equal) const { | ||
return equal(module, other->module) && equal(diagnostics, other->diagnostics); | ||
} | ||
|
||
static constexpr const char* _type_key = "DiagnosticContext"; | ||
TVM_DECLARE_FINAL_OBJECT_INFO(DiagnosticContextNode, Object); | ||
}; | ||
|
||
class DiagnosticContext : public ObjectRef { | ||
public: | ||
TVM_DLL DiagnosticContext(const IRModule& module, const DiagnosticRenderer& renderer); | ||
TVM_DLL static DiagnosticContext Default(const IRModule& source_map); | ||
|
||
/*! \brief Emit a diagnostic. | ||
* \param diagnostic The diagnostic to emit. | ||
*/ | ||
void Emit(const Diagnostic& diagnostic); | ||
|
||
/*! \brief Emit a diagnostic and then immediately attempt to render all errors. | ||
* | ||
* \param diagnostic The diagnostic to emit. | ||
* | ||
* Note: this will raise an exception if you would like to instead continue execution | ||
* use the Emit method instead. | ||
*/ | ||
void EmitFatal(const Diagnostic& diagnostic); | ||
jroesch marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
/*! \brief Render the errors and raise a DiagnosticError exception. */ | ||
void Render(); | ||
|
||
DiagnosticContextNode* operator->() { | ||
CHECK(get() != nullptr); | ||
jroesch marked this conversation as resolved.
Show resolved
Hide resolved
|
||
return static_cast<DiagnosticContextNode*>(get_mutable()); | ||
} | ||
|
||
TVM_DEFINE_NOTNULLABLE_OBJECT_REF_METHODS(DiagnosticContext, ObjectRef, DiagnosticContextNode); | ||
}; | ||
|
||
DiagnosticRenderer TerminalRenderer(std::ostream& ostream); | ||
|
||
} // namespace tvm | ||
#endif // TVM_IR_DIAGNOSTIC_H_ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should probably use
tests/lint/git-black.sh
andtests/lint/git-clang-format.sh
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So I think running Black without the caching is actually more aggressive/safe, but YMMV, happy to change it.