hc
2024-08-19 a51341d8c7882adfad4f167bc7c3ca616908b53d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * Copyright (C) ST-Ericsson AB 2010
 * Author:    Sjur Brendeland
 */
 
#ifndef CAIF_DEVICE_H_
#define CAIF_DEVICE_H_
#include <linux/kernel.h>
#include <linux/net.h>
#include <linux/netdevice.h>
#include <linux/caif/caif_socket.h>
#include <net/caif/caif_device.h>
 
/**
 * struct caif_dev_common - data shared between CAIF drivers and stack.
 * @flowctrl:        Flow Control callback function. This function is
 *                      supplied by CAIF Core Stack and is used by CAIF
 *                      Link Layer to send flow-stop to CAIF Core.
 *                      The flow information will be distributed to all
 *                      clients of CAIF.
 *
 * @link_select:    Profile of device, either high-bandwidth or
 *            low-latency. This member is set by CAIF Link
 *            Layer Device in    order to indicate if this device
 *            is a high bandwidth or low latency device.
 *
 * @use_frag:        CAIF Frames may be fragmented.
 *            Is set by CAIF Link Layer in order to indicate if the
 *            interface receives fragmented frames that must be
 *            assembled by CAIF Core Layer.
 *
 * @use_fcs:        Indicate if Frame CheckSum (fcs) is used.
 *            Is set if the physical interface is
 *            using Frame Checksum on the CAIF Frames.
 *
 * @use_stx:        Indicate STart of frame eXtension (stx) in use.
 *            Is set if the CAIF Link Layer expects
 *            CAIF Frames to start with the STX byte.
 *
 * This structure is shared between the CAIF drivers and the CAIF stack.
 * It is used by the device to register its behavior.
 * CAIF Core layer must set the member flowctrl in order to supply
 * CAIF Link Layer with the flow control function.
 *
 */
 struct caif_dev_common {
   void (*flowctrl)(struct net_device *net, int on);
   enum caif_link_selector link_select;
   int use_frag;
   int use_fcs;
   int use_stx;
};
 
#endif    /* CAIF_DEVICE_H_ */