Re: [PATCH] spi

From: Andrew Morton
Date: Mon Aug 08 2005 - 17:59:52 EST


dmitry pervushin <dpervushin@xxxxxxxxx> wrote:
>

A few coding style nits.

> +#include "spi_locals.h"
> +
> +static LIST_HEAD( spi_busses );

Please don't put spaces after '(' and before ')'.

> + if (0 == strncmp(*id, SPI_ID_ANY, strlen(SPI_ID_ANY))) {

And this trick isn't really needed. If you do

if (whatever = constant)

then the compiler will generate a warning. Please do these comparisons in
the conventional way, with the constant on the right hand side.

> + if( bus ) {
> + init_MUTEX( &bus->lock );
> +
> + bus->platform_device.name = NULL;
> + bus->the_bus.name = NULL;
> +
> + strncpy( busname, name ? name : "SPI", sizeof( busname ) );

Lots more extraneous spaces after '(' and before ')'.

> + if( bus->the_bus.name ) {
> + strcpy( bus->the_bus.name, fullname );
> + }

No braces here.

> + err = bus_register( &bus->the_bus );
> + if( err ) {
> + goto out;
> + }

And here.

> + list_add_tail( &bus->bus_list, &spi_busses );
> + bus->platform_device.name = kmalloc( strlen( busname )+1, GFP_KERNEL );
> + if( bus->platform_device.name ) {
> + strcpy( bus->platform_device.name, busname );
> + }

and here...

> +void spi_bus_unregister( struct spi_bus* bus )
> +{
> + if( bus ) {

We do put a space after `if', so this line should be

if (bus) {

> +struct spi_bus* spi_bus_find( char* id )

The asterisk goes with the variable, not with the type. So the above should be

struct spi_bus *spi_bus_find(char *id)

> +int spi_device_add( struct spi_bus* bus, struct spi_device *dev, char* name)

Here too.

> +int spi_do_probe( struct device* dev, void* device_driver )

You seem to have an awful lot of non-static functions. Please check
whether they all really need to have global scope.

> + if (NULL == dev) {

if (dev == NULL) {

> +static int spidev_do_open(struct device *the_dev, void *context)
> +{
> + struct spidev_openclose *o = (struct spidev_openclose *) context;

Don't typecast void* when assigning to and from pointers. It adds clutter
and defeats typechecking.

> + struct spi_device *dev = SPI_DEV(the_dev);
> + struct spidev_driver_data *drvdata;
> +
> + drvdata = (struct spidev_driver_data *) dev_get_drvdata(the_dev);

Ditto.

> +
> + out_unreg:

Labels go in column zero.

> + void *(*alloc) (size_t, int);
> + void (*free) (const void *);
> + unsigned long (*copy_from_user) (void *to, const void *from_user,
> + unsigned long len);
> + unsigned long (*copy_to_user) (void *to_user, const void *from,
> + unsigned long len);

The above names are risky. Some platform may implement copy_to_user() as a
macro.


-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/