On 2/1/19 4:48 AM, Chee, Tien Fong wrote:
> On Thu, 2019-01-31 at 15:54 +0100, Marek Vasut wrote:
>> On 1/31/19 3:51 PM, tien.fong.c...@intel.com wrote:
>>>
>>> From: Tien Fong Chee <tien.fong.c...@intel.com>
>>>
>>> This patch adds description on properties about file name used for
>>> both
>>> peripheral bitstream and core bitstream.
>>>
>>> Signed-off-by: Tien Fong Chee <tien.fong.c...@intel.com>
>>>
>>> ---
>>>
>>> changes for v7
>>> - Provided example of setting FPGA FIT image for both early IO
>>> release
>>>   and full release FPGA configuration.
>>> ---
>>>  .../fpga/altera-socfpga-a10-fpga-mgr.txt           | 34
>>> +++++++++++++++++++++-
>>>  1 file changed, 33 insertions(+), 1 deletion(-)
>>>
>>> diff --git a/doc/device-tree-bindings/fpga/altera-socfpga-a10-fpga-
>>> mgr.txt b/doc/device-tree-bindings/fpga/altera-socfpga-a10-fpga-
>>> mgr.txt
>>> index 2fd8e7a..5f81a32 100644
>>> --- a/doc/device-tree-bindings/fpga/altera-socfpga-a10-fpga-mgr.txt
>>> +++ b/doc/device-tree-bindings/fpga/altera-socfpga-a10-fpga-mgr.txt
>>> @@ -7,8 +7,39 @@ Required properties:
>>>                 - The second index is for writing FPGA
>>> configuration data.
>>>  - resets     : Phandle and reset specifier for the device's reset.
>>>  - clocks     : Clocks used by the device.
>>> +- altr,bitstream : File name for FPGA peripheral bitstream which
>>> is used
>>> +              to initialize FPGA IOs, PLL, IO48 and DDR. This
>>> bitstream is
>>> +              required to get DDR up running.
>>> +              or
>>> +              File name for full bitstream, consist of
>>> peripheral bitstream
>>> +              and core bitstream.
>>> +- altr,bitstream-core(optional) : File name for core bitstream
>>> which contains
>> Is the name of the property 'altr,bitstream-core(optional)' ? I think
>> the "optional" part should be in the description.
> Yes, you are right.
>>
>>>
>>> +                             FPGA design which is used to
>>> program FPGA CRAM
>>> +                             and ERAM.
>>>  
>>> -Example:
>>> +Example: Bundles both peripheral bitstream and core bitstream into
>>> FIT image
>>> +    called fit_spl_fpga.itb. This FIT image can be created
>>> through running
>>> +    this command: tools/mkimage
>>> +                  -E -p 400
>>> +                  -f board/altera/arria10-
>>> socdk/fit_spl_fpga.its
>>> +                  fit_spl_fpga.itb
>>> +
>>> +    For details of describing structure and contents of the
>>> FIT image,
>>> +    please refer board/altera/arria10-socdk/fit_spl_fpga.its
>>> +
>>> +- Examples for booting with early IO release, and enter early user
>>> mode:
>>> +
>>> +   fpga_mgr: fpga-mgr@ffd03000 {
>>> +           compatible = "altr,socfpga-a10-fpga-mgr";
>>> +           reg = <0xffd03000 0x100
>>> +                  0xffcfe400 0x20>;
>>> +           clocks = <&l4_mp_clk>;
>>> +           resets = <&rst FPGAMGR_RESET>;
>>> +           altr,bitstream = "fit_spl_fpga.itb";
>>> +           altr,bitstream-core = "fit_spl_fpga.itb";
>> It's the same file, why does it use two properties ? 
> 1. Allows user to run optional for program core. When "" is set to 
> altr,bitstream-core, then SPL would skip programming FPGA with core, so
> user can program it later on U-Boot or Linux.

You can just pass in a fitImage with only the periph image in it in such
a case.

> 2. Allows core in different FIT file.

Is this really useful ?

>> And where is this
>> file loaded from ?
> You need to set the default source in DTS, for example "firmware-loader 
> = &fs_loader0", that's for power boot up purpose. After that, generic
> firmware loader would go to the dsignated storage as described below to
> find the FPGA FIT image according description from above.
> 
>       fs_loader0: fs-loader@0 {
>               u-boot,dm-pre-reloc;
>               compatible = "u-boot,fs-loader";
>               phandlepart = <&mmc 1>;
>       };

How does the driver bound to fpga-mgr know which firmware loader
instance to use ? There's no phandle.

>>> +   };
>>> +
>>> +- Examples for booting with full release, enter user mode with
>>> full bitstream:
>>>  
>>>     fpga_mgr: fpga-mgr@ffd03000 {
>>>             compatible = "altr,socfpga-a10-fpga-mgr";
>>> @@ -16,4 +47,5 @@ Example:
>>>                    0xffcfe400 0x20>;
>>>             clocks = <&l4_mp_clk>;
>>>             resets = <&rst FPGAMGR_RESET>;
>>> +           altr,bitstream = "fit_spl_fpga.itb";
>>>     };
>>>


-- 
Best regards,
Marek Vasut
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot

Reply via email to