2019-05-27 09:55:01 +03:00
// SPDX-License-Identifier: GPL-2.0-or-later
2005-04-17 02:20:36 +04:00
/*
* NET3 : Fibre Channel device handling subroutines
2007-02-09 17:24:24 +03:00
*
2005-04-17 02:20:36 +04:00
* Vineet Abraham < vma @ iol . unh . edu >
* v 1.0 03 / 22 / 99
*/
2016-12-24 22:46:01 +03:00
# include <linux/uaccess.h>
2005-04-17 02:20:36 +04:00
# include <linux/types.h>
# include <linux/kernel.h>
# include <linux/string.h>
# include <linux/mm.h>
# include <linux/socket.h>
# include <linux/in.h>
# include <linux/inet.h>
# include <linux/netdevice.h>
# include <linux/fcdevice.h>
# include <linux/skbuff.h>
# include <linux/errno.h>
# include <linux/timer.h>
# include <linux/net.h>
# include <linux/proc_fs.h>
# include <linux/init.h>
2011-07-15 19:47:34 +04:00
# include <linux/export.h>
2005-04-17 02:20:36 +04:00
# include <net/arp.h>
/*
2007-02-09 17:24:24 +03:00
* Put the headers on a Fibre Channel packet .
2005-04-17 02:20:36 +04:00
*/
2007-02-09 17:24:24 +03:00
2005-04-17 02:20:36 +04:00
static int fc_header ( struct sk_buff * skb , struct net_device * dev ,
unsigned short type ,
2012-04-15 09:58:06 +04:00
const void * daddr , const void * saddr , unsigned int len )
2005-04-17 02:20:36 +04:00
{
struct fch_hdr * fch ;
int hdr_len ;
2007-02-09 17:24:24 +03:00
/*
* Add the 802.2 SNAP header if IP as the IPv4 code calls
2005-04-17 02:20:36 +04:00
* dev - > hard_header directly .
*/
if ( type = = ETH_P_IP | | type = = ETH_P_ARP )
{
struct fcllc * fcllc ;
hdr_len = sizeof ( struct fch_hdr ) + sizeof ( struct fcllc ) ;
networking: make skb_push & __skb_push return void pointers
It seems like a historic accident that these return unsigned char *,
and in many places that means casts are required, more often than not.
Make these functions return void * and remove all the casts across
the tree, adding a (u8 *) cast only where the unsigned char pointer
was used directly, all done with the following spatch:
@@
expression SKB, LEN;
typedef u8;
identifier fn = { skb_push, __skb_push, skb_push_rcsum };
@@
- *(fn(SKB, LEN))
+ *(u8 *)fn(SKB, LEN)
@@
expression E, SKB, LEN;
identifier fn = { skb_push, __skb_push, skb_push_rcsum };
type T;
@@
- E = ((T *)(fn(SKB, LEN)))
+ E = fn(SKB, LEN)
@@
expression SKB, LEN;
identifier fn = { skb_push, __skb_push, skb_push_rcsum };
@@
- fn(SKB, LEN)[0]
+ *(u8 *)fn(SKB, LEN)
Note that the last part there converts from push(...)[0] to the
more idiomatic *(u8 *)push(...).
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-06-16 15:29:23 +03:00
fch = skb_push ( skb , hdr_len ) ;
2005-04-17 02:20:36 +04:00
fcllc = ( struct fcllc * ) ( fch + 1 ) ;
fcllc - > dsap = fcllc - > ssap = EXTENDED_SAP ;
fcllc - > llc = UI_CMD ;
fcllc - > protid [ 0 ] = fcllc - > protid [ 1 ] = fcllc - > protid [ 2 ] = 0x00 ;
fcllc - > ethertype = htons ( type ) ;
}
else
{
hdr_len = sizeof ( struct fch_hdr ) ;
networking: make skb_push & __skb_push return void pointers
It seems like a historic accident that these return unsigned char *,
and in many places that means casts are required, more often than not.
Make these functions return void * and remove all the casts across
the tree, adding a (u8 *) cast only where the unsigned char pointer
was used directly, all done with the following spatch:
@@
expression SKB, LEN;
typedef u8;
identifier fn = { skb_push, __skb_push, skb_push_rcsum };
@@
- *(fn(SKB, LEN))
+ *(u8 *)fn(SKB, LEN)
@@
expression E, SKB, LEN;
identifier fn = { skb_push, __skb_push, skb_push_rcsum };
type T;
@@
- E = ((T *)(fn(SKB, LEN)))
+ E = fn(SKB, LEN)
@@
expression SKB, LEN;
identifier fn = { skb_push, __skb_push, skb_push_rcsum };
@@
- fn(SKB, LEN)[0]
+ *(u8 *)fn(SKB, LEN)
Note that the last part there converts from push(...)[0] to the
more idiomatic *(u8 *)push(...).
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-06-16 15:29:23 +03:00
fch = skb_push ( skb , hdr_len ) ;
2005-04-17 02:20:36 +04:00
}
if ( saddr )
memcpy ( fch - > saddr , saddr , dev - > addr_len ) ;
else
memcpy ( fch - > saddr , dev - > dev_addr , dev - > addr_len ) ;
2007-02-09 17:24:24 +03:00
if ( daddr )
2005-04-17 02:20:36 +04:00
{
memcpy ( fch - > daddr , daddr , dev - > addr_len ) ;
2010-09-23 00:43:57 +04:00
return hdr_len ;
2005-04-17 02:20:36 +04:00
}
return - hdr_len ;
}
2007-02-09 17:24:24 +03:00
2007-10-09 12:40:57 +04:00
static const struct header_ops fc_header_ops = {
. create = fc_header ,
} ;
2005-04-17 02:20:36 +04:00
static void fc_setup ( struct net_device * dev )
{
2007-10-09 12:40:57 +04:00
dev - > header_ops = & fc_header_ops ;
2005-04-17 02:20:36 +04:00
dev - > type = ARPHRD_IEEE802 ;
dev - > hard_header_len = FC_HLEN ;
dev - > mtu = 2024 ;
dev - > addr_len = FC_ALEN ;
dev - > tx_queue_len = 100 ; /* Long queues on fc */
dev - > flags = IFF_BROADCAST ;
memset ( dev - > broadcast , 0xFF , FC_ALEN ) ;
}
/**
* alloc_fcdev - Register fibre channel device
* @ sizeof_priv : Size of additional driver - private structure to be allocated
* for this fibre channel device
*
* Fill in the fields of the device structure with fibre channel - generic values .
*
* Constructs a new net device , complete with a private data area of
* size @ sizeof_priv . A 32 - byte ( not bit ) alignment is enforced for
* this private data area .
*/
struct net_device * alloc_fcdev ( int sizeof_priv )
{
net: set name_assign_type in alloc_netdev()
Extend alloc_netdev{,_mq{,s}}() to take name_assign_type as argument, and convert
all users to pass NET_NAME_UNKNOWN.
Coccinelle patch:
@@
expression sizeof_priv, name, setup, txqs, rxqs, count;
@@
(
-alloc_netdev_mqs(sizeof_priv, name, setup, txqs, rxqs)
+alloc_netdev_mqs(sizeof_priv, name, NET_NAME_UNKNOWN, setup, txqs, rxqs)
|
-alloc_netdev_mq(sizeof_priv, name, setup, count)
+alloc_netdev_mq(sizeof_priv, name, NET_NAME_UNKNOWN, setup, count)
|
-alloc_netdev(sizeof_priv, name, setup)
+alloc_netdev(sizeof_priv, name, NET_NAME_UNKNOWN, setup)
)
v9: move comments here from the wrong commit
Signed-off-by: Tom Gundersen <teg@jklm.no>
Reviewed-by: David Herrmann <dh.herrmann@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2014-07-14 18:37:24 +04:00
return alloc_netdev ( sizeof_priv , " fc%d " , NET_NAME_UNKNOWN , fc_setup ) ;
2005-04-17 02:20:36 +04:00
}
EXPORT_SYMBOL ( alloc_fcdev ) ;