1 Commits

Author SHA1 Message Date
Jay Larson
2de20ac6fa The following changes were made:
* removed mounting tmp filesystems from user (now done by snap)
  * split off separate doc package
  * Added package name override to prevent duplicated version string in name
  * removed version string from file name (Makefile.linux-headers)
2017-05-22 09:33:23 -05:00
6 changed files with 54 additions and 43 deletions

View File

@@ -16,36 +16,55 @@ BRIEF = The Linux kernel
DESC = Linux is a clone of the operating system Unix, written from scratch \ DESC = Linux is a clone of the operating system Unix, written from scratch \
by Linus Torvalds with assistance from a loosely-knit team of hackers \ by Linus Torvalds with assistance from a loosely-knit team of hackers \
across the Net. across the Net.
SNAPVER = 3 export SNAPVER = 4
ARCHIVE := $(PWD)/SRC/$(shell ls SRC|egrep '(bz2|gz|tar|xz)$$'|tail -1) ARCHIVE := $(PWD)/SRC/$(shell ls SRC|egrep '(bz2|gz|tar|xz)$$'|tail -1)
TYPE := $(shell file -ib $(ARCHIVE)|cut -d';' -f1|tr -d '\n') TYPE := $(shell file -ib $(ARCHIVE)|cut -d';' -f1|tr -d '\n')
SRCDIR := $(shell tar -tf $(ARCHIVE)|head -1|sed 's/\/.*//') SRCDIR := $(shell tar -tf $(ARCHIVE)|head -1|sed 's/\/.*//')
PATCHDIR := $(PWD)/SRC/patches PATCHDIR := $(PWD)/SRC/patches
export KERNVER := $(shell echo $(SRCDIR)|egrep -o '\-[0-9].*'|sed 's/^-//') export KERNVER := $(shell echo $(SRCDIR)|egrep -o '\-[0-9].*'|sed 's/^-//')
export VERSION := $(SNAPVER) export VERSION := $(KERNVER)-$(SNAPVER)
LINUX-FIRMWARE := $(PWD)/linux-firmware # This overrids the package file name in Makefile.snaplinux
# This is necessary due to the kernel version string being
# a part of the package name
SNAP = $(PACKAGE)-$(SNAPVER).snap
LINUX-DOC := $(PWD)/linux-doc-$(KERNVER)
LINUX-DOC-ROOT := $(LINUX-DOC)/ROOT
LINUX-FIRMWARE := $(PWD)/linux-firmware-$(KERNVER)
LINUX-FIRMWARE-ROOT := $(LINUX-FIRMWARE)/ROOT LINUX-FIRMWARE-ROOT := $(LINUX-FIRMWARE)/ROOT
LINUX-HEADERS := $(PWD)/linux-headers-$(KERNVER) LINUX-HEADERS := $(PWD)/linux-headers-$(KERNVER)
LINUX-HEADERS-ROOT := $(LINUX-HEADERS)/ROOT LINUX-HEADERS-ROOT := $(LINUX-HEADERS)/ROOT
include /usr/share/snap/Makefile.snaplinux include /usr/share/snap/Makefile.snaplinux
$(LINUX-DOC-ROOT): $(LINUX-HEADERS-ROOT)
@install -v -d $(LINUX-DOC)/SNAP && \
install -v -d $(LINUX-DOC-ROOT) && \
install -d -m 755 \
$(LINUX-DOC-ROOT)/usr/share/doc/linux-$(VERSION) && \
cp -r $(SRCDIR)/Documentation/* \
$(LINUX-DOC-ROOT)/usr/share/doc/linux-$(VERSION) && \
find $(LINUX-DOC-ROOT) -name \*.txt -o -name \*.html \
-exec gzip {} \; && \
cd $(LINUX-DOC) && make -f ../Makefile.linux-doc && mv *.snap ../
$(LINUX-HEADERS-ROOT): $(LINUX-FIRMWARE-ROOT) $(LINUX-HEADERS-ROOT): $(LINUX-FIRMWARE-ROOT)
@install -v -d $(LINUX-HEADERS)/SNAP && \ @install -v -d $(LINUX-HEADERS)/SNAP && \
install -v -d $(LINUX-HEADERS-ROOT) && \ install -v -d $(LINUX-HEADERS-ROOT) && \
cd $(SRCDIR) && make headers_install \ cd $(SRCDIR) && make headers_install \
INSTALL_HDR_PATH=$(LINUX-HEADERS-ROOT)/usr && \ INSTALL_HDR_PATH=$(LINUX-HEADERS-ROOT)/usr && \
cd $(LINUX-HEADERS) && make -f \ cd $(LINUX-HEADERS) && make -f \
../Makefile.linux-headers-$(KERNVER) && \ ../Makefile.linux-headers && \
mv *.snap ../ mv *.snap ../
$(LINUX-FIRMWARE-ROOT): $(SRCDIR)/arch/x86_64/boot/bzImage $(LINUX-FIRMWARE-ROOT): $(SRCDIR)/arch/x86_64/boot/bzImage
@install -v -d $(LINUX-FIRMWARE)/SNAP && \ @install -v -d $(LINUX-FIRMWARE)/SNAP && \
install -v -d $(LINUX-FIRMWARE-ROOT) && \ install -v -d $(LINUX-FIRMWARE-ROOT)/lib/firmware && \
cd $(SRCDIR) && make firmware_install \ cd $(SRCDIR) && make firmware_install \
INSTALL_FW_PATH=$(LINUX-FIRMWARE-ROOT) && \ INSTALL_FW_PATH=$(LINUX-FIRMWARE-ROOT)/lib/firmware && \
cd $(LINUX-FIRMWARE) && make -f \ cd $(LINUX-FIRMWARE) && make -f \
../Makefile.linux-firmware && mv *.snap ../ ../Makefile.linux-firmware && mv *.snap ../
@@ -67,11 +86,11 @@ $(SRCDIR)/Makefile: $(ARCHIVE)
$(SRCDIR)/arch/x86_64/boot/bzImage: $(SRCDIR)/Makefile $(SRCDIR)/arch/x86_64/boot/bzImage: $(SRCDIR)/Makefile
@cd $(SRCDIR); \ @cd $(SRCDIR); \
make mrproper make mrproper
@cp SNAP/config-$(KERNVER)-$(VERSION) $(SRCDIR)/.config @cp SNAP/config $(SRCDIR)/.config
@cd $(SRCDIR); \ @cd $(SRCDIR); \
make make
$(ROOT): $(LINUX-HEADERS-ROOT) $(ROOT): $(LINUX-DOC-ROOT)
@if [ -d $(ROOT) ]; then \ @if [ -d $(ROOT) ]; then \
touch $(ROOT); \ touch $(ROOT); \
else \ else \
@@ -83,14 +102,12 @@ $(ROOT): $(LINUX-HEADERS-ROOT)
rm -rf $(ROOT)/lib/firmware && \ rm -rf $(ROOT)/lib/firmware && \
install -d -m 755 $(ROOT)/boot && \ install -d -m 755 $(ROOT)/boot && \
install -d -m 755 $(ROOT)/etc/modprobe.d && \ install -d -m 755 $(ROOT)/etc/modprobe.d && \
install -d -m 755 $(ROOT)/usr/share/doc/linux-$(KERNVER)-$(VERSION) && \ install -m 644 .config $(ROOT)/boot/config-$(VERSION) && \
install -m 644 .config $(ROOT)/boot/config-$(KERNVER)-$(VERSION) && \
install -m 644 System.map \ install -m 644 System.map \
$(ROOT)/boot/System.map-$(KERNVER)-$(VERSION) && \ $(ROOT)/boot/System.map-$(VERSION) && \
install -m 644 arch/x86_64/boot/bzImage \ install -m 644 arch/x86_64/boot/bzImage \
$(ROOT)/boot/vmlinuz-$(KERNVER)-$(VERSION) && \ $(ROOT)/boot/vmlinuz-$(VERSION) && \
install -m 644 ../SNAP/usb.conf $(ROOT)/etc/modprobe.d/usb.conf && \ install -m 644 ../SNAP/usb.conf $(ROOT)/etc/modprobe.d/usb.conf
cp -r Documentation/* $(ROOT)/usr/share/doc/linux-$(KERNVER)-$(VERSION)
test: $(ROOT) test: $(ROOT)
@cd $(SRCDIR); \ @cd $(SRCDIR); \

15
Makefile.linux-doc Normal file
View File

@@ -0,0 +1,15 @@
# This file is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 as
# published by the Free Software Foundation here:
# (http://www.gnu.org/licenses/gpl-2.0.html)
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
BRIEF = Documentation for The Linux kernel
DESC = Detailed documentation describing the Linux kernel
SNAP = $(PACKAGE)-$(SNAPVER).snap
include /usr/share/snap/Makefile.snaplinux

View File

@@ -11,7 +11,7 @@
DEPENDS = DEPENDS =
BRIEF = Firmware for the Linux kernel BRIEF = Firmware for the Linux kernel
DESC = This provides the firmware necessary for some Linux kernel modules DESC = This provides the firmware necessary for some Linux kernel modules
SNAPVER = 0
VERSION = $(KERNVER)-$(SNAPVER) VERSION = $(KERNVER)-$(SNAPVER)
SNAP = $(PACKAGE)-$(SNAPVER).snap
include /usr/share/snap/Makefile.snaplinux include /usr/share/snap/Makefile.snaplinux

View File

@@ -11,5 +11,6 @@
BRIEF = Header files for The Linux kernel BRIEF = Header files for The Linux kernel
DESC = This provides the header files that are generally used to compile \ DESC = This provides the header files that are generally used to compile \
kernel modules kernel modules
SNAP = $(PACKAGE)-$(SNAPVER).snap
include /usr/share/snap/Makefile.snaplinux include /usr/share/snap/Makefile.snaplinux

View File

@@ -7,37 +7,15 @@ case $1 in
exit 0 exit 0
;; ;;
postinst) postinst)
KERNEL_VER=`ls -C1rt ${TARGET}/boot/vmlinuz*|sed 's/.*vmlinuz-//'`
if [[ ${TARGET} ]]; then if [[ ${TARGET} ]]; then
echo "Running within ${TARGET} for kernel $KERNEL_VER" echo "Running within ${TARGET} for kernel ${VERSION}"
if ! mountpoint -q ${TARGET}/dev; then chroot ${TARGET} mkinitramfs ${VERSION}
mount -t devtmpfs none ${TARGET}/dev chroot ${TARGET} grub-mkconfig -o /boot/grub/grub.cfg
fi
if ! mountpoint -q ${TARGET}/proc; then
mount -t proc none ${TARGET}/proc
fi
if ! mountpoint -q ${TARGET}/sys; then
mount -t sysfs none ${TARGET}/sys
fi
chroot ${TARGET} /bin/bash -c "/sbin/mkinitramfs $KERNEL_VER"
chroot ${TARGET} /bin/bash -c \
"/sbin/grub-mkconfig -o /boot/grub/grub.cfg"
if mountpoint -q ${TARGET}/dev; then
umount ${TARGET}/dev
fi
if mountpoint -q ${TARGET}/proc; then
umount ${TARGET}/proc
fi
if mountpoint -q ${TARGET}/sys; then
umount ${TARGET}/sys
fi
else else
echo "Running for kernel $KERNEL_VER" echo "Running for kernel ${VERSION}"
mkinitramfs $KERNEL_VER
mkinitramfs ${VERSION}
grub-mkconfig -o /boot/grub/grub.cfg grub-mkconfig -o /boot/grub/grub.cfg
fi fi
;; ;;