SEARCH  

NEWS

2010.10.06:11:36:28
Przez komiks i animację do wiedzy ekonomicznej
Komiksy, animacje i scenariusze lekcji, przygotowane przez metodyków z Ośrodka Rozwoju Edukacji we współpracy z ekonomistami Fundacji FOR, będą dystrybuowane bezpłatnie wśród nauczycieli szkół gimnazjalnych i ponadgimnazjalnych, prowadzących lekcje z podstaw przedsiębiorczości i wiedzy o społeczeństwie. Wspomniane materiały będą dostępne dla nauczycieli na stronie internetowej FOR.

 

messageID:579060007477
author:Robert Schwebel
title:Re RFC PATCH Device Tree on ARM platform
On Wed, May 27, 2009 at 9:05 AM, Robert Schwebel <r.schwebel@xxxxxxxxxxxxxx wrote: Seriously: oftree in general is a good idea. Just that it doesnt work in practise. The concept has some serious flaws: - The whole concept is based on the assumption that bindings are defined  *once*, then never to be changed again. As this is not true (check  MPC5200 to find out what I mean), oftree wreckage is *the* main cause  of new kernels not working on old bootloaders any more. Is there a  solution of this problem? I have not seen a good idea how to avoid the  constant change in definitions. This is a MPC5200 is the posterchild for device tree wreckage; mostly because of my own inexperience at the time. A lot of mistakes were made and I freely admit that. However, my counter example is Xilinx Virtex support. The Virtex is an FPGA with all the devices instantiated in the FPGA fabric. It would be a nightmare to try and describe each different FPGA bitstream using hand coded platform devices, and the xparameters.h file exported by the Xilinx toolchain wasnt much better. Encoding the machine layout in a data structure (the device tree) has decoupled FPGA changes from the kernel image. Now FPGA engineers can make major changes to FPGA layouts without having to lockstep with changes in the kernel. I regularly boot a single kernel image on multiple bitstream images. That being said, the problems we have had are the reason why it is *not* recommended to hard link the device tree image into firmware. We do commit to not breaking old trees, but the ability to update is important; particularly for enabling new features/drivers. - The oftree layering is fundamentally broken. We already have a sane  abstraction for arbitrary hardware in the kernel: platform devices.  Why not instanciate platform devices from a generic oftree core? No; the oftree is a data structure. That is it, nothing more. The device tree layout is well defined and independent of Linux kernel internal implementation details. In powerpc land weve chosen to use the of_platform bus to decode the data into Linux usable form, and I think it is the best approach. If a designer wanted to, then platform devices could be instantiated instead. In fact, that used to be done for most powerpc devices, but weve moved away from that model because the data still needs to be decoded somewhere, and that somewhere should be as close to the driver as possible. - Platform data makes it possible to store function pointers. There  is no equivalent to this concept in oftree-land. But there is concept of platform specific code. In the majority of cases platform specific function pointers arent needed at all. In the cases where they are; platform devices can still be used. oftree could be a great tool if these things would be resolved. Currently they are not, and in result, ARM just works and is easy, whereas on PowerPC systems people often spend more time working on binding stuff than on the actual functionality. Thats a rather polarizing statement and I dont think its fair. The FDT is not a magic bullet. It makes aspects of platform independence, code sharing, and board porting simpler, but it is also requires forethought and has overhead associated with it. I dont think anyone is proposing to require all ARM platforms to use the FDT approach. g. -- Grant Likely, B.Sc., P.Eng. Secret Lab Technologies Ltd. ------------------------------------------------------------------- List admin: rel="nofollow" lists.arm.linux.org.uk/mailman/listinfo/linux-arm-kernel lists.arm.linux.org.uk/mailman/listinfo/linux-arm-kernel FAQ: rel="nofollow" www.arm.linux.org.uk/mailinglists/faq.php www.arm.linux.org.uk/mailinglists/faq.php Etiquette: rel="nofollow" www.arm.linux.org.uk/mailinglists/etiquette.php www.arm.linux.org.uk/mailinglists/etiquette.php
Index