Skip to content
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

[SR-2844] Compiler crash in MergeSwiftModule #45438

Closed
swift-ci opened this issue Oct 4, 2016 · 2 comments
Closed

[SR-2844] Compiler crash in MergeSwiftModule #45438

swift-ci opened this issue Oct 4, 2016 · 2 comments
Assignees
Labels
bug A deviation from expected or documented behavior. Also: expected but undesirable behavior. compiler The Swift compiler in itself crash Bug: A crash, i.e., an abnormal termination of software serialization Area → compiler: Serialization & deserialization

Comments

@swift-ci
Copy link
Collaborator

swift-ci commented Oct 4, 2016

Previous ID SR-2844
Radar None
Original Reporter xavierjurado (JIRA User)
Type Bug
Status Resolved
Resolution Done

Attachment: Download

Environment

Xcode 7.3.1 (7D1014), Local Swift Development Snapshot built from "swift-2.2.1-RELEASE" tag.

Additional Detail from JIRA
Votes 1
Component/s Compiler
Labels Bug, CompilerCrash, Serialization
Assignee @belkadan
Priority Medium

md5: 946c285e7abadddf653bac7de4965198

Issue Description:

Compiler crashes in the MergeSwiftModule step while building a project with the attached files. The crash can be avoided either by merging the two class declarations into a single file, or by renaming the instance/class var "pathComponents" to have a different name.

Important note: this issue can not be reproduced with the default toolchain bundled by Xcode 7.3.1, but it keeps crashing with our development build created from the swift-2.2.1-RELEASE tag.

Assertion failed:

Assertion failed: ((!FileContext || issue != Status::Malformed) && "error deserializing an individual record"), function error, file /Users/xavi/Desktop/swift-toolchain/swift/include/swift/Serialization/ModuleFile.h, line 355.
0  swift                    0x000000010696374b llvm::sys::PrintStackTrace(llvm::raw_ostream&) + 43
1  swift                    0x0000000106962a36 llvm::sys::RunSignalHandlers() + 70
2  swift                    0x0000000106963d1f SignalHandler(int) + 287
3  libsystem_platform.dylib 0x00007fff9afb352a _sigtramp + 26
4  libsystem_platform.dylib 0x00007fff61e585c8 _sigtramp + 3337244856
5  libsystem_c.dylib        0x00007fff875636df abort + 129
6  libsystem_c.dylib        0x00007fff8752add8 basename + 0
7  swift                    0x0000000104a6420f swift::ModuleFile::resolveCrossReference(swift::ModuleDecl*, unsigned int) + 4991
8  swift                    0x0000000104a578d4 swift::ModuleFile::getDecl(llvm::Fixnum<31u, unsigned int>, llvm::Optional<swift::DeclContext*>) + 10340
9  swift                    0x0000000104a5c15a swift::ModuleFile::getDecl(llvm::Fixnum<31u, unsigned int>, llvm::Optional<swift::DeclContext*>) + 28906
10 swift                    0x0000000104a652bd swift::ModuleFile::configureStorage(swift::AbstractStorageDecl*, unsigned int, llvm::Fixnum<31u, unsigned int>, llvm::Fixnum<31u, unsigned int>, llvm::Fixnum<31u, unsigned int>, llvm::Fixnum<31u, unsigned int>, llvm::Fixnum<31u, unsigned int>, llvm::Fixnum<31u, unsigned int>, llvm::Fixnum<31u, unsigned int>) + 621
11 swift                    0x0000000104a5a33a swift::ModuleFile::getDecl(llvm::Fixnum<31u, unsigned int>, llvm::Optional<swift::DeclContext*>) + 21194
12 swift                    0x0000000104a5cf4c swift::ModuleFile::maybeReadPattern() + 364
13 swift                    0x0000000104a5d346 swift::ModuleFile::maybeReadPattern() + 1382
14 swift                    0x0000000104a5901c swift::ModuleFile::getDecl(llvm::Fixnum<31u, unsigned int>, llvm::Optional<swift::DeclContext*>) + 16300
15 swift                    0x0000000104a62ddd swift::ModuleFile::readMembers(llvm::SmallVectorImpl<swift::Decl*>&) + 269
16 swift                    0x0000000104a65e65 swift::ModuleFile::loadAllMembers(swift::Decl*, unsigned long long) + 245
17 swift                    0x0000000104e22fbb swift::IterableDeclContext::loadAllMembers() const + 91
18 swift                    0x0000000104e116ec swift::NominalTypeDecl::getMembers(bool) const + 28
19 swift                    0x0000000104dadf77 (anonymous namespace)::Traversal::visitNominalTypeDecl(swift::NominalTypeDecl*) + 247
20 swift                    0x0000000104da999f (anonymous namespace)::Traversal::doIt(swift::Decl*) + 239
21 swift                    0x0000000104da989b swift::Decl::walk(swift::ASTWalker&) + 27
22 swift                    0x0000000104863b0b swift::ClassHierarchyAnalysis::init() + 155
23 swift                    0x0000000104858fd1 swift::createClassHierarchyAnalysis(swift::SILModule*) + 129
24 swift                    0x00000001048fbb3d swift::SILPassManager::SILPassManager(swift::SILModule*, llvm::StringRef) + 317
25 swift                    0x00000001049077d2 swift::runSILDiagnosticPasses(swift::SILModule&) + 130
26 swift                    0x000000010450fa4c performCompile(swift::CompilerInstance&, swift::CompilerInvocation&, llvm::ArrayRef<char const*>, int&) + 14060
27 swift                    0x000000010450b523 frontend_main(llvm::ArrayRef<char const*>, char const*, void*) + 2803
28 swift                    0x000000010450646c main + 1532
29 libdyld.dylib            0x00007fff969275ad start + 1
30 libdyld.dylib            0x0000000000000037 start + 1768786571

