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

fix pitfall for comdat folding #15467

Merged
merged 6 commits into from
Jan 7, 2022
Merged

Conversation

jsteemann
Copy link
Contributor

@jsteemann jsteemann commented Jan 6, 2022

Scope & Purpose

Enterprise companion PR: https://github.com/arangodb/enterprise/pull/848

we have had 2 static methods with identical code, which returned the
addresses of the distinct method-local static objects. when enabling
comdat folding, the compiler decided to merge the two functions into
one, which gave both objects the same in-memory address.
this lead to follow-up errors because the object addresses were used to
tell two types of object (collections and views) apart.
this was not only error-prone, but also complicated. this PR replaces
all this with a simple enum class.

  • 💩 Bugfix (requires CHANGELOG entry)
  • 🍕 New feature (requires CHANGELOG entry, feature documentation and release notes)
  • 🔥 Performance improvement
  • 🔨 Refactoring/simplification
  • 📖 CHANGELOG entry made

Testing & Verification

  • This change is a trivial rework / code cleanup without any test coverage.
  • The behavior in this PR was manually tested

we have two static methods with identical code, which returned the
addresses of the distinct method-local static objects. when enabling
comdat folding, the compiler decided to merge the two functions into
one, which gave both objects the same in-memory address.
this lead to follow-up errors because the object addresses were used to
tell two types of object (collections and views) apart.
this was not only error-prone, but also complicated. this PR replaces
all this with a simple enum class.
@jsteemann jsteemann added this to the devel milestone Jan 6, 2022
@cla-bot cla-bot bot added the cla-signed label Jan 6, 2022
@mpoeter mpoeter self-requested a review January 6, 2022 08:30
@@ -105,7 +105,7 @@ class LogicalCollection : public LogicalDataSource {
};

/// @brief the category representing a logical collection
static Category const& category() noexcept;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it has to remain static as member is already present in LogicalDataSource

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think so. It is declared as pure virtual in LogicalDataSource.

