Christoph Hellwig wrote: > On Wed, Oct 29, 2008 at 12:18:47PM -0700, David Daney wrote: >> Christoph Hellwig wrote: >>> On Mon, Oct 27, 2008 at 05:02:38PM -0700, David Daney wrote: >>>> Signed-off-by: Tomaso Paoletti <tpaoletti@xxxxxxxxxxxxxxxxxx> >>>> Signed-off-by: David Daney <ddaney@xxxxxxxxxxxxxxxxxx> >>>> --- >>>> .../cavium-octeon/executive/cvmx-csr-addresses.h | 8391 ++++++ >>>> arch/mips/cavium-octeon/executive/cvmx-csr-enums.h | 86 + >>>> .../cavium-octeon/executive/cvmx-csr-typedefs.h |27517 >>>> ++++++++++++++++++++ >>> 27517 lines in a header and it's all junk? >>> >> I'm glad you asked. No it is not all junk. >> >> That file contains the bit definitions for all on-chip registers. >> >> We are interested in transforming this information into a form suitable >> for inclusion in the kernel. Any specific suggestions as to improve the >> patch will be considered. >> >> Several possibilities are: >> >> 1) Don't typedef all the unions in cvmx-csr-typedefs.h. An rename the >> file so it doesn't contain the reprehensible word 'typedef' >> >> 2) Break cvmx-csr-addresses.h and cvmx-csr-typedefs.h into several >> parts, one for each functional block in the processor. > > The two are very good ideas, but not really the important part. > > Adding a massive inline for every single bit somewhere in a register > just doesn't make sense. Take a look at normal hardware defintion > headers in the tree. > > Have a simple define for each _register_ (applied relative to a bank/chip > or whatever is appropriate) and if the individual bits in it are > important add bit defintions, too - leaving the arithmetics for it to > the caller. > > Also please don't add defintions for those blocks of the chip that > aren't actually used in your submission. That's best done with one > header per block that can be added with the driver supporting that > block. > > And yes, we had this a few times. Eventually I'll make a fortune > by selling a perl script generating proper headers out of common HDLs.. > The kernel's normal method of defining a whole bunch of #defines for every bit doesn't really work well for maintainability. Many times it isn't obvious which define goes with which register. It also doesn't cover changes in hardware over time. Our CSR definitions are generated from the RTL and designed to catch incompatibilities that might show up in the future. The "s" member of the union contains all of the bits that don't conflict for the known Octeon chips. If a bit changes meaning in a future Octeon, then the bit will disappear out of the "s" member and only be available through the chip specific unions. This makes the compiler find all usages of the change bit and forces you to fix them. It also doesn't make sense to leave out registers that aren't currently used. How does anyone write a new driver if the register definitions aren't there? Typing these in after the fact is a waste of time. Chad