From: Tom Zanussi <tom.zanu...@intel.com> Since I've been doing kind of similar work lately for the 'custom kernel' support for yocto-bsp and have gotten several requests lately (mainly from Darren in support of the new kernel documentation) for something like this, I decided to just go ahead and try to quickly implement a general-purpose layer-generation tool based on the BSP-generation code used in the yocto-bsp tool.
There's actually an enhancement request bug for this already in the Yocto bugzilla, but it doesn't contain many details: Bug 3094 - Add a layer generation tool: https://bugzilla.yoctoproject.org/show_bug.cgi?id=3094 v1 changes (the previous version was an RFC): - if layer_priority is specified on the command line, the user is not queried and the layer is generated immediately - explicitly return 0 in the hello.c example code Below are a couple examples of how it's used - you really have to try it yourself to see what's generated - I don't want to post tarballs or such on the list and it's simple to generate and look at the layers. The first case is just a very simple layer with a layer.conf and README - basically the simplest layer you can create, and which exists mainly because even that is easy to get wrong. As with the yocto-bsp tool, the script queries the user for a couple items, here we just take the defaults, which are a priority of 6 for the layer and no other components such as example recipes: [trz@empanada build]$ yocto-layer create simplestlayer Please enter the layer priority you'd like to use for the layer: [default: 6] Would you like to have an example recipe created? (y/n) [default: n] Would you like to have an example bbappend file created? (y/n) [default: n] New layer created in meta-simplestlayer. Don't forget to add it to your BBLAYERS (for details see meta-simplestlayer\README). [trz@empanada build]$ find . . ./meta-simplestlayer ./meta-simplestlayer/conf ./meta-simplestlayer/conf/layer.conf ./meta-simplestlayer/README ./meta-simplestlayer/COPYING.MIT If you specify a layer_priority directly on the command line, yocto-layer will not query the user at all but instead will generate the layer (without example recipes etc) immediately: [trz@empanada build]$ yocto-layer create simplestlayer 7 New layer created in meta-simplestlayer. Don't forget to add it to your BBLAYERS (for details see meta-simplestlayer\README). In the second case, we tell the tool that we do want an example .bb and and an example .bbappend. We're queried for the recipe name that we want our recipe to have, and for the .bbappend, the name of the base recipe and its version. Below you can see the files it generates - please look at the files themselves to see the contents. For the recipe example, it generates a recipe based on the example in the Yocto manual, and my own helloworld.c code (untested so far which is also why this is an RFC). For the .bbappend example, it just creates an empty .patch file with some instructions on what to do to modify the parent recipe with a patch: [trz@empanada build]$ yocto-layer create mylayer Please enter the layer priority you'd like to use for the layer: [default: 6] Would you like to have an example recipe created? (y/n) [default: n] y Please enter the name you'd like to use for your example recipe: [default: example] flork Would you like to have an example bbappend file created? (y/n) [default: n] y Please enter the name you'd like to use for your bbappend file: [default: example] chork Please enter the version number you'd like to use for your bbappend file (this should match the recipe you're appending to): [default: 0.1] 0.22.3 New layer created in meta-mylayer. Don't forget to add it to your BBLAYERS (for details see meta-mylayer\README). [trz@empanada build]$ find . . ./meta-mylayer ./meta-mylayer/recipes-example ./meta-mylayer/recipes-example/example ./meta-mylayer/recipes-example/example/flork-0.1 ./meta-mylayer/recipes-example/example/flork-0.1/helloworld.c ./meta-mylayer/recipes-example/example/flork-0.1/example.patch ./meta-mylayer/recipes-example/example/flork_0.1.bb ./meta-mylayer/conf ./meta-mylayer/conf/layer.conf ./meta-mylayer/recipes-example-bbappend ./meta-mylayer/recipes-example-bbappend/example-bbappend ./meta-mylayer/recipes-example-bbappend/example-bbappend/chork-0.22.3 ./meta-mylayer/recipes-example-bbappend/example-bbappend/chork-0.22.3/example.patch ./meta-mylayer/recipes-example-bbappend/example-bbappend/chork_0.22.3.bbappend ./meta-mylayer/README ./meta-mylayer/COPYING.MIT Thanks, Tom The following changes since commit 53cc748b93e8af584557d6db5309c3e955182c5c: linux-libc-headers: fix headers install in long path name environments (2013-01-10 23:53:51 +0000) are available in the git repository at: git://git.yoctoproject.org/poky-contrib.git tzanussi/yocto-layer-v1 http://git.yoctoproject.org/cgit/cgit.cgi/poky-contrib/log/?h=tzanussi/yocto-layer-v1 Tom Zanussi (7): scripts/lib/bsp/engine.py: add yocto_layer_create() yocto-layer: new script yocto-layer: add help/usage yocto-layer: add 'layer' template data scripts/lib/bsp/engine.py: refactor bsp-creation code yocto-layer: add optional layer priority param scripts/lib/bsp/engine.py: add handling for JSON strings scripts/lib/bsp/engine.py | 114 ++++++++-- scripts/lib/bsp/help.py | 238 +++++++++++++++++++++ .../bsp/substrate/target/arch/layer/COPYING.MIT | 17 ++ scripts/lib/bsp/substrate/target/arch/layer/README | 64 ++++++ .../substrate/target/arch/layer/conf/layer.conf | 10 + .../target/arch/layer/layer-questions.noinstall | 14 ++ .../example.patch" | 12 ++ ..._name}}_{{=example_bbappend_version}}.bbappend" | 8 + .../{{=example_recipe_name}}-0.1/example.patch" | 12 ++ .../{{=example_recipe_name}}-0.1/helloworld.c" | 8 + .../example/{{=example_recipe_name}}_0.1.bb" | 23 ++ scripts/yocto-layer | 147 +++++++++++++ 12 files changed, 645 insertions(+), 22 deletions(-) create mode 100644 scripts/lib/bsp/substrate/target/arch/layer/COPYING.MIT create mode 100644 scripts/lib/bsp/substrate/target/arch/layer/README create mode 100644 scripts/lib/bsp/substrate/target/arch/layer/conf/layer.conf create mode 100644 scripts/lib/bsp/substrate/target/arch/layer/layer-questions.noinstall create mode 100644 "scripts/lib/bsp/substrate/target/arch/layer/{{ if create_example_bbappend == \"y\": }} recipes-example-bbappend/example-bbappend/{{=example_bbappend_name}}-{{=example_bbappend_version}}/example.patch" create mode 100644 "scripts/lib/bsp/substrate/target/arch/layer/{{ if create_example_bbappend == \"y\": }} recipes-example-bbappend/example-bbappend/{{=example_bbappend_name}}_{{=example_bbappend_version}}.bbappend" create mode 100644 "scripts/lib/bsp/substrate/target/arch/layer/{{ if create_example_recipe == \"y\": }} recipes-example/example/{{=example_recipe_name}}-0.1/example.patch" create mode 100644 "scripts/lib/bsp/substrate/target/arch/layer/{{ if create_example_recipe == \"y\": }} recipes-example/example/{{=example_recipe_name}}-0.1/helloworld.c" create mode 100644 "scripts/lib/bsp/substrate/target/arch/layer/{{ if create_example_recipe == \"y\": }} recipes-example/example/{{=example_recipe_name}}_0.1.bb" create mode 100755 scripts/yocto-layer -- 1.7.11.4 _______________________________________________ yocto mailing list yocto@yoctoproject.org https://lists.yoctoproject.org/listinfo/yocto