xref: /freebsd/sys/contrib/dev/iwlwifi/fw/api/context.h (revision bfcc09ddd422c95a1a2e4e794b63ee54c4902398)
1*bfcc09ddSBjoern A. Zeeb /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
2*bfcc09ddSBjoern A. Zeeb /*
3*bfcc09ddSBjoern A. Zeeb  * Copyright (C) 2012-2014 Intel Corporation
4*bfcc09ddSBjoern A. Zeeb  * Copyright (C) 2013-2015 Intel Mobile Communications GmbH
5*bfcc09ddSBjoern A. Zeeb  * Copyright (C) 2016-2017 Intel Deutschland GmbH
6*bfcc09ddSBjoern A. Zeeb  */
7*bfcc09ddSBjoern A. Zeeb #ifndef __iwl_fw_api_context_h__
8*bfcc09ddSBjoern A. Zeeb #define __iwl_fw_api_context_h__
9*bfcc09ddSBjoern A. Zeeb 
10*bfcc09ddSBjoern A. Zeeb /**
11*bfcc09ddSBjoern A. Zeeb  * enum iwl_ctxt_id_and_color - ID and color fields in context dword
12*bfcc09ddSBjoern A. Zeeb  * @FW_CTXT_ID_POS: position of the ID
13*bfcc09ddSBjoern A. Zeeb  * @FW_CTXT_ID_MSK: mask of the ID
14*bfcc09ddSBjoern A. Zeeb  * @FW_CTXT_COLOR_POS: position of the color
15*bfcc09ddSBjoern A. Zeeb  * @FW_CTXT_COLOR_MSK: mask of the color
16*bfcc09ddSBjoern A. Zeeb  * @FW_CTXT_INVALID: value used to indicate unused/invalid
17*bfcc09ddSBjoern A. Zeeb  */
18*bfcc09ddSBjoern A. Zeeb enum iwl_ctxt_id_and_color {
19*bfcc09ddSBjoern A. Zeeb 	FW_CTXT_ID_POS		= 0,
20*bfcc09ddSBjoern A. Zeeb 	FW_CTXT_ID_MSK		= 0xff << FW_CTXT_ID_POS,
21*bfcc09ddSBjoern A. Zeeb 	FW_CTXT_COLOR_POS	= 8,
22*bfcc09ddSBjoern A. Zeeb 	FW_CTXT_COLOR_MSK	= 0xff << FW_CTXT_COLOR_POS,
23*bfcc09ddSBjoern A. Zeeb 	FW_CTXT_INVALID		= 0xffffffff,
24*bfcc09ddSBjoern A. Zeeb };
25*bfcc09ddSBjoern A. Zeeb 
26*bfcc09ddSBjoern A. Zeeb #define FW_CMD_ID_AND_COLOR(_id, _color) (((_id) << FW_CTXT_ID_POS) |\
27*bfcc09ddSBjoern A. Zeeb 					  ((_color) << FW_CTXT_COLOR_POS))
28*bfcc09ddSBjoern A. Zeeb 
29*bfcc09ddSBjoern A. Zeeb /* Possible actions on PHYs, MACs and Bindings */
30*bfcc09ddSBjoern A. Zeeb enum iwl_ctxt_action {
31*bfcc09ddSBjoern A. Zeeb 	FW_CTXT_ACTION_STUB = 0,
32*bfcc09ddSBjoern A. Zeeb 	FW_CTXT_ACTION_ADD,
33*bfcc09ddSBjoern A. Zeeb 	FW_CTXT_ACTION_MODIFY,
34*bfcc09ddSBjoern A. Zeeb 	FW_CTXT_ACTION_REMOVE,
35*bfcc09ddSBjoern A. Zeeb 	FW_CTXT_ACTION_NUM
36*bfcc09ddSBjoern A. Zeeb }; /* COMMON_CONTEXT_ACTION_API_E_VER_1 */
37*bfcc09ddSBjoern A. Zeeb 
38*bfcc09ddSBjoern A. Zeeb #endif /* __iwl_fw_api_context_h__ */
39