diff options
Diffstat (limited to 'documentation/bsp-guide')
-rw-r--r-- | documentation/bsp-guide/bsp.xml | 860 |
1 files changed, 429 insertions, 431 deletions
diff --git a/documentation/bsp-guide/bsp.xml b/documentation/bsp-guide/bsp.xml index e4a113a3f2..df1a557a5d 100644 --- a/documentation/bsp-guide/bsp.xml +++ b/documentation/bsp-guide/bsp.xml | |||
@@ -754,454 +754,452 @@ | |||
754 | You must eventually rebuild the image if you want to remove this restriction. | 754 | You must eventually rebuild the image if you want to remove this restriction. |
755 | </note> | 755 | </note> |
756 | </section> | 756 | </section> |
757 | <section id='yocto-bsp-tools'> | 757 | |
758 | <title>Using the Yocto BSP Tools</title> | 758 | <section id='using-the-yocto-projects-bsp-tools'> |
759 | <para> | 759 | <title>Using the Yocto Project's BSP Tools</title> |
760 | The Yocto Project includes a couple of tools that enable | 760 | |
761 | you to create a BSP from scratch | 761 | <para> |
762 | (<filename>yocto-bsp</filename>) and do basic | 762 | The Yocto Project includes a couple of tools that enable |
763 | configuration and maintenance of the kernel | 763 | you to create a <link linkend='bsp-layers'>BSP layer</link> |
764 | (<filename>yocto-kernel</filename>) without ever looking at | 764 | from scratch and do basic configuration and maintenance |
765 | a Yocto metadata file. | 765 | of the kernel without ever looking at a Yocto Project metadata file. |
766 | </para> | 766 | These tools are <filename>yocto-bsp</filename> and <filename>yocto-kernel</filename>, |
767 | <para> | 767 | respectively. |
768 | The following sections describe each of those tools in | ||
769 | detail, but there are some features common to both that | ||
770 | will be useful to describe before delving into the | ||
771 | details of either. | ||
772 | </para> | ||
773 | <para> | ||
774 | First, a word about how the tools are structured. | ||
775 | Designed to have a 'git-like' command interface, each | ||
776 | tool is structured as a set of sub-commands under a | ||
777 | 'top-level' command. The top-level command | ||
778 | (<filename>yocto-bsp</filename> | ||
779 | or <filename>yocto-kernel</filename>) itself does | ||
780 | nothing but invoke or provide help on the sub-commands | ||
781 | it supports. | ||
782 | </para> | ||
783 | <para> | ||
784 | Secondly, since the tools themselves live in | ||
785 | the <filename>scripts/</filename> subdirectory, in order | ||
786 | to use them, you need to 'source' the environment just | ||
787 | as you would when invoking a build: | ||
788 | <literallayout class='monospaced'> | ||
789 | $ source oe-init-build-env [build_dir] | ||
790 | </literallayout> | ||
791 | </para> | ||
792 | <para> | ||
793 | With that in mind, the most immediately useful function | ||
794 | to describe is the built-in help system common to both | ||
795 | tools. | ||
796 | </para> | ||
797 | <para> | ||
798 | The built-in help system makes it easy to drill down at | ||
799 | any time and remind oneself of the syntax required for | ||
800 | any specific command. | ||
801 | </para> | ||
802 | <para> | ||
803 | Simply entering the name of the command, or the command | ||
804 | along with 'help' will display a list of the available | ||
805 | sub-commands. For example: | ||
806 | </para> | ||
807 | <para> | ||
808 | <literallayout class='monospaced'> | ||
809 | $ yocto-bsp | ||
810 | $ yocto-bsp help | ||
811 | |||
812 | Usage: | ||
813 | |||
814 | Create a customized Yocto BSP layer. | ||
815 | |||
816 | usage: yocto-bsp [--version] [--help] COMMAND [ARGS] | ||
817 | |||
818 | The most commonly used 'yocto-bsp' commands are: | ||
819 | create Create a new Yocto BSP | ||
820 | list List available values for options and BSP properties | ||
821 | |||
822 | See 'yocto-bsp help COMMAND' for more information on a specific command. | ||
823 | |||
824 | |||
825 | Options: | ||
826 | --version show program's version number and exit | ||
827 | -h, --help show this help message and exit | ||
828 | -D, --debug output debug information | ||
829 | </literallayout> | ||
830 | </para> | ||
831 | <para> | ||
832 | Similarly, entering just the name of a sub-command will | ||
833 | show the detailed usage for that sub-command: | ||
834 | </para> | ||
835 | <para> | ||
836 | <literallayout class='monospaced'> | ||
837 | $ yocto-bsp create | ||
838 | |||
839 | Usage: | ||
840 | |||
841 | Create a new Yocto BSP | ||
842 | usage: yocto-bsp create <bsp-name> <karch> [-o <DIRNAME> | --outdir <DIRNAME>] | ||
843 | [-i <JSON PROPERTY FILE> | --infile <JSON PROPERTY_FILE>] | ||
844 | |||
845 | This command creates a Yocto BSP based on the specified parameters. | ||
846 | The new BSP will be a new Yocto BSP layer contained by default within | ||
847 | the top-level directory specified as 'meta-bsp-name'. The -o option | ||
848 | can be used to place the BSP layer in a directory with a different | ||
849 | name and location. | ||
850 | |||
851 | ... | ||
852 | </literallayout> | ||
853 | </para> | ||
854 | <para> | ||
855 | For any sub-command, you can also use the word 'help' | ||
856 | just before the sub-command to get more extensive | ||
857 | documentation on the sub-command: | ||
858 | </para> | 768 | </para> |
859 | <para> | 769 | |
860 | <literallayout class='monospaced'> | 770 | <para> |
861 | $ yocto-bsp help create | 771 | The following sections describe the common location and help features as well |
862 | 772 | as details for the <filename>yocto-bsp</filename> and <filename>yocto-kernel</filename> | |
863 | NAME | 773 | tools. |
864 | yocto-bsp create - Create a new Yocto BSP | 774 | </para> |
865 | 775 | ||
866 | SYNOPSIS | 776 | <section id='common-features'> |
867 | yocto-bsp create <bsp-name> <karch> [-o <DIRNAME> | --outdir <DIRNAME>] | 777 | <title>Common Features</title> |
868 | [-i <JSON PROPERTY FILE> | --infile <JSON PROPERTY_FILE>] | 778 | |
869 | 779 | <para> | |
870 | DESCRIPTION | 780 | Designed to have a command interface somewhat like |
871 | This command creates a Yocto BSP based on the specified | 781 | <ulink url='&YOCTO_DOCS_DEV_URL;#git'>Git</ulink>, each |
872 | parameters. The new BSP will be a new Yocto BSP layer contained | 782 | tool is structured as a set of sub-commands under a |
873 | by default within the top-level directory specified as | 783 | top-level command. |
874 | 'meta-bsp-name'. The -o option can be used to place the BSP layer | 784 | The top-level command (<filename>yocto-bsp</filename> |
875 | in a directory with a different name and location. | 785 | or <filename>yocto-kernel</filename>) itself does |
786 | nothing but invoke or provide help on the sub-commands | ||
787 | it supports. | ||
788 | </para> | ||
789 | |||
790 | <para> | ||
791 | Both tools reside in the <filename>scripts/</filename> subdirectory | ||
792 | of the <ulink url='&YOCTO_DOCS_DEV_URL;#yocto-project-files'>Yocto Project | ||
793 | Files</ulink>. | ||
794 | Consequently, to use the scripts, you must <filename>source</filename> the | ||
795 | environment just as you would when invoking a build: | ||
796 | <literallayout class='monospaced'> | ||
797 | $ source oe-init-build-env [build_dir] | ||
798 | </literallayout> | ||
799 | </para> | ||
800 | |||
801 | <para> | ||
802 | The most immediately useful function is to get help on both tools. | ||
803 | The built-in help system makes it easy to drill down at | ||
804 | any time and view the syntax required for any specific command. | ||
805 | Simply enter the name of the command, or the command along with | ||
806 | <filename>help</filename> to display a list of the available sub-commands. | ||
807 | Here is an example: | ||
808 | <literallayout class='monospaced'> | ||
809 | $ yocto-bsp | ||
810 | $ yocto-bsp help | ||
811 | |||
812 | Usage: | ||
813 | |||
814 | Create a customized Yocto BSP layer. | ||
815 | |||
816 | usage: yocto-bsp [--version] [--help] COMMAND [ARGS] | ||
817 | |||
818 | The most commonly used 'yocto-bsp' commands are: | ||
819 | create Create a new Yocto BSP | ||
820 | list List available values for options and BSP properties | ||
821 | |||
822 | See 'yocto-bsp help COMMAND' for more information on a specific command. | ||
823 | |||
824 | |||
825 | Options: | ||
826 | --version show program's version number and exit | ||
827 | -h, --help show this help message and exit | ||
828 | -D, --debug output debug information | ||
829 | </literallayout> | ||
830 | </para> | ||
831 | |||
832 | <para> | ||
833 | Similarly, entering just the name of a sub-command shows the detailed usage | ||
834 | for that sub-command: | ||
835 | <literallayout class='monospaced'> | ||
836 | $ yocto-bsp create | ||
837 | |||
838 | Usage: | ||
839 | |||
840 | Create a new Yocto BSP | ||
841 | usage: yocto-bsp create <bsp-name> <karch> [-o <DIRNAME> | --outdir <DIRNAME>] | ||
842 | [-i <JSON PROPERTY FILE> | --infile <JSON PROPERTY_FILE>] | ||
843 | |||
844 | This command creates a Yocto BSP based on the specified parameters. | ||
845 | The new BSP will be a new Yocto BSP layer contained by default within | ||
846 | the top-level directory specified as 'meta-bsp-name'. The -o option | ||
847 | can be used to place the BSP layer in a directory with a different | ||
848 | name and location. | ||
849 | |||
850 | ... | ||
851 | </literallayout> | ||
852 | </para> | ||
853 | |||
854 | <para> | ||
855 | For any sub-command, you can also use the word 'help' just before the | ||
856 | sub-command to get more extensive documentation: | ||
857 | <literallayout class='monospaced'> | ||
858 | $ yocto-bsp help create | ||
859 | |||
860 | NAME | ||
861 | yocto-bsp create - Create a new Yocto BSP | ||
862 | |||
863 | SYNOPSIS | ||
864 | yocto-bsp create <bsp-name> <karch> [-o <DIRNAME> | --outdir <DIRNAME>] | ||
865 | [-i <JSON PROPERTY FILE> | --infile <JSON PROPERTY_FILE>] | ||
866 | |||
867 | DESCRIPTION | ||
868 | This command creates a Yocto BSP based on the specified | ||
869 | parameters. The new BSP will be a new Yocto BSP layer contained | ||
870 | by default within the top-level directory specified as | ||
871 | 'meta-bsp-name'. The -o option can be used to place the BSP layer | ||
872 | in a directory with a different name and location. | ||
876 | 873 | ||
877 | The value of the 'karch' parameter determines the set of files | 874 | The value of the 'karch' parameter determines the set of files |
878 | that will be generated for the BSP, along with the specific set of | 875 | that will be generated for the BSP, along with the specific set of |
879 | 'properties' that will be used to fill out the BSP-specific | 876 | 'properties' that will be used to fill out the BSP-specific |
880 | portions of the BSP. | 877 | portions of the BSP. |
881 | 878 | ||
882 | ... | 879 | ... |
883 | 880 | ||
884 | NOTE: Once created, you should add your new layer to your | 881 | NOTE: Once created, you should add your new layer to your |
885 | bblayers.conf file in order for it to be subsquently seen and | 882 | bblayers.conf file in order for it to be subsquently seen and |
886 | modified by the yocto-kernel tool. | 883 | modified by the yocto-kernel tool. |
887 | 884 | ||
888 | NOTE for x86- and x86_64-based BSPs: The generated BSP assumes the | 885 | NOTE for x86- and x86_64-based BSPs: The generated BSP assumes the |
889 | presence of the of the meta-intel layer, so you should also have a | 886 | presence of the of the meta-intel layer, so you should also have a |
890 | meta-intel layer present and added to your bblayers.conf as well. | 887 | meta-intel layer present and added to your bblayers.conf as well. |
891 | </literallayout> | 888 | </literallayout> |
892 | </para> | 889 | </para> |
893 | <para> | 890 | |
894 | With the knowledge that there are two | 891 | <para> |
895 | commands, <filename>yocto-bsp</filename> | 892 | Now that you know where these two commands reside and how to access information |
896 | and <filename>yocto-kernel</filename> and a built-in | 893 | on them, you should find it relatively straightforward to discover the commands |
897 | help system available for each, it should be relatively | 894 | necessary to create a BSP and perform basic kernel maintainence on that BSP using |
898 | straightforward to discover the commands necessary to | 895 | the tools. |
899 | create a BSP and do basic kernel maintainence of that | 896 | The next sections provide a concrete starting point to expand on a few points that |
900 | BSP using the tools. The following sections are | 897 | might not be immediately obvious or that could use further explanation. |
901 | provided, however, in order to serve as a concrete | 898 | </para> |
902 | starting point and to expand on a few points that may | 899 | </section> |
903 | not be immediately obvious or that could use further | 900 | |
904 | explanation. | 901 | |
905 | </para> | 902 | <section id='creating-a-new-bsp-layer-using-the-yocto-bsp-script'> |
906 | <section id='using-yocto-bsp'> | 903 | <title>Creating a new BSP Layer Using the yocto-bsp Script</title> |
907 | <title>Creating a new BSP using <filename>yocto-bsp</filename></title> | 904 | |
908 | <para> | 905 | <para> |
909 | <filename>yocto-bsp</filename> is a Yocto script that | 906 | The <filename>yocto-bsp</filename> script creates a new |
910 | allows you to create a new Yocto BSP for any | 907 | <link linkend='bsp-layers'>BSP layer</link> for any architecture supported |
911 | architecture supported Yocto, as well as qemu versions | 908 | by the Yocto Project, as well as QEMU versions of the same. |
912 | of the same. The default mode of operation when invoked | 909 | The default mode of the script's operation is to prompt you for information needed |
913 | from the command-line is to prompt the user for | 910 | to generate the BSP layer. |
914 | information needed to generate the BSP. For the current | 911 | For the current set of BSPs, the script prompts you for various important |
915 | set of BSPs, the user is prompted for various important | 912 | parameters such as: |
916 | parameters such as which kernel to use, which branch of | 913 | <itemizedlist> |
917 | that kernel to use (or re-use), whether or not to use X, | 914 | <listitem><para>which kernel to use</para></listitem> |
918 | and if so, which drivers to use, whether to turn on SMP, | 915 | <listitem><para>which branch of that kernel to use (or re-use)</para></listitem> |
919 | whether the BSP has a keyboard, touchscreen, or anything | 916 | <listitem><para>whether or not to use X, and if so, which drivers to use</para></listitem> |
920 | that happens to be configurable and has an associated | 917 | <listitem><para>whether to turn on SMP</para></listitem> |
921 | input prompt. | 918 | <listitem><para>whether the BSP has a keyboard</para></listitem> |
922 | </para> | 919 | <listitem><para>whether the BSP has a touchscreen</para></listitem> |
923 | <para> | 920 | <listitem><para>any remaining configurable items associated with the BSP</para></listitem> |
924 | The <filename>yocto-bsp create</filename> sub-command is | 921 | </itemizedlist> |
925 | the sub-command you use to create a new BSP. It | 922 | </para> |
926 | requires you to specify a particular architecture to | 923 | |
927 | base the BSP on. You can use the <filename>yocto-bsp | 924 | <para> |
928 | list karch</filename> sub-command to list the | 925 | You use the <filename>yocto-bsp create</filename> sub-command to create |
929 | architectures available for BSP creation: | 926 | a new BSP layer. |
930 | </para> | 927 | This command requires you to specify a particular architecture on which to |
931 | <para> | 928 | base the BSP. |
932 | Assuming you've sourced the environment, you can invoke | 929 | Assuming you have sourced the environment, you can use the |
933 | the <filename>yocto-bsp create</filename> command to | 930 | <filename>yocto-bsp list karch</filename> sub-command to list the |
934 | create the BSP. The example below uses 'myarm' as the | 931 | architectures available for BSP creation as follows: |
935 | machine name, and tells it to use the 'qemu' | 932 | <literallayout class='monospaced'> |
936 | architecture (the specific qemu machine architecture to | 933 | $ yocto-bsp list karch |
937 | use will be prompted for). You can use the 'yocto-bsp | 934 | Architectures available: |
938 | list karch' command to list the aviailable architectures | 935 | arm |
939 | for BSP creation: | 936 | powerpc |
940 | </para> | 937 | i386 |
941 | <para> | 938 | mips |
942 | <literallayout class='monospaced'> | 939 | x86_64 |
943 | $ yocto-bsp list karch | 940 | qemu |
944 | Architectures available: | 941 | </literallayout> |
945 | arm | 942 | </para> |
946 | powerpc | 943 | |
947 | i386 | 944 | <para> |
948 | mips | 945 | The remainder of this section presents an example that uses |
949 | x86_64 | 946 | <filename>myarm</filename> as the machine name and <filename>qemu</filename> |
950 | qemu | 947 | as the machine architecture. |
951 | </literallayout> | 948 | Of the available architectures, <filename>qemu</filename> is the only architecture |
952 | </para> | 949 | that causes the script to prompt you further for an actual architecture. |
953 | <para> | 950 | In every other way, this architecture is representative of how creating a BSP for |
954 | For the example output below, we'll use the 'qemu' | 951 | a 'real' machine would work. |
955 | architecture, which is a special architecture that is | 952 | The reason the example uses this architecture is because it is an emulated architecture |
956 | the only one of the supported architectures that will | 953 | and can easily be followed without requireing actual hardware. |
957 | prompt you further for a 'real' architecture. In every | 954 | </para> |
958 | other way, it's representative of how creating a BSP for | 955 | |
959 | a 'real' machine would work; the reason we're using it | 956 | <para> |
960 | here as an example is that since it's an emulated | 957 | As the <filename>yocto-bsp create</filename> command runs, default values for |
961 | architecture, it's easy for readers to try out | 958 | the prompts appear in brackets. |
962 | themselves without having any special hardware | 959 | Pressing enter without supplying anything on the command line or pressing enter |
963 | requirements. | 960 | and providing an invalid response causes the script to accept the default value. |
964 | </para> | 961 | </para> |
965 | <para> | 962 | |
966 | The 'yocto-bsp create' command for the qemu architecture | 963 | <para> |
967 | will display the following prompts along the way to | 964 | Following is the complete example: |
968 | gather the input required for BSP generation. Each | 965 | <literallayout class='monospaced'> |
969 | prompt asks for input, but has a default value [in | 966 | $ yocto-bsp create myarm qemu |
970 | brackets]. If you press 'enter' (or any invalid value), | 967 | Which qemu architecture would you like to use? [default: x86] |
971 | the default value will automatically be used. | 968 | 1) common 32-bit x86 |
972 | </para> | 969 | 2) common 64-bit x86 |
973 | <para> | 970 | 3) common 32-bit ARM |
974 | In the case of the qemu architecture, the first prompt | 971 | 4) common 32-bit PowerPC |
975 | asks which emulated architecture to use. In this | 972 | 5) common 32-bit MIPS |
976 | example, we'll use the 'arm' qemu architecture. | 973 | 3 |
977 | </para> | 974 | Would you like to use the default (3.2) kernel? (Y/n) |
978 | <para> | 975 | Do you need a new machine branch for this BSP (the alternative is to re-use an existing branch)? [Y/n] |
979 | It then asks if the default kernel (3.2) is ok, and we | 976 | Getting branches from remote repo git://git.yoctoproject.org/linux-yocto-3.2... |
980 | press enter, essentially telling it 'yes'. If we had | 977 | Please choose a machine branch to base this BSP on => [default: standard/default/common-pc] |
981 | entered 'n', we would have been prompted to choose a | 978 | 1) base |
982 | different kernel from a list of available kernels (3.0, | 979 | 2) standard/base |
983 | 3.2_preempt-rt, etc). | 980 | 3) standard/default/arm-versatile-926ejs |
984 | </para> | 981 | 4) standard/default/base |
985 | <para> | 982 | 5) standard/default/beagleboard |
986 | Once we've selected the kernel, the next prompt asks | 983 | 6) standard/default/cedartrailbsp (copy).xml |
987 | whether we'd like to have a new branch in the Yocto | 984 | 7) standard/default/common-pc-64/base |
988 | kernel git repository created especially for this BSP, | 985 | 8) standard/default/common-pc-64/jasperforest |
989 | or whether we'll just re-use an existing branch. If we | 986 | 9) standard/default/common-pc-64/romley |
990 | say 'yes', which is the default, the BSP code generated | 987 | 10) standard/default/common-pc-64/sugarbay |
991 | will create a new branch specifically for the BSP rather | 988 | 11) standard/default/common-pc/atom-pc |
992 | than a common shared branch; this is the branch that any | 989 | 12) standard/default/common-pc/base |
993 | patches we add later would be committed. The reason | 990 | 13) standard/default/crownbay |
994 | creating a new branch is the default is that typically | 991 | 14) standard/default/emenlow |
995 | new BSPs do require BSP-specific patches and so the BSP | 992 | 15) standard/default/fishriver |
996 | tool assumes that most of time a new branch will be | 993 | 16) standard/default/fri2 |
997 | required. Note that in the current implementation it | 994 | 17) standard/default/fsl-mpc8315e-rdb |
998 | doesn't actually matter, since the generated BSPs assume | 995 | 18) standard/default/mti-malta32-be |
999 | that patches and configuration live in recipe-space, | 996 | 19) standard/default/mti-malta32-le |
1000 | which is something that can be done with or without a | 997 | 20) standard/default/preempt-rt |
1001 | dedicated branch. The BSP that's generated, however, | 998 | 21) standard/default/qemu-ppc32 |
1002 | will be different, and this difference will become | 999 | 22) standard/default/routerstationpro |
1003 | significant once 'publish' functionality is implemented. | 1000 | 23) standard/preempt-rt/base |
1004 | </para> | 1001 | 24) standard/preempt-rt/qemu-ppc32 |
1005 | <para> | 1002 | 25) standard/preempt-rt/routerstationpro |
1006 | Regardless of which choice we made in the previous step, | 1003 | 26) standard/tiny |
1007 | we're then given the opportunity to select a particular | 1004 | 3 |
1008 | machine branch to base our new BSP-specific machine | 1005 | Do you need SMP support? (Y/n) |
1009 | branch on (or re-use if we elected not to create a new | 1006 | Does your BSP have a touchscreen? (y/N) |
1010 | branch). Because we're generating an arm BSP, we choose | 1007 | Does your BSP have a keyboard? (Y/n) |
1011 | #3 at that prompt to select the arm-versatile branch. | 1008 | New qemu BSP created in meta-myarm |
1012 | The rest of the prompts are routine, and once all the | 1009 | </literallayout> |
1013 | questions have been completed, the BSP is generated | 1010 | Let's take a closer look at the example now: |
1014 | along with a message telling you so. The output of the | 1011 | <orderedlist> |
1015 | complete session is shown below: | 1012 | <listitem><para>For the <filename>qemu</filename> architecture, |
1016 | </para> | 1013 | the script first prompts you for which emulated architecture to use. |
1017 | <para> | 1014 | In the example, we use the <filename>arm</filename> architecture. |
1018 | <literallayout class='monospaced'> | 1015 | </para></listitem> |
1019 | $ yocto-bsp create myarm qemu | 1016 | <listitem><para>The script then prompts you for the kernel. |
1020 | Which qemu architecture would you like to use? [default: x86] | 1017 | The default kernel is 3.2 and is acceptable. |
1021 | 1) common 32-bit x86 | 1018 | So, the example accepts the default. |
1022 | 2) common 64-bit x86 | 1019 | If you enter 'n', the script prompts you to further enter the kernel |
1023 | 3) common 32-bit ARM | 1020 | you do want to use (e.g. 3.0, 3.2_preempt-rt, etc.).</para></listitem> |
1024 | 4) common 32-bit PowerPC | 1021 | <listitem><para>Next, the script asks whether you would like to have a new |
1025 | 5) common 32-bit MIPS | 1022 | branch created especially for your BSPin the local |
1026 | 3 | 1023 | <ulink url='&YOCTO_DOCS_DEV_URL;#local-kernel-files'>Linux Yocto Kernel</ulink> |
1027 | Would you like to use the default (3.2) kernel? (Y/n) | 1024 | Git repository . |
1028 | Do you need a new machine branch for this BSP (the alternative is to re-use an existing branch)? [Y/n] | 1025 | If not, then the script re-uses an existing branch.</para> |
1029 | Getting branches from remote repo git://git.yoctoproject.org/linux-yocto-3.2... | 1026 | <para>In this example, the default (or 'yes') is accepted. |
1030 | Please choose a machine branch to base this BSP on => [default: standard/default/common-pc] | 1027 | Thus, a new branch is created for the BSP rather than using a common, shared |
1031 | 1) base | 1028 | branch. |
1032 | 2) standard/base | 1029 | The new branch is the branch committed to for any patches you might later add. |
1033 | 3) standard/default/arm-versatile-926ejs | 1030 | The reason a new branch is the default is that typically |
1034 | 4) standard/default/base | 1031 | new BSPs do require BSP-specific patches. |
1035 | 5) standard/default/beagleboard | 1032 | The tool thus assumes that most of time a new branch is required. |
1036 | 6) standard/default/cedartrail | 1033 | <note>In the current implementation, creation or re-use of a branch does |
1037 | 7) standard/default/common-pc-64/base | 1034 | not actually matter. |
1038 | 8) standard/default/common-pc-64/jasperforest | 1035 | The reason is because the generated BSPs assume that patches and |
1039 | 9) standard/default/common-pc-64/romley | 1036 | configurations live in recipe-space, which is something that can be done |
1040 | 10) standard/default/common-pc-64/sugarbay | 1037 | with or without a dedicated branch. |
1041 | 11) standard/default/common-pc/atom-pc | 1038 | Generated BSPs, however, are different. |
1042 | 12) standard/default/common-pc/base | 1039 | This difference becomes significant once the tool's 'publish' functionality |
1043 | 13) standard/default/crownbay | 1040 | is implemented.</note></para></listitem> |
1044 | 14) standard/default/emenlow | 1041 | <listitem><para>Regardless of which choice is made in the previous step, |
1045 | 15) standard/default/fishriver | 1042 | you are now given the opportunity to select a particular machine branch on |
1046 | 16) standard/default/fri2 | 1043 | which to base your new BSP-specific machine branch on |
1047 | 17) standard/default/fsl-mpc8315e-rdb | 1044 | (or to re-use if you had elected to not create a new branch). |
1048 | 18) standard/default/mti-malta32-be | 1045 | Because this example is generating an <filename>arm</filename> BSP, the example |
1049 | 19) standard/default/mti-malta32-le | 1046 | uses <filename>#3</filename> at the prompt, which selects the arm-versatile branch. |
1050 | 20) standard/default/preempt-rt | 1047 | </para></listitem> |
1051 | 21) standard/default/qemu-ppc32 | 1048 | <listitem><para>The remainder of the prompts are routine. |
1052 | 22) standard/default/routerstationpro | 1049 | Defaults are accepted for each.</para></listitem> |
1053 | 23) standard/preempt-rt/base | 1050 | <listitem><para>By default, the script creates the new BSP Layer in the |
1054 | 24) standard/preempt-rt/qemu-ppc32 | 1051 | <ulink url='&YOCTO_DOCS_DEV_URL;#yocto-project-build-directory'>Yocto Project |
1055 | 25) standard/preempt-rt/routerstationpro | 1052 | Build Directory</ulink>.</para></listitem> |
1056 | 26) standard/tiny | 1053 | </orderedlist> |
1057 | 3 | 1054 | </para> |
1058 | Do you need SMP support? (Y/n) | 1055 | |
1059 | Does your BSP have a touchscreen? (y/N) | 1056 | <para> |
1060 | Does your BSP have a keyboard? (Y/n) | 1057 | Once the BSP Layer is created, you must add it to your |
1061 | New qemu BSP created in meta-myarm | 1058 | <filename>bblayers.conf</filename> file. |
1062 | </literallayout> | 1059 | Here is an example: |
1063 | </para> | 1060 | <literallayout class='monospaced'> |
1064 | <para> | ||
1065 | Now that we have our BSP created, we need to add it to | ||
1066 | our bblayers.conf. This of course is required in order | ||
1067 | to build the BSP, but it's also required in order for | ||
1068 | the <filename>yocto-kernel</filename> tool to be able to | ||
1069 | find the layer and other metadata it needs to operate | ||
1070 | on. | ||
1071 | <literallayout class='monospaced'> | ||
1072 | BBLAYERS = " \ | 1061 | BBLAYERS = " \ |
1073 | /usr/local/src/yocto/meta \ | 1062 | /usr/local/src/yocto/meta \ |
1074 | /usr/local/src/yocto/meta-yocto \ | 1063 | /usr/local/src/yocto/meta-yocto \ |
1075 | /usr/local/src/yocto/meta-myarm \ | 1064 | /usr/local/src/yocto/meta-myarm \ |
1076 | " | 1065 | " |
1077 | </literallayout> | 1066 | </literallayout> |
1078 | </para> | 1067 | Adding the layer to this file allows the build system to build the BSP and |
1068 | the <filename>yocto-kernel</filename> tool to be able to find the layer and | ||
1069 | other metadata it needs on which to operate. | ||
1070 | </para> | ||
1079 | </section> | 1071 | </section> |
1080 | <section id='using-yocto-kernel'> | ||
1081 | <title>Managing Kernel Patches and Config Items | ||
1082 | with <filename>yocto-kernel</filename></title> | ||
1083 | <para> | ||
1084 | Assuming we've created a Yocto BSP layer | ||
1085 | using <filename>yocto-bsp</filename> and added it to our | ||
1086 | BBLAYERS, we can now use | ||
1087 | the <filename>yocto-kernel</filename> command to add | ||
1088 | patches and config items to the BSP's | ||
1089 | kernel. <filename>yocto-kernel</filename> is a Yocto | ||
1090 | script that allows you to add, remove, and list patches | ||
1091 | and kernel config settings to a Yocto BSP's kernel | ||
1092 | .bbappend file. The easiest way to see exactly what | ||
1093 | sub-commands are available | ||
1094 | using <filename>yocto-kernel</filename> is again to make | ||
1095 | use of the built-in help: | ||
1096 | </para> | ||
1097 | <para> | ||
1098 | <literallayout class='monospaced'> | ||
1099 | $ yocto-kernel | ||
1100 | Usage: | ||
1101 | 1072 | ||
1102 | Modify and list Yocto BSP kernel config items and patches. | 1073 | <section id='managing-kernel-patches-and-config-items-with-yocto-kernel'> |
1074 | <title>Managing Kernel Patches and Config Items with yocto-kernel</title> | ||
1103 | 1075 | ||
1104 | usage: yocto-kernel [--version] [--help] COMMAND [ARGS] | 1076 | <para> |
1077 | Assuming you have created a Yocto Project | ||
1078 | <link linkend='bsp-layers'>BSP Layer</link> using | ||
1079 | <link linkend='creating-a-new-bsp-layer-using-the-yocto-bsp-script'> | ||
1080 | <filename>yocto-bsp</filename></link> and you added it to your | ||
1081 | <ulink url='&YOCTO_DOCS_REF_URL;#var-BBLAYERS'><filename>BBLAYERS</filename></ulink> | ||
1082 | variable in the <filename>bblayers.conf</filename> file, you can now use | ||
1083 | the <filename>yocto-kernel</filename> script to add patches and configuration | ||
1084 | items to the BSP's kernel. | ||
1085 | </para> | ||
1105 | 1086 | ||
1106 | The most commonly used 'yocto-kernel' commands are: | 1087 | <para> |
1107 | config list List the modifiable set of bare kernel config options for a BSP | 1088 | The <filename>yocto-kernel</filename> script allows you to add, remove, and list patches |
1108 | config add Add or modify bare kernel config options for a BSP | 1089 | and kernel config settings to a Yocto Project BSP's kernel |
1109 | config rm Remove bare kernel config options from a BSP | 1090 | <filename>.bbappend</filename> file. |
1110 | patch list List the patches associated with a BSP | 1091 | All you need to do is use the appropriate sub-command. |
1111 | patch add Patch the Yocto kernel for a BSP | 1092 | Recall that the easiest way to see exactly what sub-commands are available |
1112 | patch rm Remove patches from a BSP | 1093 | is to use the <filename>yocto-kernel</filename> built-in help as follows: |
1094 | <literallayout class='monospaced'> | ||
1095 | $ yocto-kernel | ||
1096 | Usage: | ||
1097 | |||
1098 | Modify and list Yocto BSP kernel config items and patches. | ||
1099 | |||
1100 | usage: yocto-kernel [--version] [--help] COMMAND [ARGS] | ||
1101 | |||
1102 | The most commonly used 'yocto-kernel' commands are: | ||
1103 | config list List the modifiable set of bare kernel config options for a BSP | ||
1104 | config add Add or modify bare kernel config options for a BSP | ||
1105 | config rm Remove bare kernel config options from a BSP | ||
1106 | patch list List the patches associated with a BSP | ||
1107 | patch add Patch the Yocto kernel for a BSP | ||
1108 | patch rm Remove patches from a BSP | ||
1109 | |||
1110 | See 'yocto-kernel help COMMAND' for more information on a specific command. | ||
1111 | </literallayout> | ||
1112 | </para> | ||
1113 | 1113 | ||
1114 | See 'yocto-kernel help COMMAND' for more information on a specific command. | 1114 | <para> |
1115 | </literallayout> | 1115 | The <filename>yocto-kernel patch add</filename> sub-command allows you to add a |
1116 | </para> | 1116 | patch to a BSP. |
1117 | <para> | 1117 | The following example adds two patches to the <filename>myarm</filename> BSP: |
1118 | The <filename>yocto-kernel patch add</filename> | 1118 | <literallayout class='monospaced'> |
1119 | sub-command allows us to add a patch to a BSP. The | 1119 | $ yocto-kernel patch add myarm ~/test.patch |
1120 | following commands add a couple of patches to the | 1120 | Added patches: |
1121 | 'myarm' BSP: | 1121 | test.patch |
1122 | <literallayout class='monospaced'> | 1122 | |
1123 | $ yocto-kernel patch add myarm ~/test.patch | 1123 | $ yocto-kernel patch add myarm ~/yocto-testmod.patch |
1124 | Added patches: | 1124 | Added patches: |
1125 | test.patch | 1125 | yocto-testmod.patch |
1126 | </literallayout> | ||
1127 | <note>Although the previous example adds patches one at a time, it is possible | ||
1128 | to add multiple patches at the same time.</note> | ||
1129 | </para> | ||
1126 | 1130 | ||
1127 | $ yocto-kernel patch add myarm ~/yocto-testmod.patch | 1131 | <para> |
1128 | Added patches: | 1132 | You can verify patches have been added by using the |
1129 | yocto-testmod.patch | 1133 | <filename>yocto-kernel patch list</filename> sub-command. |
1130 | </literallayout> | 1134 | Here is an example: |
1131 | Note that though we added patches one by one above, we | 1135 | <literallayout class='monospaced'> |
1132 | could also add multiple patches at the same time if we | 1136 | $ yocto-kernel patch list myarm |
1133 | wanted to. | 1137 | The current set of machine-specific patches for myarm is: |
1134 | </para> | 1138 | 1) test.patch |
1135 | <para> | 1139 | 2) yocto-testmod.patch |
1136 | We can verify that the patches were added by using | 1140 | </literallayout> |
1137 | the <filename>yocto-kernel patch list</filename> | 1141 | </para> |
1138 | sub-command: | ||
1139 | <literallayout class='monospaced'> | ||
1140 | $ yocto-kernel patch list myarm | ||
1141 | The current set of machine-specific patches for myarm is: | ||
1142 | 1) test.patch | ||
1143 | 2) yocto-testmod.patch | ||
1144 | </literallayout> | ||
1145 | </para> | ||
1146 | <para> | ||
1147 | We can also use <filename>yocto-kernel</filename> to | ||
1148 | remove a patch using the <filename>yocto-kernel patch | ||
1149 | rm</filename> sub-command: | ||
1150 | <literallayout class='monospaced'> | ||
1151 | $ yocto-kernel patch rm myarm | ||
1152 | Specify the patches to remove: | ||
1153 | 1) test.patch | ||
1154 | 2) yocto-testmod.patch | ||
1155 | 1 | ||
1156 | Removed patches: | ||
1157 | test.patch | ||
1158 | </literallayout> | ||
1159 | </para> | ||
1160 | <para> | ||
1161 | Again using <filename>yocto-kernel patch list</filename> | ||
1162 | we can verify that it was in fact removed: | ||
1163 | <literallayout class='monospaced'> | ||
1164 | $ yocto-kernel patch list myarm | ||
1165 | The current set of machine-specific patches for myarm is: | ||
1166 | 1) yocto-testmod.patch | ||
1167 | </literallayout> | ||
1168 | </para> | ||
1169 | <para> | ||
1170 | In a completely similar way, we can use | ||
1171 | the <filename>yocto-kernel config add</filename> | ||
1172 | sub-command to add one or more kernel config item | ||
1173 | settings to a BSP. The following commands add a couple | ||
1174 | of config items to the 'myarm' BSP: | ||
1175 | <literallayout class='monospaced'> | ||
1176 | $ yocto-kernel config add myarm CONFIG_MISC_DEVICES=y | ||
1177 | Added items: | ||
1178 | CONFIG_MISC_DEVICES=y | ||
1179 | 1142 | ||
1180 | $ yocto-kernel config add myarm KCONFIG_YOCTO_TESTMOD=y | 1143 | <para> |
1181 | Added items: | 1144 | You can also use the <filename>yocto-kernel</filename> script to |
1182 | CONFIG_YOCTO_TESTMOD=y | 1145 | remove a patch using the <filename>yocto-kernel patch rm</filename> sub-command. |
1183 | </literallayout> | 1146 | Here is an example: |
1184 | Note that though we added config items one by one | 1147 | <literallayout class='monospaced'> |
1185 | above, we could also add multiple configuration | 1148 | $ yocto-kernel patch rm myarm |
1186 | settings at the same time if we wanted to. | 1149 | Specify the patches to remove: |
1187 | </para> | 1150 | 1) test.patch |
1188 | <para> | 1151 | 2) yocto-testmod.patch |
1189 | Finally, we can list the config items now associated | 1152 | 1 |
1190 | with the BSP and see the config items we added along | 1153 | Removed patches: |
1191 | with some others. | 1154 | test.patch |
1192 | <literallayout class='monospaced'> | 1155 | </literallayout> |
1193 | $ yocto-kernel config list myarm | 1156 | </para> |
1194 | The current set of machine-specific kernel config items for myarm is: | 1157 | |
1195 | 1) CONFIG_MISC_DEVICES=y | 1158 | <para> |
1196 | 2) CONFIG_YOCTO_TESTMOD=y | 1159 | Again, using the <filename>yocto-kernel patch list</filename> sub-command, |
1197 | </literallayout> | 1160 | you can verify that the patch was in fact removed: |
1198 | </para> | 1161 | <literallayout class='monospaced'> |
1199 | <para> | 1162 | $ yocto-kernel patch list myarm |
1200 | Similarly, we can remove one or more config items using | 1163 | The current set of machine-specific patches for myarm is: |
1201 | <filename>yocto-kernel config rm</filename> in a manner | 1164 | 1) yocto-testmod.patch |
1202 | completely analogous to <filename>yocto-kernel patch | 1165 | </literallayout> |
1203 | rm</filename>. | 1166 | </para> |
1204 | </para> | 1167 | |
1168 | <para> | ||
1169 | In a completely similar way, you can use the <filename>yocto-kernel config add</filename> | ||
1170 | sub-command to add one or more kernel config item settings to a BSP. | ||
1171 | The following commands add a couple of config items to the | ||
1172 | <filename>myarm</filename> BSP: | ||
1173 | <literallayout class='monospaced'> | ||
1174 | $ yocto-kernel config add myarm CONFIG_MISC_DEVICES=y | ||
1175 | Added items: | ||
1176 | CONFIG_MISC_DEVICES=y | ||
1177 | |||
1178 | $ yocto-kernel config add myarm KCONFIG_YOCTO_TESTMOD=y | ||
1179 | Added items: | ||
1180 | CONFIG_YOCTO_TESTMOD=y | ||
1181 | </literallayout> | ||
1182 | <note>Although the previous example adds config items one at a time, it is possible | ||
1183 | to add multiple config items at the same time.</note> | ||
1184 | </para> | ||
1185 | |||
1186 | <para> | ||
1187 | You can list the config items now associated with the BSP. | ||
1188 | Doing so shows you the config items you added as well as others associated | ||
1189 | with the BSP: | ||
1190 | <literallayout class='monospaced'> | ||
1191 | $ yocto-kernel config list myarm | ||
1192 | The current set of machine-specific kernel config items for myarm is: | ||
1193 | 1) CONFIG_MISC_DEVICES=y | ||
1194 | 2) CONFIG_YOCTO_TESTMOD=y | ||
1195 | </literallayout> | ||
1196 | </para> | ||
1197 | |||
1198 | <para> | ||
1199 | Finally, you can remove one or more config items using the | ||
1200 | <filename>yocto-kernel config rm</filename> sub-command in a manner | ||
1201 | completely analogous to <filename>yocto-kernel patch rm</filename>. | ||
1202 | </para> | ||
1205 | </section> | 1203 | </section> |
1206 | </section> | 1204 | </section> |
1207 | </chapter> | 1205 | </chapter> |