Stack dump:

0.  Program arguments: /Library/Developer/Toolchains/swift-LOCAL-2016-09-25-a.xctoolchain/usr/bin/swift -frontend -emit-module /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/Objects-normal/x86_64/AnotherRouter~partial.swiftmodule /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/Objects-normal/x86_64/ViewController~partial.swiftmodule /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/Objects-normal/x86_64/Router~partial.swiftmodule /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/Objects-normal/x86_64/AppDelegate~partial.swiftmodule /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/Objects-normal/x86_64/FirstCrash~partial.swiftmodule -parse-as-library -target x86_64-apple-ios9.3 -enable-objc-interop -sdk /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator9.3.sdk -I /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Products/Debug-iphonesimulator -F /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Products/Debug-iphonesimulator -enable-testing -g -module-cache-path /Users/xavi/Library/Developer/Xcode/DerivedData/ModuleCache -serialize-debugging-options -Xcc -I/Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/swift-overrides.hmap -Xcc -iquote -Xcc /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/SwiftCrashers-generated-files.hmap -Xcc -I/Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/SwiftCrashers-own-target-headers.hmap -Xcc -I/Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/SwiftCrashers-all-target-headers.hmap -Xcc -iquote -Xcc /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/SwiftCrashers-project-headers.hmap -Xcc -I/Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Products/Debug-iphonesimulator/include -Xcc -I/Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/DerivedSources/x86_64 -Xcc -I/Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/DerivedSources -Xcc -DDEBUG=1 -Xcc -working-directory/Users/xavi/Desktop/SwiftCrashers -emit-module-doc-path /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/Objects-normal/x86_64/SwiftCrashers.swiftdoc -module-name SwiftCrashers -emit-objc-header-path /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/Objects-normal/x86_64/SwiftCrashers-Swift.h -o /Users/xavi/Library/Developer/Xcode/DerivedData/SwiftCrashers-abozamfkptcbmsgqbgmumrgnbluz/Build/Intermediates/SwiftCrashers.build/Debug-iphonesimulator/SwiftCrashers.build/Objects-normal/x86_64/SwiftCrashers.swiftmodule 
1.  While loading members for 'AnotherRouter' at <invalid loc>
2.  While deserializing decl #&#8203;42 (PATTERN_BINDING_DECL)
3.  While deserializing 'pathComponent' (VarDecl #&#8203;43) 
4.  While deserializing '_' (FuncDecl #&#8203;44) 
5.  While deserializing decl #&#8203;58 (XREF)
6.  Cross-reference to module 'SwiftCrashers'
    ... Router
    ... pathComponent
    ... with type String
    ... (infix)
@belkadan
Copy link
Contributor

belkadan commented Feb 1, 2017

Finally getting around to this one. It was simple, too.

master: #7176 (already merged)
3.1: #7187

@belkadan
Copy link
Contributor

belkadan commented Feb 1, 2017

Merged in 36e166c.

@swift-ci swift-ci transferred this issue from apple/swift-issues Apr 25, 2022
@AnthonyLatsis AnthonyLatsis added the crash Bug: A crash, i.e., an abnormal termination of software label Dec 12, 2022
This issue was closed.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug A deviation from expected or documented behavior. Also: expected but undesirable behavior. compiler The Swift compiler in itself crash Bug: A crash, i.e., an abnormal termination of software serialization Area → compiler: Serialization & deserialization
Projects
None yet
Development

No branches or pull requests

3 participants