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

Share objectives between nodes #2754

Open
wants to merge 20 commits into
base: main
Choose a base branch
from
Open

Conversation

BAGUVIX456
Copy link
Contributor

fixes issue #1917

@BAGUVIX456
Copy link
Contributor Author

Do tell me if I have overlooked anything. Also, is this okay as a compile-time option?

@tokatoka
Copy link
Member

tokatoka commented Dec 8, 2024

Also, is this okay as a compile-time option?

yeah

@domenukk domenukk requested a review from addisoncrump December 9, 2024 11:17
@tokatoka tokatoka marked this pull request as draft December 10, 2024 09:45
@BAGUVIX456
Copy link
Contributor Author

Does LibAFL have a preferred way to tackle conditional trait bounds based on compile-time features? I am having to add optional trait bounds by dividing implementations based on features, and is causing massive code duplication

@tokatoka
Copy link
Member

The implementation of MaybeHasClientPerfMonitor could answer your question

@BAGUVIX456
Copy link
Contributor Author

@tokatoka is this issue fixed? Should I stop working on this issue?

@tokatoka
Copy link
Member

no i closed because you have this PR

@domenukk
Copy link
Member

I suggest we leave issues open until they are actually fixed in main

@BAGUVIX456 BAGUVIX456 marked this pull request as ready for review December 15, 2024 18:48
@BAGUVIX456 BAGUVIX456 requested a review from tokatoka December 15, 2024 18:49
@BAGUVIX456 BAGUVIX456 marked this pull request as draft December 15, 2024 19:27
@BAGUVIX456
Copy link
Contributor Author

@tokatoka could you explain what are you trying to do in PRs #2761 and #2745? i am having trouble fixing conflicts

@BAGUVIX456 BAGUVIX456 marked this pull request as ready for review December 16, 2024 22:12
@BAGUVIX456
Copy link
Contributor Author

Any idea why msrv is failing? cargo hack worked fine for me locally

@Mrmaxmeier
Copy link
Contributor

Mrmaxmeier commented Dec 17, 2024

Any idea why msrv is failing? cargo hack worked fine for me locally

Seems like the home crate updated their MSRV without a major version bump so building with fresh/up-to-date crates leads to a MSRV mismatch

@BAGUVIX456
Copy link
Contributor Author

Should I try implementing this in some other way?

@BAGUVIX456 BAGUVIX456 marked this pull request as draft December 24, 2024 17:10
@BAGUVIX456
Copy link
Contributor Author

@tokatoka I am having to declare the method perform() of the Stage trait twice on merging the duplicate impl blocks in stages/sync.rs, one with the required additional trait bounds and other being the original definition. The other way to merge the impl blocks would be to trivially add the trait bounds without cfg flags, which would have no code duplication but we would be left with a redundant bound when objectives are not shared. How do I proceed with this?

@BAGUVIX456 BAGUVIX456 changed the title Add optional feature to share objectives between nodes Share objectives between nodes Jan 5, 2025
@tokatoka
Copy link
Member

tokatoka commented Jan 9, 2025

Hey @BAGUVIX456 , sorry I was in holidays before and I am just back today.

which would have no code duplication but we would be left with a redundant bound when objectives are not shared.

this is okay.
to be specific you can avoid this problem if you do in a way similar to how MaybeHasClientPerfMonitor
See this snippet

#[cfg(feature = "introspection")]
/// Trait for offering a [`ClientPerfMonitor`]
pub trait HasClientPerfMonitor {
    /// [`ClientPerfMonitor`] itself
    fn introspection_monitor(&self) -> &ClientPerfMonitor;

    /// Mutatable ref to [`ClientPerfMonitor`]
    fn introspection_monitor_mut(&mut self) -> &mut ClientPerfMonitor;
}

/// Intermediate trait for `HasClientPerfMonitor`
#[cfg(feature = "introspection")]
pub trait MaybeHasClientPerfMonitor: HasClientPerfMonitor {}

/// Intermediate trait for `HasClientPerfmonitor`
#[cfg(not(feature = "introspection"))]
pub trait MaybeHasClientPerfMonitor {}

but you don't have to.
Overspecifying a bit is fine.

@tokatoka
Copy link
Member

tokatoka commented Jan 9, 2025

If you are ready change this to "Ready for review"

You'll see merge conflict, but I'll merge for you, tell me when you need to merge

@BAGUVIX456 BAGUVIX456 marked this pull request as ready for review January 9, 2025 16:19
@BAGUVIX456
Copy link
Contributor Author

BAGUVIX456 commented Jan 9, 2025

I'm assuming the failing CIs are not an issue? Do tell me if I have to fix them before merging

@tokatoka
Copy link
Member

tokatoka commented Jan 9, 2025

you can ignore them now.
for now, just de-duplicate the code by overspecifying.
after that i fix the conflict
and then if there's still problem remaining regarding clippy, plz fix them

@BAGUVIX456
Copy link
Contributor Author

yeah i have deduplicated the code already, you can go ahead

@@ -472,6 +472,9 @@ pub fn run_observers_and_save_state<E, EM, OF, Z>(
.fire(
state,
Event::Objective {
#[cfg(feature = "share_objectives")]
input: input.clone(),
Copy link
Member

Choose a reason for hiding this comment

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

do you need clone()?

@@ -469,6 +469,12 @@ where
}
}
}

#[cfg(feature = "share_objectives")]
Copy link
Member

Choose a reason for hiding this comment

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

here put the same code as you did in llmp/mod.rs

@@ -645,8 +645,17 @@ where
}

#[cfg(feature = "share_objectives")]
Copy link
Member

Choose a reason for hiding this comment

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

Can we add a runtime flag instead of compile time? Overhead should be minimal and it's easier to use IMHO

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants