The Go Programming Language
Go to file
David Benoit caf6a247d6 Fix endian issue in FIPS mode
Resolves: rhbz#1966992
2022-11-30 22:32:05 -05:00
.gitignore Update go to version 1.19.2 2022-10-24 12:45:45 +00:00
000-initial-setup.patch Update go to version 1.19.2 2022-10-24 12:45:45 +00:00
001-initial-openssl-for-fips.patch Update go to version 1.19.2 2022-10-24 12:45:45 +00:00
disable_static_tests_part1.patch Update go to version 1.19.2 2022-10-24 12:45:45 +00:00
disable_static_tests_part2.patch Rebase to Go 1.19.1 2022-09-29 15:34:15 -04:00
enable-big-endian-fips-mode.patch Fix endian issue in FIPS mode 2022-11-30 22:32:05 -05:00
fedora.go RHEL 9.0.0 Alpha bootstrap 2020-10-15 02:06:09 +02:00
fix_TestScript_list_std.patch Rebase to Go 1.18.2 2022-05-31 16:56:54 -04:00
gating.yaml gating.yaml: Set up CI gating 2021-06-23 15:03:02 +02:00
go1.5-zoneinfo_testing_only.patch Rebase to Go 1.19.1 2022-09-29 15:34:15 -04:00
golang-gdbinit change over to RHEL 8.4 config instead of ELN 2020-11-12 15:03:09 -05:00
golang-prelink.conf change over to RHEL 8.4 config instead of ELN 2020-11-12 15:03:09 -05:00
golang.spec Fix endian issue in FIPS mode 2022-11-30 22:32:05 -05:00
openssl_cgo_build_tag.patch Rebase to Go 1.19.1 2022-09-29 15:34:15 -04:00
README.md Rebase to go-1.16.1-2-openssl-fips 2021-03-30 11:52:32 +02:00
runtime_pprof_wrong_mapping.patch Rebase to Go 1.19.1 2022-09-29 15:34:15 -04:00
skip_test_rhbz1939923.patch Rebase to Go 1.19.1 2022-09-29 15:34:15 -04:00
sources Update go to version 1.19.2 2022-10-24 12:45:45 +00:00

Golang

Introduction

This package holds the spec file and related patches for the Golang package. The golang package is part of the larger go-toolset meta package.

Sources

This particular branch provides Go 1.16.x. The sources for this branch can be found at https://pagure.io/go/tree/go1.16-openssl-fips. The reason the source is coming from a pagure fork as opposed to an upstream tarball is due to certain patches we have written and currently maintain in order to claim FIPS compliance by calling into OpenSSL. Shipping a forked version of the toolchain is not the ideal scenario, and there is work in progress with upstream to enable us to instead ship a pure upstream toolchain and include a crypto module in go-toolset which will satisfy our FIPS requirements.

The current fork is based on an upstream branch0 which uses boringcrypto1 instead of OpenSSL.

If you need to make changes to the source for a rebase or bug fix, check out the pagure repo and switch to the branch listed above. Once you have made your changes you can test them locally with ./all.bash. You may want to export GOLANG_FIPS=1 before running that if you want to verify the FIPS codepaths are correct. Please note however that the test suite does not fully expect FIPS compliance, and will attempt to test non FIPS compliant code paths. The easiest way to test your changes correctly is to create a tarball locally and execute a mockbuild using this packge, which knows how to correctly run the testsuite in both FIPS and non-FIPS modes.

NOTE: The way pagure previously handled uploaded releases has changed, and releases must be tagged in the appropriate branch, from which pagure will generate source tarballs.

Testing & building changes

The first test you should run is a local mockbuild. This can be done with the rhpkg command:

rhpkg mockbuild

Once everything builds and passes locally you'll likely want to perform a scratch build. This will ensure that the changes you made build and run correctly on all architectures that this package supports. The best way to do this is to run a scratch build from your local sources without first having to push them. This ensures your changes are correct before commiting them to the repo. This can also be done via the following rhpkg command:

rhpkg scratch-build --srpm

Once your scratch build has passed you can execute a real build:

rhpkg build

[0] https://github.com/golang/go/tree/dev.boringcrypto [1] https://opensource.google.com/projects/boringssl