summaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/intel/iwlwifi/mld/hcmd.h
blob: 64a8d424832410ce1361cf351139adf17057c54a (plain)
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
56
/* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
/*
 * Copyright (C) 2024-2025 Intel Corporation
 */
#ifndef __iwl_mld_hcmd_h__
#define __iwl_mld_hcmd_h__

static inline int iwl_mld_send_cmd(struct iwl_mld *mld, struct iwl_host_cmd *cmd)
{
	/* No commands, including the d3 related commands, should be sent
	 * after entering d3
	 */
#ifdef CONFIG_PM_SLEEP
	if (WARN_ON(mld->fw_status.in_d3))
		return -EIO;
#endif

	if (!(cmd->flags & CMD_ASYNC))
		lockdep_assert_wiphy(mld->wiphy);

	/* Devices that need to shutdown immediately on rfkill are not
	 * supported, so we can send all the cmds in rfkill
	 */
	cmd->flags |= CMD_SEND_IN_RFKILL;

	return iwl_trans_send_cmd(mld->trans, cmd);
}

static inline int
__iwl_mld_send_cmd_with_flags_pdu(struct iwl_mld *mld, u32 id,
				  u32 flags, const void *data, u16 len)
{
	struct iwl_host_cmd cmd = {
		.id = id,
		.len = { data ? len : 0, },
		.data = { data, },
		.flags = flags,
	};

	return iwl_mld_send_cmd(mld, &cmd);
}

#define _iwl_mld_send_cmd_with_flags_pdu(mld, id, flags, data, len,	\
					 ignored...)			\
	__iwl_mld_send_cmd_with_flags_pdu(mld, id, flags, data, len)
#define iwl_mld_send_cmd_with_flags_pdu(mld, id, flags, data, len...)	\
	_iwl_mld_send_cmd_with_flags_pdu(mld, id, flags, data, ##len,	\
					 sizeof(*(data)))

#define iwl_mld_send_cmd_pdu(mld, id, ...)				\
	iwl_mld_send_cmd_with_flags_pdu(mld, id, 0, __VA_ARGS__)

#define iwl_mld_send_cmd_empty(mld, id)					\
	iwl_mld_send_cmd_with_flags_pdu(mld, id, 0, NULL, 0)

#endif /* __iwl_mld_hcmd_h__ */