2019-05-29 22:17:55 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
2005-04-17 06:20:36 +08: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>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/if_arp.h>
|
|
|
|
#include <linux/netdevice.h>
|
|
|
|
#include <linux/skbuff.h>
|
2011-07-15 23:47:34 +08:00
|
|
|
#include <linux/export.h>
|
2005-04-17 06:20:36 +08:00
|
|
|
#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 14:59:36 +08:00
|
|
|
int llc_mac_hdr_init(struct sk_buff *skb,
|
|
|
|
const unsigned char *sa, const unsigned char *da)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2009-12-26 19:50:59 +08:00
|
|
|
int rc = -EINVAL;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
switch (skb->dev->type) {
|
|
|
|
case ARPHRD_ETHER:
|
2009-12-26 19:50:59 +08: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 06:20:36 +08:00
|
|
|
break;
|
|
|
|
default:
|
2014-01-29 05:30:52 +08:00
|
|
|
break;
|
2005-04-17 06:20:36 +08: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,
|
2021-10-12 23:58:37 +08:00
|
|
|
const unsigned char *dmac, unsigned char dsap)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
|
|
|
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 15:32:10 +08:00
|
|
|
if (likely(!rc))
|
2005-04-17 06:20:36 +08:00
|
|
|
rc = dev_queue_xmit(skb);
|
2019-05-28 08:35:52 +08:00
|
|
|
else
|
|
|
|
kfree_skb(skb);
|
2005-04-17 06:20:36 +08:00
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPORT_SYMBOL(llc_mac_hdr_init);
|
|
|
|
EXPORT_SYMBOL(llc_build_and_send_ui_pkt);
|