__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

[email protected]: ~ $
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * Copyright (c) 2023, Intel Corporation. All rights reserved.
 */
#ifndef _LINUX_USB_LJCA_H_
#define _LINUX_USB_LJCA_H_

#include <linux/auxiliary_bus.h>
#include <linux/list.h>
#include <linux/spinlock.h>
#include <linux/types.h>

#define LJCA_MAX_GPIO_NUM 64

#define auxiliary_dev_to_ljca_client(auxiliary_dev)			\
		container_of(auxiliary_dev, struct ljca_client, auxdev)

struct ljca_adapter;

/**
 * typedef ljca_event_cb_t - event callback function signature
 *
 * @context: the execution context of who registered this callback
 * @cmd: the command from device for this event
 * @evt_data: the event data payload
 * @len: the event data payload length
 *
 * The callback function is called in interrupt context and the data payload is
 * only valid during the call. If the user needs later access of the data, it
 * must copy it.
 */
typedef void (*ljca_event_cb_t)(void *context, u8 cmd, const void *evt_data, int len);

/**
 * struct ljca_client - represent a ljca client device
 *
 * @type: ljca client type
 * @id: ljca client id within same client type
 * @link: ljca client on the same ljca adapter
 * @auxdev: auxiliary device object
 * @adapter: ljca adapter the ljca client sit on
 * @context: the execution context of the event callback
 * @event_cb: ljca client driver register this callback to get
 *	firmware asynchronous rx buffer pending notifications
 * @event_cb_lock: spinlock to protect event callback
 */
struct ljca_client {
	u8 type;
	u8 id;
	struct list_head link;
	struct auxiliary_device auxdev;
	struct ljca_adapter *adapter;

	void *context;
	ljca_event_cb_t event_cb;
	/* lock to protect event_cb */
	spinlock_t event_cb_lock;
};

/**
 * struct ljca_gpio_info - ljca gpio client device info
 *
 * @num: ljca gpio client device pin number
 * @valid_pin_map: ljca gpio client device valid pin mapping
 */
struct ljca_gpio_info {
	unsigned int num;
	DECLARE_BITMAP(valid_pin_map, LJCA_MAX_GPIO_NUM);
};

/**
 * struct ljca_i2c_info - ljca i2c client device info
 *
 * @id: ljca i2c client device identification number
 * @capacity: ljca i2c client device capacity
 * @intr_pin: ljca i2c client device interrupt pin number if exists
 */
struct ljca_i2c_info {
	u8 id;
	u8 capacity;
	u8 intr_pin;
};

/**
 * struct ljca_spi_info - ljca spi client device info
 *
 * @id: ljca spi client device identification number
 * @capacity: ljca spi client device capacity
 */
struct ljca_spi_info {
	u8 id;
	u8 capacity;
};

/**
 * ljca_register_event_cb - register a callback function to receive events
 *
 * @client: ljca client device
 * @event_cb: callback function
 * @context: execution context of event callback
 *
 * Return: 0 in case of success, negative value in case of error
 */
int ljca_register_event_cb(struct ljca_client *client, ljca_event_cb_t event_cb, void *context);

/**
 * ljca_unregister_event_cb - unregister the callback function for an event
 *
 * @client: ljca client device
 */
void ljca_unregister_event_cb(struct ljca_client *client);

/**
 * ljca_transfer - issue a LJCA command and wait for a response
 *
 * @client: ljca client device
 * @cmd: the command to be sent to the device
 * @obuf: the buffer to be sent to the device; it can be NULL if the user
 *	doesn't need to transmit data with this command
 * @obuf_len: the size of the buffer to be sent to the device; it should
 *	be 0 when obuf is NULL
 * @ibuf: any data associated with the response will be copied here; it can be
 *	NULL if the user doesn't need the response data
 * @ibuf_len: must be initialized to the input buffer size
 *
 * Return: the actual length of response data for success, negative value for errors
 */
