]>
Commit | Line | Data |
---|---|---|
6d345395 TL |
1 | include /usr/share/dpkg/pkg-info.mk |
2 | ||
6e72c5b2 | 3 | # also bump proxmox-kernel-meta if the default MAJ.MIN version changes! |
67ec0da2 | 4 | KERNEL_MAJ=6 |
fd2107cc | 5 | KERNEL_MIN=2 |
43bc5742 | 6 | KERNEL_PATCHLEVEL=16 |
6e72c5b2 | 7 | # increment KREL for every published package release! |
8b4e1fa9 | 8 | # rebuild packages with new KREL and run 'make abiupdate' |
498d87be | 9 | KREL=18 |
44403fcc | 10 | |
5fd5ec0e SI |
11 | KERNEL_MAJMIN=$(KERNEL_MAJ).$(KERNEL_MIN) |
12 | KERNEL_VER=$(KERNEL_MAJMIN).$(KERNEL_PATCHLEVEL) | |
13 | ||
8fbdb63a TL |
14 | EXTRAVERSION=-$(KREL)-pve |
15 | KVNAME=$(KERNEL_VER)$(EXTRAVERSION) | |
6e72c5b2 FG |
16 | PACKAGE=proxmox-kernel-$(KVNAME) |
17 | HDRPACKAGE=proxmox-headers-$(KVNAME) | |
ba2f1a67 | 18 | |
37d1225d | 19 | ARCH=$(shell dpkg-architecture -qDEB_BUILD_ARCH) |
6490543b TL |
20 | |
21 | # amd64/x86_64/x86 share the arch subdirectory in the kernel, 'x86' so we need | |
22 | # a mapping | |
23 | KERNEL_ARCH=x86 | |
8fbdb63a TL |
24 | ifneq ($(ARCH), amd64) |
25 | KERNEL_ARCH=$(ARCH) | |
6490543b TL |
26 | endif |
27 | ||
41f5ee98 FG |
28 | SKIPABI=0 |
29 | ||
6e72c5b2 | 30 | BUILD_DIR=proxmox-kernel-$(KERNEL_VER) |
ba2f1a67 | 31 | |
00d66e96 | 32 | KERNEL_SRC=ubuntu-kernel |
5fd5ec0e | 33 | KERNEL_SRC_SUBMODULE=submodules/$(KERNEL_SRC) |
8fbdb63a | 34 | KERNEL_CFG_ORG=config-$(KERNEL_VER).org |
ba2f1a67 | 35 | |
2e38f6f9 | 36 | ZFSONLINUX_SUBMODULE=submodules/zfsonlinux |
66aed5b8 | 37 | ZFSDIR=pkg-zfs |
e96d2ab3 | 38 | |
66aed5b8 | 39 | MODULES=modules |
8fbdb63a | 40 | MODULE_DIRS=$(ZFSDIR) |
ba2f1a67 | 41 | |
66aed5b8 | 42 | # exported to debian/rules via debian/rules.d/dirs.mk |
5fa6b6ae | 43 | DIRS=KERNEL_SRC ZFSDIR MODULES |
66aed5b8 | 44 | |
de185308 FG |
45 | DSC=proxmox-kernel-$(KERNEL_MAJMIN)_$(KERNEL_VER)-$(KREL).dsc |
46 | DST_DEB=$(PACKAGE)_$(KERNEL_VER)-$(KREL)_$(ARCH).deb | |
47 | META_DEB=proxmox-kernel-$(KERNEL_MAJMIN)_$(KERNEL_VER)-$(KREL)_all.deb | |
48 | HDR_DEB=$(HDRPACKAGE)_$(KERNEL_VER)-$(KREL)_$(ARCH).deb | |
49 | META_HDR_DEB=proxmox-headers-$(KERNEL_MAJMIN)_$(KERNEL_VER)-$(KREL)_all.deb | |
50 | USR_HDR_DEB=proxmox-kernel-libc-dev_$(KERNEL_VER)-$(KREL)_$(ARCH).deb | |
51 | LINUX_TOOLS_DEB=linux-tools-$(KERNEL_MAJMIN)_$(KERNEL_VER)-$(KREL)_$(ARCH).deb | |
52 | LINUX_TOOLS_DBG_DEB=linux-tools-$(KERNEL_MAJMIN)-dbgsym_$(KERNEL_VER)-$(KREL)_$(ARCH).deb | |
ba2f1a67 | 53 | |
6e72c5b2 | 54 | DEBS=$(DST_DEB) $(META_DEB) $(HDR_DEB) $(META_HDR_DEB) $(LINUX_TOOLS_DEB) $(LINUX_TOOLS_DBG_DEB) # $(USR_HDR_DEB) |
ba2f1a67 | 55 | |
2135c723 | 56 | all: deb |
8fbdb63a TL |
57 | deb: $(DEBS) |
58 | ||
6e72c5b2 | 59 | $(META_DEB) $(META_HDR_DEB) $(LINUX_TOOLS_DEB) $(HDR_DEB): $(DST_DEB) |
8fbdb63a TL |
60 | $(DST_DEB): $(BUILD_DIR).prepared |
61 | cd $(BUILD_DIR); dpkg-buildpackage --jobs=auto -b -uc -us | |
62 | lintian $(DST_DEB) | |
63 | #lintian $(HDR_DEB) | |
64 | lintian $(LINUX_TOOLS_DEB) | |
65 | ||
e55f32e3 TL |
66 | dsc: |
67 | $(MAKE) $(DSC) | |
68 | lintian $(DSC) | |
69 | ||
ecf7b6eb TL |
70 | $(DSC): $(BUILD_DIR).prepared |
71 | cd $(BUILD_DIR); dpkg-buildpackage -S -uc -us -d | |
ecf7b6eb | 72 | |
8b45a37b TL |
73 | sbuild: $(DSC) |
74 | sbuild $(DSC) | |
75 | ||
8fbdb63a TL |
76 | $(BUILD_DIR).prepared: $(addsuffix .prepared,$(KERNEL_SRC) $(MODULES) debian) |
77 | cp -a fwlist-previous $(BUILD_DIR)/ | |
78 | cp -a abi-prev-* $(BUILD_DIR)/ | |
79 | cp -a abi-blacklist $(BUILD_DIR)/ | |
66aed5b8 FG |
80 | touch $@ |
81 | ||
5ba48a84 TL |
82 | .PHONY: build-dir-fresh |
83 | build-dir-fresh: | |
84 | $(MAKE) clean | |
85 | $(MAKE) $(BUILD_DIR).prepared | |
86 | echo "created build-directory: $(BUILD_DIR).prepared/" | |
87 | ||
66aed5b8 | 88 | debian.prepared: debian |
8fbdb63a TL |
89 | rm -rf $(BUILD_DIR)/debian |
90 | mkdir -p $(BUILD_DIR) | |
91 | cp -a debian $(BUILD_DIR)/debian | |
5c467ccb TL |
92 | echo "git clone git://git.proxmox.com/git/pve-kernel.git\\ngit checkout $(shell git rev-parse HEAD)" \ |
93 | >$(BUILD_DIR)/debian/SOURCE | |
8fbdb63a TL |
94 | @$(foreach dir, $(DIRS),echo "$(dir)=$($(dir))" >> $(BUILD_DIR)/debian/rules.d/env.mk;) |
95 | echo "KVNAME=$(KVNAME)" >> $(BUILD_DIR)/debian/rules.d/env.mk | |
96 | echo "KERNEL_MAJMIN=$(KERNEL_MAJMIN)" >> $(BUILD_DIR)/debian/rules.d/env.mk | |
97 | cd $(BUILD_DIR); debian/rules debian/control | |
ba2f1a67 FG |
98 | touch $@ |
99 | ||
8fbdb63a TL |
100 | $(KERNEL_SRC).prepared: $(KERNEL_SRC_SUBMODULE) | submodule |
101 | rm -rf $(BUILD_DIR)/$(KERNEL_SRC) $@ | |
102 | mkdir -p $(BUILD_DIR) | |
103 | cp -a $(KERNEL_SRC_SUBMODULE) $(BUILD_DIR)/$(KERNEL_SRC) | |
e96d2ab3 | 104 | # TODO: split for archs, track and diff in our repository? |
8fbdb63a TL |
105 | cd $(BUILD_DIR)/$(KERNEL_SRC); python3 debian/scripts/misc/annotations --arch amd64 --export >../../$(KERNEL_CFG_ORG) |
106 | cp $(KERNEL_CFG_ORG) $(BUILD_DIR)/$(KERNEL_SRC)/.config | |
107 | sed -i $(BUILD_DIR)/$(KERNEL_SRC)/Makefile -e 's/^EXTRAVERSION.*$$/EXTRAVERSION=$(EXTRAVERSION)/' | |
108 | rm -rf $(BUILD_DIR)/$(KERNEL_SRC)/debian $(BUILD_DIR)/$(KERNEL_SRC)/debian.master | |
8349ace6 TL |
109 | set -e; cd $(BUILD_DIR)/$(KERNEL_SRC); \ |
110 | for patch in ../../patches/kernel/*.patch; do \ | |
111 | echo "applying patch '$$patch'"; \ | |
112 | patch --batch -p1 < "$${patch}"; \ | |
113 | done | |
ba2f1a67 FG |
114 | touch $@ |
115 | ||
8fbdb63a | 116 | $(MODULES).prepared: $(addsuffix .prepared,$(MODULE_DIRS)) |
e96d2ab3 FG |
117 | touch $@ |
118 | ||
8fbdb63a TL |
119 | $(ZFSDIR).prepared: $(ZFSONLINUX_SUBMODULE) |
120 | rm -rf $(BUILD_DIR)/$(MODULES)/$(ZFSDIR) $(BUILD_DIR)/$(MODULES)/tmp $@ | |
121 | mkdir -p $(BUILD_DIR)/$(MODULES)/tmp | |
122 | cp -a $(ZFSONLINUX_SUBMODULE)/* $(BUILD_DIR)/$(MODULES)/tmp | |
123 | cd $(BUILD_DIR)/$(MODULES)/tmp; make kernel | |
124 | rm -rf $(BUILD_DIR)/$(MODULES)/tmp | |
125 | touch $(ZFSDIR).prepared | |
ba2f1a67 | 126 | |
ba2f1a67 | 127 | .PHONY: upload |
6d345395 | 128 | upload: UPLOAD_DIST ?= $(DEB_DISTRIBUTION) |
8fbdb63a | 129 | upload: $(DEBS) |
6d345395 | 130 | tar cf - $(DEBS)|ssh -X repoman@repo.proxmox.com -- upload --product pve,pmg,pbs --dist $(UPLOAD_DIST) --arch $(ARCH) |
ba2f1a67 FG |
131 | |
132 | .PHONY: distclean | |
133 | distclean: clean | |
e96d2ab3 | 134 | git submodule deinit --all |
ba2f1a67 | 135 | |
32054ef4 FG |
136 | # upgrade to current master |
137 | .PHONY: update_modules | |
a6dd515e | 138 | update_modules: submodule |
32054ef4 | 139 | git submodule foreach 'git pull --ff-only origin master' |
8fbdb63a | 140 | cd $(ZFSONLINUX_SUBMODULE); git pull --ff-only origin master |
32054ef4 FG |
141 | |
142 | # make sure submodules were initialized | |
a6dd515e FG |
143 | .PHONY: submodule |
144 | submodule: | |
8fbdb63a TL |
145 | test -f "$(KERNEL_SRC_SUBMODULE)/README" || git submodule update --init $(KERNEL_SRC_SUBMODULE) |
146 | test -f "$(ZFSONLINUX_SUBMODULE)/Makefile" || git submodule update --init --recursive $(ZFSONLINUX_SUBMODULE) | |
32054ef4 | 147 | |
b4ecde23 FG |
148 | # call after ABI bump with header deb in working directory |
149 | .PHONY: abiupdate | |
8fbdb63a TL |
150 | abiupdate: abi-prev-$(KVNAME) |
151 | abi-prev-$(KVNAME): abi-tmp-$(KVNAME) | |
b4ecde23 FG |
152 | ifneq ($(strip $(shell git status --untracked-files=no --porcelain -z)),) |
153 | @echo "working directory unclean, aborting!" | |
154 | @false | |
155 | else | |
156 | git rm "abi-prev-*" | |
157 | mv $< $@ | |
158 | git add $@ | |
8fbdb63a TL |
159 | git commit -s -m "update ABI file for $(KVNAME)" -m "(generated with debian/scripts/abi-generate)" |
160 | @echo "update abi-prev-$(KVNAME) committed!" | |
b4ecde23 FG |
161 | endif |
162 | ||
8fbdb63a TL |
163 | abi-tmp-$(KVNAME): |
164 | @ test -e $(HDR_DEB) || (echo "need $(HDR_DEB) to extract ABI data!" && false) | |
165 | debian/scripts/abi-generate $(HDR_DEB) $@ $(KVNAME) 1 | |
32054ef4 | 166 | |
ba2f1a67 FG |
167 | .PHONY: clean |
168 | clean: | |
6e72c5b2 FG |
169 | rm -rf *~ proxmox-kernel-[0-9]*/ *.prepared $(KERNEL_CFG_ORG) |
170 | rm -f *.deb *.dsc *.changes *.buildinfo *.build proxmox-kernel*.tar.* |