On 08-10-15 03:46, Khem Raj wrote:

On Oct 7, 2015, at 6:05 AM, Mike Looijmans <[email protected]> wrote:

Since our boards needs 'some' bitstream in the FPGA to become somewhat useful, 
in the machine.conf I say:

MACHINE_FPGA_BITSTREAM ?= "fpga-image-miami-florida-gen-reference"
MACHINE_EXTRA_RRECOMMENDS = "${MACHINE_FPGA_BITSTREAM} ..."

This puts that into the packagegroup-base-machine RDEPENDS and hence it gets 
installed on the board if you don't specify anything else.

However, I want to be able to pick alternative FPGA bitstream providers in the 
image recipe. Without having to define a new machine for each and every project…

would IMAGE_FEATURES help ? IMAGE_FEATURE = blue and blue may be car for one 
machine and truck for another.

There are virtually unlimited sets of bitstreams. In general, each project will define its own if it has special tasks for the FPGA, or it'll just just the default. They are not directly related to the machine - the FPGA is only a part of it and doesn't run Linux or so.

I did look into that before posting this, but IMAGE_FEATURES must be set from a fixed list. There is no such list, each layer could add extra FPGA bitstream recipes.

The trouble here is that the "image" decides which it is going to be. And that "image" is often not mine to write, so I can't get away with writing my own image class or recipe.


Currently, I do this by forcing packagegroup-base-machine and 
packagegroup-base-distro out of the IMAGE_INSTALL list (for some obscure 
reason, building packagegroup-base-distro also results in building the 
reference bitstream) and then add MACHINE_EXTRA_RRECOMMENDS directly to the 
IMAGE_INSTALL list, so I can set MACHINE_FPGA_BITSTREAM to whichever I'd like 
to have in this image.

I was lookign for a way to have the machine configuration inject its packages 
into the IMAGE_INSTALL (or similar) list, so it can easily be overridden in an 
image recipe.

Bluntly putting IMAGE_INSTALL+="${MACHINE_FPGA_BITSTREAM}" into the machine.conf might 
work, but doesn't "feel" quite right. But there's apparently no other way to do this.

An alternative would be to introduce an IMAGE_INSTALL_MACHINE variable that 
gets added to the PACKAGE_INSTALL variable in image.bbclass. That would allow 
machines to inject their desirables into the image instead. It's a simple 
patch, I've pasted it below:

diff --git a/meta/classes/image.bbclass b/meta/classes/image.bbclass
index 86a98bb..90c1c05 100644
--- a/meta/classes/image.bbclass
+++ b/meta/classes/image.bbclass
@@ -64,7 +64,8 @@ def check_image_features(d):

IMAGE_INSTALL ?= ""
IMAGE_INSTALL[type] = "list"
-export PACKAGE_INSTALL ?= "${IMAGE_INSTALL} ${ROOTFS_BOOTSTRAP_INSTALL} 
${FEATURE_INSTALL}"
+IMAGE_INSTALL_MACHINE ?= ""
+export PACKAGE_INSTALL ?= "${IMAGE_INSTALL} ${ROOTFS_BOOTSTRAP_INSTALL} 
${FEATURE_INSTALL} ${IMAGE_IN
PACKAGE_INSTALL_ATTEMPTONLY ?= "${FEATURE_INSTALL_OPTIONAL}"

# Images are generally built explicitly, do not need to be part of world.


Kind regards,

Mike Looijmans
System Expert

TOPIC Embedded Products
Eindhovenseweg 32-C, NL-5683 KH Best
Postbus 440, NL-5680 AK Best
Telefoon: +31 (0) 499 33 69 79
Telefax: +31 (0) 499 33 69 70
E-mail: [email protected]
Website: www.topicproducts.com

Please consider the environment before printing this e-mail





--


Kind regards,

Mike Looijmans
System Expert

TOPIC Embedded Products
Eindhovenseweg 32-C, NL-5683 KH Best
Postbus 440, NL-5680 AK Best
Telefoon: +31 (0) 499 33 69 79
Telefax: +31 (0) 499 33 69 70
E-mail: [email protected]
Website: www.topicproducts.com

Please consider the environment before printing this e-mail





_______________________________________________
Openembedded-core mailing list
[email protected]
http://lists.openembedded.org/mailman/listinfo/openembedded-core


--
_______________________________________________
Openembedded-core mailing list
[email protected]
http://lists.openembedded.org/mailman/listinfo/openembedded-core

Reply via email to