2005-04-17 02:20:36 +04:00
/*
* llc_output . c - LLC minimal output path
*
* Copyright ( c ) 1997 by Procom Technology , Inc .
* 2001 - 2003 by Arnaldo Carvalho de Melo < acme @ conectiva . com . br >
*
* This program can be redistributed or modified under the terms of the
* GNU General Public License version 2 as published by the Free Software
* Foundation .
* This program is distributed without any warranty or implied warranty
* of merchantability or fitness for a particular purpose .
*
* See the GNU General Public License version 2 for more details .
*/
# include <linux/if_arp.h>
# include <linux/if_tr.h>
# include <linux/netdevice.h>
# include <linux/trdevice.h>
# include <linux/skbuff.h>
# include <net/llc.h>
# include <net/llc_pdu.h>
/**
* llc_mac_hdr_init - fills MAC header fields
* @ skb : Address of the frame to initialize its MAC header
* @ sa : The MAC source address
* @ da : The MAC destination address
*
* Fills MAC header fields , depending on MAC type . Returns 0 , If MAC type
* is a valid type and initialization completes correctly 1 , otherwise .
*/
2006-03-21 09:59:36 +03:00
int llc_mac_hdr_init ( struct sk_buff * skb ,
const unsigned char * sa , const unsigned char * da )
2005-04-17 02:20:36 +04:00
{
2009-12-26 14:50:59 +03:00
int rc = - EINVAL ;
2005-04-17 02:20:36 +04:00
switch ( skb - > dev - > type ) {
2009-12-26 14:50:59 +03:00
case ARPHRD_IEEE802_TR :
2005-04-17 02:20:36 +04:00
case ARPHRD_ETHER :
2009-12-26 14:50:59 +03:00
case ARPHRD_LOOPBACK :
rc = dev_hard_header ( skb , skb - > dev , ETH_P_802_2 , da , sa ,
skb - > len ) ;
if ( rc > 0 )
rc = 0 ;
2005-04-17 02:20:36 +04:00
break ;
default :
2009-12-26 14:50:59 +03:00
WARN ( 1 , " device type not supported: %d \n " , skb - > dev - > type ) ;
2005-04-17 02:20:36 +04:00
}
return rc ;
}
/**
* llc_build_and_send_ui_pkt - unitdata request interface for upper layers
* @ sap : sap to use
* @ skb : packet to send
* @ dmac : destination mac address
* @ dsap : destination sap
*
* Upper layers calls this function when upper layer wants to send data
* using connection - less mode communication ( UI pdu ) .
*
* Accept data frame from network layer to be sent using connection -
* less mode communication ; timeout / retries handled by network layer ;
* package primitive as an event and send to SAP event handler
*/
int llc_build_and_send_ui_pkt ( struct llc_sap * sap , struct sk_buff * skb ,
unsigned char * dmac , unsigned char dsap )
{
int rc ;
llc_pdu_header_init ( skb , LLC_PDU_TYPE_U , sap - > laddr . lsap ,
dsap , LLC_PDU_CMD ) ;
llc_pdu_init_as_ui_cmd ( skb ) ;
rc = llc_mac_hdr_init ( skb , skb - > dev - > dev_addr , dmac ) ;
2005-09-22 11:32:10 +04:00
if ( likely ( ! rc ) )
2005-04-17 02:20:36 +04:00
rc = dev_queue_xmit ( skb ) ;
return rc ;
}
EXPORT_SYMBOL ( llc_mac_hdr_init ) ;
EXPORT_SYMBOL ( llc_build_and_send_ui_pkt ) ;