int ljca_transfer(struct ljca_client *client, u8 cmd, const u8 *obuf,
		  u8 obuf_len, u8 *ibuf, u8 ibuf_len);

/**
 * ljca_transfer_noack - issue a LJCA command without a response
 *
 * @client: ljca client device
 * @cmd: the command to be sent to the device
 * @obuf: the buffer to be sent to the device; it can be NULL if the user
 *	doesn't need to transmit data with this command
 * @obuf_len: the size of the buffer to be sent to the device
 *
 * Return: 0 for success, negative value for errors
 */
int ljca_transfer_noack(struct ljca_client *client, u8 cmd, const u8 *obuf,
			u8 obuf_len);

#endif

Filemanager

Name Type Size Permission Actions
audio-v2.h File 13.87 KB 0644
audio-v3.h File 13.94 KB 0644
audio.h File 1.08 KB 0644
c67x00.h File 1.12 KB 0644
ccid.h File 787 B 0644
cdc-wdm.h File 511 B 0644
cdc.h File 1.3 KB 0644
cdc_ncm.h File 5.84 KB 0644
ch9.h File 2.13 KB 0644
chipidea.h File 3.61 KB 0644
composite.h File 24.61 KB 0644
ehci-dbgp.h File 2.05 KB 0644
ehci_def.h File 7.4 KB 0644
ehci_pdriver.h File 1.66 KB 0644
ezusb.h File 286 B 0644
func_utils.h File 2.65 KB 0644
functionfs.h File 151 B 0644
g_hid.h File 442 B 0644
gadget.h File 36.8 KB 0644
gadget_configfs.h File 2.87 KB 0644
hcd.h File 27.41 KB 0644
input.h File 526 B 0644
iowarrior.h File 1.34 KB 0644
irda.h File 3.76 KB 0644
isp116x.h File 1.13 KB 0644
isp1301.h File 1.93 KB 0644
isp1362.h File 1.59 KB 0644
ljca.h File 4.2 KB 0644
m66592.h File 773 B 0644
midi-v2.h File 3.55 KB 0644
musb-ux500.h File 395 B 0644
musb.h File 3.16 KB 0644
net2280.h File 22.86 KB 0644
of.h File 2.03 KB 0644
ohci_pdriver.h File 1.02 KB 0644
onboard_dev.h File 584 B 0644
otg-fsm.h File 7.93 KB 0644
otg.h File 3.08 KB 0644
pd.h File 16.7 KB 0644
pd_ado.h File 1.16 KB 0644
pd_bdo.h File 556 B 0644
pd_ext_sdb.h File 698 B 0644
pd_vdo.h File 16.51 KB 0644
phy.h File 8.09 KB 0644
phy_companion.h File 693 B 0644
quirks.h File 2.44 KB 0644
r8152.h File 1.04 KB 0644
r8a66597.h File 16.99 KB 0644
renesas_usbhs.h File 3.62 KB 0644
rndis_host.h File 5.32 KB 0644
role.h File 3.58 KB 0644
rzv2m_usb3drd.h File 450 B 0644
serial.h File 17.17 KB 0644
sl811.h File 838 B 0644
storage.h File 2.77 KB 0644
tcpci.h File 8.49 KB 0644
tcpm.h File 7.73 KB 0644
tegra_usb_phy.h File 2.23 KB 0644
typec.h File 12.61 KB 0644
typec_altmode.h File 7.71 KB 0644
typec_dp.h File 4.69 KB 0644
typec_mux.h File 2.77 KB 0644
typec_retimer.h File 1.17 KB 0644
typec_tbt.h File 1.82 KB 0644
uas.h File 2.07 KB 0644
ulpi.h File 2.1 KB 0644
usb338x.h File 7.29 KB 0644
usb_phy_generic.h File 582 B 0644
usbnet.h File 10.07 KB 0644
uvc.h File 6.46 KB 0644
webusb.h File 2.4 KB 0644
xhci-dbgp.h File 651 B 0644
Filemanager