blob: cfea4df2fead42c871cab473ae0fda9f42839e2f (
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
|
# Copyright 1999-2014 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
inherit eutils flag-o-matic
DESCRIPTION="An MBR that can handle BIOS-based boot on GPT"
MY_P="${PN}_${PV}"
HOMEPAGE="http://aybabtu.com/mbr-gpt/"
SRC_URI="http://aybabtu.com/mbr-gpt/${MY_P}.tar.gz"
LICENSE="GPL-2"
SLOT="0"
# This should probably NEVER go to stable. It's crazy advanced dangerous magic.
# It's also pure ASM, so not suitable for elsewhere anyway.
KEYWORDS="~x86 ~amd64"
IUSE=""
# It only depends on binutils/gcc/make, and doesn't link against libc even.
DEPEND=""
RDEPEND=""
# It's a mostly an MBR block and it does use the executable stack.
QA_WX_LOAD="usr/sbin/boot.elf"
src_unpack() {
unpack ${A}
cd "${S}"
emake clean
# Need to build it 32-bit for the MBR
# Btw, no CFLAGS are respected, it's ASM!
use amd64 && sed -i -e 's/-Wall/-Wall -m32/g' "${S}"/Makefile
}
src_compile() {
emake CC="$(tc-getCC)"
}
src_install() {
# get_libdir is not correct here. We want this to go into a 32-bit library
# location.
insinto /usr/lib/mbr-gpt/
doins mbr
dosbin boot.elf
dodoc AUTHORS
}
pkg_postinst() {
einfo "See the instructions on the homepage, and make sure you know what"
einfo "you are doing before touching this. The mbr file does into your"
einfo "MBR, or alternatively you can do a creative reboot utilizing the"
einfo "boot.elf binary."
}
|