diff --git a/meta/classes-recipe/packagefeed.bbclass b/meta/classes-recipe/packagefeed.bbclass
new file mode 100644
index 0000000000..7dfccbb58b
--- /dev/null
+++ b/meta/classes-recipe/packagefeed.bbclass
@@ -0,0 +1,16 @@
+
+FEED_CLASSES = "packagefeed_${IMAGE_PKGTYPE} packagegroup"
+inherit ${FEED_CLASSES}
+
+FEED_PATH = "${DEPLOY_DIR_FEED}/${PN}"
+FEED_DEPENDS ??= ""
+
+fakeroot python do_packagefeed() {
+    from oe.packagefeed import create_packagefeed
+
+    create_packagefeed(d)
+}
+addtask packagefeed before do_build
+do_packagefeed[nostamp] = "1"
+do_packagefeed[cleandirs] += "${FEED_PATH}"
+do_packagefeed[rdepends] += "${@' '.join([x + ':do_packagefeed' for x in d.getVar('FEED_DEPENDS').split()])}"
diff --git a/meta/classes-recipe/packagefeed_deb.bbclass b/meta/classes-recipe/packagefeed_deb.bbclass
new file mode 100644
index 0000000000..6ca5a33e93
--- /dev/null
+++ b/meta/classes-recipe/packagefeed_deb.bbclass
@@ -0,0 +1,2 @@
+do_packagefeed[depends] += "dpkg-native:do_populate_sysroot apt-native:do_populate_sysroot"
+do_packagefeed[recrdeptask] += "do_package_write_deb do_package_qa"
diff --git a/meta/classes-recipe/packagefeed_ipk.bbclass b/meta/classes-recipe/packagefeed_ipk.bbclass
new file mode 100644
index 0000000000..00ef8a30df
--- /dev/null
+++ b/meta/classes-recipe/packagefeed_ipk.bbclass
@@ -0,0 +1,2 @@
+do_packagefeed[depends] += "opkg-native:do_populate_sysroot"
+do_packagefeed[recrdeptask] += "do_package_write_ipk do_package_qa"
diff --git a/meta/classes-recipe/packagefeed_rpm.bbclass b/meta/classes-recipe/packagefeed_rpm.bbclass
new file mode 100644
index 0000000000..862ba99290
--- /dev/null
+++ b/meta/classes-recipe/packagefeed_rpm.bbclass
@@ -0,0 +1,2 @@
+do_packagefeed[depends] += "rpm-native:do_populate_sysroot dnf-native:do_populate_sysroot createrepo-c-native:do_populate_sysroot"
+do_packagefeed[recrdeptask] += "do_package_write_rpm do_package_qa"
