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

Respect $SOURCE_DATE_EPOCH in generate_bram_types_sim.py #4683

Merged
merged 1 commit into from
Jan 10, 2025

Conversation

keszybz
Copy link
Contributor

@keszybz keszybz commented Oct 24, 2024

What are the reasons/motivation for this change?

I'm working on build reproducibility of Fedora packages, and this patch fixes an issue observed in test rebuilds.

Explain how this is achieved.

The variable is set in build environments to allow the build to be reproducible (identical result in independent builds), see https://reproducible-builds.org/docs/source-date-epoch/. The code snippet is based on the sample from that page too.

If applicable, please suggest to reviewers how they can test the change.

Generate the output without $SOURCE_DATE_EPOCH set, which should result in a file with a current timestamp, and then again with SOURCE_DATE_EPOCH set, which should result in the specified timestamp.

@keszybz
Copy link
Contributor Author

keszybz commented Oct 24, 2024

Downstream pull request: https://src.fedoraproject.org/rpms/yosys/pull-request/5

with open(filename, "w") as f:
f.write("// **AUTOGENERATED FILE** **DO NOT EDIT**\n")
f.write(f"// Generated by {sys.argv[0]} at {datetime.now(timezone.utc)}\n")
f.write(f"// Generated by {sys.argv[0]} at {build_date}\n")
Copy link
Member

Choose a reason for hiding this comment

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

Do we even need the build date here? The file modification time indicates it already...

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 it's particularly useful, but meh, I don't care either way, as long as the file doesn't change between rebuilds ;)

Copy link
Collaborator

Choose a reason for hiding this comment

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

I think you can go ahead and remove the generation time outright. It's an outlier among the other "Generated by" string formatting in the codebase

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Updated.

I'm working on build reproducibility of Fedora packages, and this patch fixes
an issue observed in test rebuilds: the timestamp was set to the actual time
of the build, making builds nonreproducible.

Other "Generated by" strings do not include a timestamp, so drop it here too.
@keszybz keszybz force-pushed the use-SOURCE_DATE_EPOCH branch from ca688a8 to 26a3478 Compare October 30, 2024 07:49
@ldoolitt
Copy link
Contributor

Can "we" not forget about this pull request, please?

@widlarizer widlarizer merged commit 9f7040b into YosysHQ:main Jan 10, 2025
26 checks passed
@widlarizer
Copy link
Collaborator

Thanks for the reminder and sorry for the delay, I was used to a bitbucket-based project where everybody has merge permissions only blocked on requiring an approval

@keszybz keszybz deleted the use-SOURCE_DATE_EPOCH branch January 12, 2025 11:40
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