blob: 73f27787890e16cd53850f4757b3e148931be669 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
|
# Copyright 1999-2022 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
inherit toolchain-funcs
DESCRIPTION="The UEFI Boot Manager by Rod Smith"
HOMEPAGE="https://www.rodsbooks.com/refind/"
SRC_URI="mirror://sourceforge/project/${PN}/${PV}/${PN}-src-${PV}.tar.gz"
LICENSE="BSD GPL-2 GPL-3 FDL-1.3"
SLOT="0"
KEYWORDS="~amd64 ~x86"
FS_USE="btrfs +ext2 +ext4 hfs +iso9660 ntfs reiserfs"
IUSE="${FS_USE} custom-cflags doc"
DEPEND="sys-boot/gnu-efi"
DOCS=( README.txt )
pkg_pretend() {
if use custom-cflags; then
ewarn
ewarn "You have enabled building with USE=custom-cflags. Be aware that"
ewarn "using this can result in EFI binaries that fail to run and may"
ewarn "fail to build at all. This is strongly advised against by upstream."
ewarn
ewarn "See https://bugs.gentoo.org/598587#c3 for more information"
ewarn
fi
}
pkg_setup() {
if use x86; then
export EFIARCH=ia32
export BUILDARCH=ia32
elif use amd64; then
export EFIARCH=x64
export BUILDARCH=x86_64
fi
}
src_prepare() {
default
# bug 598647 - PIE not supported
sed -e '/^CFLAGS/s/$/ -fno-PIE/' -i Make.common || die
sed -e '1 i\.NOTPARALLEL:' -i filesystems/Makefile || die
}
src_compile() {
# Update fs targets depending on uses
local fs fs_names=()
for fs in ${FS_USE}; do
fs=${fs#+}
if use "${fs}"; then
fs_names+=(${fs})
fi
done
fs_names=("${fs_names[@]/%/_gnuefi}")
# Prepare flags
local make_flags=(
ARCH="${BUILDARCH}"
CC="$(tc-getCC)"
AS="$(tc-getAS)"
LD="$(tc-getLD)"
AR="$(tc-getAR)"
RANLIB="$(tc-getRANLIB)"
OBJCOPY="$(tc-getOBJCOPY)"
GNUEFILIB="/usr/$(get_libdir)"
EFILIB="/usr/$(get_libdir)"
EFICRT0="/usr/$(get_libdir)"
FILESYSTEMS="${fs_names[*]}"
FILESYSTEMS_GNUEFI="${fs_names[*]}"
)
if use custom-cflags; then
make_flags=(CFLAGS="${CFLAGS} -fno-tree-loop-distribute-patterns" "${make_flags[@]}")
fi
emake "${make_flags[@]}" all_gnuefi
}
src_install() {
exeinto "/usr/$(get_libdir)/${PN}"
doexe refind-install
dosym "../$(get_libdir)/${PN}/refind-install" "/usr/sbin/refind-install"
if use doc; then
doman "docs/man/"*
DOCS+=(NEWS.txt docs/refind docs/Styles)
fi
einstalldocs
insinto "/usr/$(get_libdir)/${PN}/refind"
doins "refind/refind_${EFIARCH}.efi"
doins "refind.conf-sample"
doins -r images icons fonts banners
if [[ -d "drivers_${EFIARCH}" ]]; then
doins -r "drivers_${EFIARCH}"
fi
insinto "/usr/$(get_libdir)/${PN}/refind/tools_${EFIARCH}"
doins "gptsync/gptsync_${EFIARCH}.efi"
insinto "/etc/refind.d"
doins -r "keys"
dosbin "mkrlconf"
dosbin "mvrefind"
dosbin "refind-mkdefault"
}
pkg_postinst() {
elog "rEFInd has been built and installed into ${EROOT}/usr/$(get_libdir)/${PN}"
elog "You will need to use the command 'refind-install' to install"
elog "the binaries into your EFI System Partition"
elog ""
elog "refind-install requires additional packages to be fully functional:"
elog " app-crypt/sbsigntools for binary signing for use with SecureBoot"
elog " sys-boot/efibootmgr for writing to NVRAM"
elog " sys-apps/gptfdisk for ESP management"
elog ""
elog "refind-mkdefault requires >=dev-lang/python-3"
elog ""
if [[ -z "${REPLACING_VERSIONS}" ]]; then
elog "A sample configuration can be found at"
elog "${EROOT}/usr/$(get_libdir)/${PN}/refind/refind.conf-sample"
else
if ver_test "${REPLACING_VERSIONS}" -lt "0.12.0"; then
ewarn "This new version uses sys-apps/gptfdisk instead of sys-block/parted"
ewarn "to manage ESP"
ewarn ""
fi
ewarn "Note that this installation will not update any EFI binaries"
ewarn "on your EFI System Partition - this needs to be done manually"
fi
}
|