@@ -124,7 +104,7 @@ class LogicalDataSource {

virtual ~LogicalDataSource() = default;

Category const& category() const noexcept { return _category; }
virtual Category category() const noexcept = 0;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

let's just store Category as a member to avoid unnecessary virtual calls

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That would also work, but I dislike that approach for the reason that then in theory it would be possible to create a LogicalView with category kCollection. I prefer the category to be part of the derived classes, so it's error-proof to use (and one less data member to carry around and think about). Of course this approach has the virtual calls as a downside, but I wouldn't expect any actual performance regression in our tests. Normally the category is determined once or maybe twice per LogicalDataSource for a high-level operation. E.g. an AQL query iterating over the docs in a collection will determine the category once or twice at start, but the actual query execution will not do it.
So it shouldn't really matter IMO.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@jsteemann we can add an assertion in LogicalCollection/LogicalView to ensure that category is correct

Copy link
Contributor

@gnusi gnusi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, but I believe we need to re-enable comdat folding on MSVC

@jsteemann jsteemann merged commit 09f39f0 into devel Jan 7, 2022
@jsteemann jsteemann deleted the bug-fix/fix-comdat-folding-pitfall branch January 7, 2022 12:34
markuspf pushed a commit that referenced this pull request Jan 10, 2022
Co-authored-by: Andrey Abramov <andrey@arangodb.com>
maierlars pushed a commit that referenced this pull request Jan 28, 2022
* Setup leader state machine functions

* Datastructure and test setup

* Skeletonizign

* First test code passes

* Implement Leadership election

* Implement some tests for running a leaderelection campaign

* velocyPackHell

* add forgotten file

* Split work up

* ...

* Fix compiler complaints

* Address linter complaints

* temp: update clang-format.yml

attempting to fix bad git diff

* Revert "temp: update clang-format.yml"

This reverts commit 02cda31.

* some light refactoring

* Fix bug in runElectionCampaign

* Add a test for leadership election terms

* Fix test comments and name

* Handle a corner case differently

* Remove rendundant comment

* Move to unified representation of Agency

* Rename files to make clearer what is supposed to to what

* Remove some no longer used files

* Add code for checking out target

* Add some stub code

* add more indexHints: `disableIndex` and `maxProjections` (#15446)

Co-authored-by: Michael Hackstein <michael@arangodb.com>

* fix pitfall for comdat folding (#15467)

Co-authored-by: Andrey Abramov <andrey@arangodb.com>

* small code cleanup (#15474)

* make it 2022 (#15466)

* [CINFRA-161] Follower State Transfer (#15352)

* Added log core to leader and follower.

* Rough sketch of snapshot transfer on followers.

* Added ILogLeader and ILogFollower interfaces.

* Optimized LogMultiplexer. Less copies of shared_ptrs.

* Added FakeReplicatedState.

* Fixing tests.

* Preparations for FollowerState tests.

* Renamed FakeFollower to FakeAbstractFollower.

* Added new FakeFollower.

* Moved interfaces to a separate header file.

* Moved LeaderStateManager and FollowerStateManager into sep. files.

* Completed first test run.

* Fixing use of temporary after expression.

* Code cleanup.

* Added missing include for mac.

* One more try for apple clang.

* Dropping std::totally_ordered because it is not supported by Jenkins apple-clang, using typename instead.

* Minor formatting

* Applied clang-format

* Reordered sources

* Fixed merge conflict

* Reformatted *.tpp files

* Switched to ParticipantResignedException

* Update arangod/Replication2/ReplicatedState/StateInterfaces.h

Co-authored-by: Alex Petenchea <alexandru.petenchea@arangodb.com>

* Use less special pointer.

Co-authored-by: apetenchea <alexandru.petenchea@arangodb.com>
Co-authored-by: Tobias Gödderz <tobias@arangodb.com>

* Move ReplicatedLog code into the correct place

* Make it build

* Fix compilation

* Use new code for supervision.

* add test

* Tests pass (or are deleted)

* Added test for setting a new leader.

* Sketch out checkReplicatedLog

* Stub out actions

* Bulk

* some more tests for Supervision functions

* Add some more harness code

* Remove LOG_DEVEL

* Added supervision trace if configured.

* all of it

* Fix supervision path

* Update participant flags

* Dictate leadership

* Added more tests for supervision.

* Resume all servers after each test.

* Added expected actions for changeLeader.

* More tests.

* Added experimental tests.

* LeaderElection

* Refactoring and cleanup of leader election

* Fix simple replication2 failover test

* Cleanup

* Remove stray console.log calls

* Fix testChangeLeader

* make more tests pass

* More tests 🎉

* Implement UpdateConfigAction

* Implement EvictLeader

* Added yet another test.

* An excluded server is not electible

* Remove redundant files

* Remove redundant files fixes

* Fixing unittests

* Fix embarassing crash

* Fix embarassing crash

* Enable Leader Replacement

* Fixing testCheckSimpleFailover. Sometimes leader was server[1].

* Added descriptions to tests. Exception handling supervision.

* Address comments

* remove stray file

* make clang-12 compile me again

* Fix a bug in testReplaceLeaderWithNewFollower

* Post errors to agency

* Add Supervision Errors

* removed targetConfig - discussed during review.

* make tests compile again

* Fix changing configuration through target

* be careful about leadership selection in Target

* Fix some tests

* Fix CMakeLists.txt

* make linter happy

* make linter happy

* Jslint.

* Fix shell tests

* Add a hack that fixes up when the user tries to add a log without participants

* clang-format

* Compiler nanny-ing

* More nanny

* clang format

* clang format

* MSVC complains that the defaulted constructor isn't defined

So we move it into the cpp file. Great good. So C++.

* Fix up some Agency Path cleanup fallout

* re-enable test

* Fix testLogStatus test

Co-authored-by: aMahanna <anthony.mahanna@gmail.com>
Co-authored-by: Jan <jsteemann@users.noreply.github.com>
Co-authored-by: Michael Hackstein <michael@arangodb.com>
Co-authored-by: Andrey Abramov <andrey@arangodb.com>
Co-authored-by: Lars Maier <lars@arangodb.com>
Co-authored-by: apetenchea <alexandru.petenchea@arangodb.com>
Co-authored-by: Tobias Gödderz <tobias@arangodb.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants