From: Venkat Duvvuru <venkatkumar.duvvuru@broadcom.com>
To: dev@dpdk.org
Cc: Jay Ding <jay.ding@broadcom.com>,
Venkat Duvvuru <venkatkumar.duvvuru@broadcom.com>
Subject: [dpdk-dev] [PATCH v3 08/20] net/bnxt: get TruFlow version
Date: Tue, 2 Nov 2021 09:35:44 +0530 [thread overview]
Message-ID: <20211102040556.7840-9-venkatkumar.duvvuru@broadcom.com> (raw)
In-Reply-To: <20211102040556.7840-1-venkatkumar.duvvuru@broadcom.com>
From: Jay Ding <jay.ding@broadcom.com>
Implement tf_get_version that returns TruFlow version
numbers and CFA resources capbilities.
Signed-off-by: Jay Ding <jay.ding@broadcom.com>
Signed-off-by: Venkat Duvvuru <venkatkumar.duvvuru@broadcom.com>
Reviewed-by: Farah Smith <farah.smith@broadcom.com>
Reviewed-by: Randy Schacher <stuart.schacher@broadcom.com>
Reviewed-by: Peter Spreadborough <peter.spreadborough@broadcom.com>
---
drivers/net/bnxt/hsi_struct_def_dpdk.h | 15 ++--
drivers/net/bnxt/tf_core/tf_core.c | 29 ++++++++
drivers/net/bnxt/tf_core/tf_core.h | 75 ++++++++++++++++++++
drivers/net/bnxt/tf_core/tf_device.h | 50 ++++++++++++++
drivers/net/bnxt/tf_core/tf_device_p4.c | 65 +++++++++++++++++-
drivers/net/bnxt/tf_core/tf_device_p4.h | 79 +++++++++++++++++++++
drivers/net/bnxt/tf_core/tf_device_p58.c | 65 +++++++++++++++++-
drivers/net/bnxt/tf_core/tf_device_p58.h | 87 ++++++++++++++++++++++++
drivers/net/bnxt/tf_core/tf_msg.c | 35 ++++++++++
drivers/net/bnxt/tf_core/tf_msg.h | 19 ++++++
10 files changed, 513 insertions(+), 6 deletions(-)
diff --git a/drivers/net/bnxt/hsi_struct_def_dpdk.h b/drivers/net/bnxt/hsi_struct_def_dpdk.h
index 77981b5cdb..6d04e39e48 100644
--- a/drivers/net/bnxt/hsi_struct_def_dpdk.h
+++ b/drivers/net/bnxt/hsi_struct_def_dpdk.h
@@ -1058,8 +1058,8 @@ struct hwrm_err_output {
#define HWRM_VERSION_MINOR 10
#define HWRM_VERSION_UPDATE 2
/* non-zero means beta version */
-#define HWRM_VERSION_RSVD 55
-#define HWRM_VERSION_STR "1.10.2.55"
+#define HWRM_VERSION_RSVD 58
+#define HWRM_VERSION_STR "1.10.2.58"
/****************
* hwrm_ver_get *
@@ -45178,7 +45178,7 @@ struct hwrm_tf_version_get_input {
uint64_t resp_addr;
} __rte_packed;
-/* hwrm_tf_version_get_output (size:128b/16B) */
+/* hwrm_tf_version_get_output (size:256b/32B) */
struct hwrm_tf_version_get_output {
/* The specific error status for the command. */
uint16_t error_code;
@@ -45195,7 +45195,14 @@ struct hwrm_tf_version_get_output {
/* Version Update number. */
uint8_t update;
/* unused. */
- uint8_t unused0[4];
+ uint8_t unused0[5];
+ /*
+ * This field is used to indicate device's capabilities and
+ * configurations.
+ */
+ uint64_t dev_caps_cfg;
+ /* unused. */
+ uint8_t unused1[7];
/*
* This field is used in Output records to indicate that the output
* is completely written to RAM. This field should be read as '1'
diff --git a/drivers/net/bnxt/tf_core/tf_core.c b/drivers/net/bnxt/tf_core/tf_core.c
index 936102c804..86dfec0eb4 100644
--- a/drivers/net/bnxt/tf_core/tf_core.c
+++ b/drivers/net/bnxt/tf_core/tf_core.c
@@ -1802,3 +1802,32 @@ int tf_get_session_info(struct tf *tfp,
return 0;
}
+
+int tf_get_version(struct tf *tfp,
+ struct tf_get_version_parms *parms)
+{
+ int rc;
+ struct tf_dev_info dev;
+
+ TF_CHECK_PARMS2(tfp, parms);
+
+ /* This function can be called before open session, filter
+ * out any non-supported device types on the Core side.
+ */
+ if (parms->device_type != TF_DEVICE_TYPE_WH &&
+ parms->device_type != TF_DEVICE_TYPE_THOR &&
+ parms->device_type != TF_DEVICE_TYPE_SR) {
+ TFP_DRV_LOG(ERR,
+ "Unsupported device type %d\n",
+ parms->device_type);
+ return -ENOTSUP;
+ }
+
+ tf_dev_bind_ops(parms->device_type, &dev);
+
+ rc = tf_msg_get_version(parms->bp, &dev, parms);
+ if (rc)
+ return rc;
+
+ return 0;
+}
diff --git a/drivers/net/bnxt/tf_core/tf_core.h b/drivers/net/bnxt/tf_core/tf_core.h
index fb02c2b161..ba9881c69d 100644
--- a/drivers/net/bnxt/tf_core/tf_core.h
+++ b/drivers/net/bnxt/tf_core/tf_core.h
@@ -2363,4 +2363,79 @@ struct tf_get_if_tbl_entry_parms {
int tf_get_if_tbl_entry(struct tf *tfp,
struct tf_get_if_tbl_entry_parms *parms);
+/**
+ * tf_get_version parameters definition.
+ */
+struct tf_get_version_parms {
+ /**
+ * [in] device type
+ *
+ * Device type for the session.
+ */
+ enum tf_device_type device_type;
+
+ /**
+ * [in] bp
+ * The pointer to the parent bp struct. This is only used for HWRM
+ * message passing within the portability layer. The type is struct
+ * bnxt.
+ */
+ void *bp;
+
+ /* [out] major
+ *
+ * Version Major number.
+ */
+ uint8_t major;
+
+ /* [out] minor
+ *
+ * Version Minor number.
+ */
+ uint8_t minor;
+
+ /* [out] update
+ *
+ * Version Update number.
+ */
+ uint8_t update;
+
+ /**
+ * [out] dev_ident_caps
+ *
+ * fw available identifier resource list
+ */
+ uint32_t dev_ident_caps;
+
+ /**
+ * [out] dev_tbl_caps
+ *
+ * fw available table resource list
+ */
+ uint32_t dev_tbl_caps;
+
+ /**
+ * [out] dev_tcam_caps
+ *
+ * fw available tcam resource list
+ */
+ uint32_t dev_tcam_caps;
+
+ /**
+ * [out] dev_em_caps
+ *
+ * fw available em resource list
+ */
+ uint32_t dev_em_caps;
+};
+
+/**
+ * Get tf fw version
+ *
+ * Used to retrieve Truflow fw version information.
+ *
+ * Returns success or failure code.
+ */
+int tf_get_version(struct tf *tfp,
+ struct tf_get_version_parms *parms);
#endif /* _TF_CORE_H_ */
diff --git a/drivers/net/bnxt/tf_core/tf_device.h b/drivers/net/bnxt/tf_core/tf_device.h
index 9b0c037db0..88bd4515ff 100644
--- a/drivers/net/bnxt/tf_core/tf_device.h
+++ b/drivers/net/bnxt/tf_core/tf_device.h
@@ -6,6 +6,7 @@
#ifndef _TF_DEVICE_H_
#define _TF_DEVICE_H_
+#include "cfa_resource_types.h"
#include "tf_core.h"
#include "tf_identifier.h"
#include "tf_tbl.h"
@@ -36,6 +37,21 @@ struct tf_dev_info {
const struct tf_dev_ops *ops;
};
+/**
+ * This structure can be used to translate the CFA resource type to TF type.
+ */
+struct tf_hcapi_resource_map {
+ /**
+ * Truflow module type associated with this resource type.
+ */
+ enum tf_module_type module_type;
+
+ /**
+ * Bitmap of TF sub-type for the element.
+ */
+ uint32_t type_caps;
+};
+
/**
* @page device Device
*
@@ -1037,6 +1053,34 @@ struct tf_dev_ops {
*/
uint64_t (*tf_dev_cfa_key_hash)(uint64_t *key_data,
uint16_t bitlen);
+
+ /**
+ * Translate the CFA resource type to Truflow type
+ *
+ * [in] hcapi_types
+ * CFA resource type bitmap
+ *
+ * [out] ident_types
+ * Pointer to identifier type bitmap
+ *
+ * [out] tcam_types
+ * Pointer to tcam type bitmap
+ *
+ * [out] tbl_types
+ * Pointer to table type bitmap
+ *
+ * [out] em_types
+ * Pointer to em type bitmap
+ *
+ * Returns
+ * - (0) if successful.
+ * - (-EINVAL) on failure.
+ */
+ int (*tf_dev_map_hcapi_caps)(uint64_t hcapi_caps,
+ uint32_t *ident_caps,
+ uint32_t *tcam_caps,
+ uint32_t *tbl_caps,
+ uint32_t *em_caps);
};
/**
@@ -1047,4 +1091,10 @@ extern const struct tf_dev_ops tf_dev_ops_p4;
extern const struct tf_dev_ops tf_dev_ops_p58_init;
extern const struct tf_dev_ops tf_dev_ops_p58;
+/**
+ * Supported device resource type mapping structures
+ */
+extern const struct tf_hcapi_resource_map tf_hcapi_res_map_p4[CFA_RESOURCE_TYPE_P4_LAST + 1];
+extern const struct tf_hcapi_resource_map tf_hcapi_res_map_p58[CFA_RESOURCE_TYPE_P58_LAST + 1];
+
#endif /* _TF_DEVICE_H_ */
diff --git a/drivers/net/bnxt/tf_core/tf_device_p4.c b/drivers/net/bnxt/tf_core/tf_device_p4.c
index 826cd0cdbc..8089785b82 100644
--- a/drivers/net/bnxt/tf_core/tf_device_p4.c
+++ b/drivers/net/bnxt/tf_core/tf_device_p4.c
@@ -271,6 +271,67 @@ static bool tf_dev_p4_is_sram_managed(struct tf *tfp __rte_unused,
{
return false;
}
+
+/**
+ * Device specific function that maps the hcapi resource types
+ * to Truflow type.
+ *
+ * [in] hcapi_caps
+ * CFA resource type bitmap
+ *
+ * [out] ident_caps
+ * Pointer to identifier type bitmap
+ *
+ * [out] tcam_caps
+ * Pointer to tcam type bitmap
+ *
+ * [out] tbl_caps
+ * Pointer to table type bitmap
+ *
+ * [out] em_caps
+ * Pointer to em type bitmap
+ *
+ * Returns
+ * - (0) if successful.
+ * - (-EINVAL) on failure.
+ */
+static int tf_dev_p4_map_hcapi_caps(uint64_t hcapi_caps,
+ uint32_t *ident_caps,
+ uint32_t *tcam_caps,
+ uint32_t *tbl_caps,
+ uint32_t *em_caps)
+{
+ uint32_t i;
+
+ *ident_caps = 0;
+ *tcam_caps = 0;
+ *tbl_caps = 0;
+ *em_caps = 0;
+
+ for (i = 0; i <= CFA_RESOURCE_TYPE_P4_LAST; i++) {
+ if (hcapi_caps & 1ULL << i) {
+ switch (tf_hcapi_res_map_p4[i].module_type) {
+ case TF_MODULE_TYPE_IDENTIFIER:
+ *ident_caps |= tf_hcapi_res_map_p4[i].type_caps;
+ break;
+ case TF_MODULE_TYPE_TABLE:
+ *tbl_caps |= tf_hcapi_res_map_p4[i].type_caps;
+ break;
+ case TF_MODULE_TYPE_TCAM:
+ *tcam_caps |= tf_hcapi_res_map_p4[i].type_caps;
+ break;
+ case TF_MODULE_TYPE_EM:
+ *em_caps |= tf_hcapi_res_map_p4[i].type_caps;
+ break;
+ default:
+ return -EINVAL;
+ }
+ }
+ }
+
+ return 0;
+}
+
/**
* Truflow P4 device specific functions
*/
@@ -321,6 +382,7 @@ const struct tf_dev_ops tf_dev_ops_p4_init = {
.tf_dev_get_global_cfg = NULL,
.tf_dev_get_mailbox = tf_dev_p4_get_mailbox,
.tf_dev_word_align = NULL,
+ .tf_dev_map_hcapi_caps = tf_dev_p4_map_hcapi_caps
};
/**
@@ -382,5 +444,6 @@ const struct tf_dev_ops tf_dev_ops_p4 = {
.tf_dev_get_global_cfg = tf_global_cfg_get,
.tf_dev_get_mailbox = tf_dev_p4_get_mailbox,
.tf_dev_word_align = tf_dev_p4_word_align,
- .tf_dev_cfa_key_hash = hcapi_cfa_p4_key_hash
+ .tf_dev_cfa_key_hash = hcapi_cfa_p4_key_hash,
+ .tf_dev_map_hcapi_caps = tf_dev_p4_map_hcapi_caps
};
diff --git a/drivers/net/bnxt/tf_core/tf_device_p4.h b/drivers/net/bnxt/tf_core/tf_device_p4.h
index c1357913f1..e84c0f9e83 100644
--- a/drivers/net/bnxt/tf_core/tf_device_p4.h
+++ b/drivers/net/bnxt/tf_core/tf_device_p4.h
@@ -157,4 +157,83 @@ struct tf_global_cfg_cfg tf_global_cfg_p4[TF_GLOBAL_CFG_TYPE_MAX] = {
TF_GLOBAL_CFG_CFG_HCAPI, TF_ACTION_BLOCK
},
};
+
+const struct tf_hcapi_resource_map tf_hcapi_res_map_p4[CFA_RESOURCE_TYPE_P4_LAST + 1] = {
+ [CFA_RESOURCE_TYPE_P4_L2_CTXT_REMAP_HIGH] = {
+ TF_MODULE_TYPE_IDENTIFIER, 1 << TF_IDENT_TYPE_L2_CTXT_HIGH
+ },
+ [CFA_RESOURCE_TYPE_P4_L2_CTXT_REMAP_LOW] = {
+ TF_MODULE_TYPE_IDENTIFIER, 1 << TF_IDENT_TYPE_L2_CTXT_LOW
+ },
+ [CFA_RESOURCE_TYPE_P4_PROF_FUNC] = {
+ TF_MODULE_TYPE_IDENTIFIER, 1 << TF_IDENT_TYPE_PROF_FUNC
+ },
+ [CFA_RESOURCE_TYPE_P4_WC_TCAM_PROF_ID] = {
+ TF_MODULE_TYPE_IDENTIFIER, 1 << TF_IDENT_TYPE_WC_PROF
+ },
+ [CFA_RESOURCE_TYPE_P4_EM_PROF_ID] = {
+ TF_MODULE_TYPE_IDENTIFIER, 1 << TF_IDENT_TYPE_EM_PROF
+ },
+ [CFA_RESOURCE_TYPE_P4_L2_CTXT_TCAM_HIGH] = {
+ TF_MODULE_TYPE_TCAM, 1 << TF_TCAM_TBL_TYPE_L2_CTXT_TCAM_HIGH
+ },
+ [CFA_RESOURCE_TYPE_P4_L2_CTXT_TCAM_LOW] = {
+ TF_MODULE_TYPE_TCAM, 1 << TF_TCAM_TBL_TYPE_L2_CTXT_TCAM_LOW
+ },
+ [CFA_RESOURCE_TYPE_P4_PROF_TCAM] = {
+ TF_MODULE_TYPE_TCAM, 1 << TF_TCAM_TBL_TYPE_PROF_TCAM
+ },
+ [CFA_RESOURCE_TYPE_P4_WC_TCAM] = {
+ TF_MODULE_TYPE_TCAM, 1 << TF_TCAM_TBL_TYPE_WC_TCAM
+ },
+ [CFA_RESOURCE_TYPE_P4_SP_TCAM] = {
+ TF_MODULE_TYPE_TCAM, 1 << TF_TCAM_TBL_TYPE_SP_TCAM
+ },
+ [CFA_RESOURCE_TYPE_P4_NAT_IPV4] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_ACT_MODIFY_IPV4
+ },
+ [CFA_RESOURCE_TYPE_P4_METER_PROF] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_METER_PROF
+ },
+ [CFA_RESOURCE_TYPE_P4_METER] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_METER_INST
+ },
+ [CFA_RESOURCE_TYPE_P4_MIRROR] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_MIRROR_CONFIG
+ },
+ [CFA_RESOURCE_TYPE_P4_FULL_ACTION] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_FULL_ACT_RECORD
+ },
+ [CFA_RESOURCE_TYPE_P4_MCG] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_MCAST_GROUPS
+ },
+ [CFA_RESOURCE_TYPE_P4_ENCAP_8B] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_ACT_ENCAP_8B
+ },
+ [CFA_RESOURCE_TYPE_P4_ENCAP_16B] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_ACT_ENCAP_16B
+ },
+ [CFA_RESOURCE_TYPE_P4_ENCAP_64B] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_ACT_ENCAP_64B
+ },
+ [CFA_RESOURCE_TYPE_P4_SP_MAC] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_ACT_SP_SMAC
+ },
+ [CFA_RESOURCE_TYPE_P4_SP_MAC_IPV4] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_ACT_SP_SMAC_IPV4
+ },
+ [CFA_RESOURCE_TYPE_P4_SP_MAC_IPV6] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_ACT_SP_SMAC_IPV6
+ },
+ [CFA_RESOURCE_TYPE_P4_COUNTER_64B] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_ACT_STATS_64
+ },
+ [CFA_RESOURCE_TYPE_P4_EM_REC] = {
+ TF_MODULE_TYPE_EM, 1 << TF_EM_TBL_TYPE_EM_RECORD
+ },
+ [CFA_RESOURCE_TYPE_P4_TBL_SCOPE] = {
+ TF_MODULE_TYPE_EM, 1 << TF_EM_TBL_TYPE_TBL_SCOPE
+ },
+};
+
#endif /* _TF_DEVICE_P4_H_ */
diff --git a/drivers/net/bnxt/tf_core/tf_device_p58.c b/drivers/net/bnxt/tf_core/tf_device_p58.c
index 47d7836a58..03e72b90f5 100644
--- a/drivers/net/bnxt/tf_core/tf_device_p58.c
+++ b/drivers/net/bnxt/tf_core/tf_device_p58.c
@@ -45,6 +45,7 @@ const char *tf_resource_str_p58[CFA_RESOURCE_TYPE_P58_LAST + 1] = {
[CFA_RESOURCE_TYPE_P58_WC_FKB] = "wc_fkb ",
[CFA_RESOURCE_TYPE_P58_VEB_TCAM] = "veb ",
[CFA_RESOURCE_TYPE_P58_METADATA] = "metadata",
+ [CFA_RESOURCE_TYPE_P58_METER_DROP_CNT] = "meter_dc",
};
/**
@@ -336,6 +337,66 @@ static int tf_dev_p58_get_sram_tbl_info(struct tf *tfp __rte_unused,
return 0;
}
+/**
+ * Device specific function that maps the hcapi resource types
+ * to Truflow type.
+ *
+ * [in] hcapi_caps
+ * CFA resource type bitmap
+ *
+ * [out] ident_caps
+ * Pointer to identifier type bitmap
+ *
+ * [out] tcam_caps
+ * Pointer to tcam type bitmap
+ *
+ * [out] tbl_caps
+ * Pointer to table type bitmap
+ *
+ * [out] em_caps
+ * Pointer to em type bitmap
+ *
+ * Returns
+ * - (0) if successful.
+ * - (-EINVAL) on failure.
+ */
+static int tf_dev_p58_map_hcapi_caps(uint64_t hcapi_caps,
+ uint32_t *ident_caps,
+ uint32_t *tcam_caps,
+ uint32_t *tbl_caps,
+ uint32_t *em_caps)
+{
+ uint32_t i;
+
+ *ident_caps = 0;
+ *tcam_caps = 0;
+ *tbl_caps = 0;
+ *em_caps = 0;
+
+ for (i = 0; i <= CFA_RESOURCE_TYPE_P58_LAST; i++) {
+ if (hcapi_caps & 1ULL << i) {
+ switch (tf_hcapi_res_map_p58[i].module_type) {
+ case TF_MODULE_TYPE_IDENTIFIER:
+ *ident_caps |= tf_hcapi_res_map_p58[i].type_caps;
+ break;
+ case TF_MODULE_TYPE_TABLE:
+ *tbl_caps |= tf_hcapi_res_map_p58[i].type_caps;
+ break;
+ case TF_MODULE_TYPE_TCAM:
+ *tcam_caps |= tf_hcapi_res_map_p58[i].type_caps;
+ break;
+ case TF_MODULE_TYPE_EM:
+ *em_caps |= tf_hcapi_res_map_p58[i].type_caps;
+ break;
+ default:
+ return -EINVAL;
+ }
+ }
+ }
+
+ return 0;
+}
+
/**
* Truflow P58 device specific functions
*/
@@ -386,6 +447,7 @@ const struct tf_dev_ops tf_dev_ops_p58_init = {
.tf_dev_get_global_cfg = NULL,
.tf_dev_get_mailbox = tf_dev_p58_get_mailbox,
.tf_dev_word_align = NULL,
+ .tf_dev_map_hcapi_caps = tf_dev_p58_map_hcapi_caps
};
/**
@@ -448,5 +510,6 @@ const struct tf_dev_ops tf_dev_ops_p58 = {
.tf_dev_get_global_cfg = tf_global_cfg_get,
.tf_dev_get_mailbox = tf_dev_p58_get_mailbox,
.tf_dev_word_align = tf_dev_p58_word_align,
- .tf_dev_cfa_key_hash = hcapi_cfa_p58_key_hash
+ .tf_dev_cfa_key_hash = hcapi_cfa_p58_key_hash,
+ .tf_dev_map_hcapi_caps = tf_dev_p58_map_hcapi_caps
};
diff --git a/drivers/net/bnxt/tf_core/tf_device_p58.h b/drivers/net/bnxt/tf_core/tf_device_p58.h
index 3e8759f2df..f6e66936f3 100644
--- a/drivers/net/bnxt/tf_core/tf_device_p58.h
+++ b/drivers/net/bnxt/tf_core/tf_device_p58.h
@@ -209,4 +209,91 @@ struct tf_global_cfg_cfg tf_global_cfg_p58[TF_GLOBAL_CFG_TYPE_MAX] = {
TF_GLOBAL_CFG_CFG_HCAPI, TF_METER_INTERVAL_CFG
},
};
+
+const struct tf_hcapi_resource_map tf_hcapi_res_map_p58[CFA_RESOURCE_TYPE_P58_LAST + 1] = {
+ [CFA_RESOURCE_TYPE_P58_L2_CTXT_REMAP_HIGH] = {
+ TF_MODULE_TYPE_IDENTIFIER, 1 << TF_IDENT_TYPE_L2_CTXT_HIGH
+ },
+ [CFA_RESOURCE_TYPE_P58_L2_CTXT_REMAP_LOW] = {
+ TF_MODULE_TYPE_IDENTIFIER, 1 << TF_IDENT_TYPE_L2_CTXT_LOW
+ },
+ [CFA_RESOURCE_TYPE_P58_PROF_FUNC] = {
+ TF_MODULE_TYPE_IDENTIFIER, 1 << TF_IDENT_TYPE_PROF_FUNC
+ },
+ [CFA_RESOURCE_TYPE_P58_WC_TCAM_PROF_ID] = {
+ TF_MODULE_TYPE_IDENTIFIER, 1 << TF_IDENT_TYPE_WC_PROF
+ },
+ [CFA_RESOURCE_TYPE_P58_EM_PROF_ID] = {
+ TF_MODULE_TYPE_IDENTIFIER, 1 << TF_IDENT_TYPE_EM_PROF
+ },
+ [CFA_RESOURCE_TYPE_P58_L2_CTXT_TCAM_HIGH] = {
+ TF_MODULE_TYPE_TCAM, 1 << TF_TCAM_TBL_TYPE_L2_CTXT_TCAM_HIGH
+ },
+ [CFA_RESOURCE_TYPE_P58_L2_CTXT_TCAM_LOW] = {
+ TF_MODULE_TYPE_TCAM, 1 << TF_TCAM_TBL_TYPE_L2_CTXT_TCAM_LOW
+ },
+ [CFA_RESOURCE_TYPE_P58_PROF_TCAM] = {
+ TF_MODULE_TYPE_TCAM, 1 << TF_TCAM_TBL_TYPE_PROF_TCAM
+ },
+ [CFA_RESOURCE_TYPE_P58_WC_TCAM] = {
+ TF_MODULE_TYPE_TCAM, 1 << TF_TCAM_TBL_TYPE_WC_TCAM
+ },
+ [CFA_RESOURCE_TYPE_P58_VEB_TCAM] = {
+ TF_MODULE_TYPE_TCAM, 1 << TF_TCAM_TBL_TYPE_VEB_TCAM
+ },
+ [CFA_RESOURCE_TYPE_P58_EM_FKB] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_EM_FKB
+ },
+ [CFA_RESOURCE_TYPE_P58_WC_FKB] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_WC_FKB
+ },
+ [CFA_RESOURCE_TYPE_P58_METER_PROF] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_METER_PROF
+ },
+ [CFA_RESOURCE_TYPE_P58_METER] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_METER_INST
+ },
+ [CFA_RESOURCE_TYPE_P58_METER_DROP_CNT] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_METER_DROP_CNT
+ },
+ [CFA_RESOURCE_TYPE_P58_MIRROR] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_MIRROR_CONFIG
+ },
+ [CFA_RESOURCE_TYPE_P58_METADATA] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_METADATA
+ },
+ /* Resources in bank 1 */
+ [CFA_RESOURCE_TYPE_P58_SRAM_BANK_1] = {
+ TF_MODULE_TYPE_TABLE,
+ 1 << TF_TBL_TYPE_FULL_ACT_RECORD
+ | 1 << TF_TBL_TYPE_COMPACT_ACT_RECORD
+ },
+ /* Resources in bank 2 */
+ [CFA_RESOURCE_TYPE_P58_SRAM_BANK_2] = {
+ TF_MODULE_TYPE_TABLE,
+ 1 << TF_TBL_TYPE_ACT_ENCAP_8B |
+ 1 << TF_TBL_TYPE_ACT_ENCAP_16B |
+ 1 << TF_TBL_TYPE_ACT_ENCAP_32B |
+ 1 << TF_TBL_TYPE_ACT_ENCAP_64B |
+ 1 << TF_TBL_TYPE_ACT_MODIFY_8B |
+ 1 << TF_TBL_TYPE_ACT_MODIFY_16B |
+ 1 << TF_TBL_TYPE_ACT_MODIFY_32B |
+ 1 << TF_TBL_TYPE_ACT_MODIFY_64B
+
+ },
+ /* Resources in bank 0 */
+ [CFA_RESOURCE_TYPE_P58_SRAM_BANK_0] = {
+ TF_MODULE_TYPE_TABLE,
+ 1 << TF_TBL_TYPE_ACT_SP_SMAC |
+ 1 << TF_TBL_TYPE_ACT_SP_SMAC_IPV4 |
+ 1 << TF_TBL_TYPE_ACT_SP_SMAC_IPV6
+ },
+ /* Resources in bank 3 */
+ [CFA_RESOURCE_TYPE_P58_SRAM_BANK_3] = {
+ TF_MODULE_TYPE_TABLE, 1 << TF_TBL_TYPE_ACT_STATS_64
+ },
+ [CFA_RESOURCE_TYPE_P58_EM_REC] = {
+ TF_MODULE_TYPE_EM, 1 << TF_EM_TBL_TYPE_EM_RECORD
+ },
+};
#endif /* _TF_DEVICE_P58_H_ */
diff --git a/drivers/net/bnxt/tf_core/tf_msg.c b/drivers/net/bnxt/tf_core/tf_msg.c
index ea6e2af7ce..25bf026658 100644
--- a/drivers/net/bnxt/tf_core/tf_msg.c
+++ b/drivers/net/bnxt/tf_core/tf_msg.c
@@ -2306,3 +2306,38 @@ tf_msg_set_if_tbl_entry(struct tf *tfp,
return 0;
}
+
+int
+tf_msg_get_version(struct bnxt *bp,
+ struct tf_dev_info *dev,
+ struct tf_get_version_parms *params)
+
+{
+ int rc;
+ struct hwrm_tf_version_get_input req = { 0 };
+ struct hwrm_tf_version_get_output resp = { 0 };
+ struct tfp_send_msg_parms parms = { 0 };
+
+ /* Populate the request */
+ parms.tf_type = HWRM_TF_VERSION_GET,
+ parms.req_data = (uint32_t *)&req;
+ parms.req_size = sizeof(req);
+ parms.resp_data = (uint32_t *)&resp;
+ parms.resp_size = sizeof(resp);
+ parms.mailbox = dev->ops->tf_dev_get_mailbox();
+
+ rc = tfp_send_msg_direct(bp,
+ &parms);
+
+ params->major = resp.major;
+ params->minor = resp.minor;
+ params->update = resp.update;
+
+ dev->ops->tf_dev_map_hcapi_caps(resp.dev_caps_cfg,
+ ¶ms->dev_ident_caps,
+ ¶ms->dev_tcam_caps,
+ ¶ms->dev_tbl_caps,
+ ¶ms->dev_em_caps);
+
+ return rc;
+}
diff --git a/drivers/net/bnxt/tf_core/tf_msg.h b/drivers/net/bnxt/tf_core/tf_msg.h
index 718bc2f3b2..08d20cdd7a 100644
--- a/drivers/net/bnxt/tf_core/tf_msg.h
+++ b/drivers/net/bnxt/tf_core/tf_msg.h
@@ -738,4 +738,23 @@ int tf_msg_set_if_tbl_entry(struct tf *tfp,
int tf_msg_get_if_tbl_entry(struct tf *tfp,
struct tf_if_tbl_get_parms *params);
+/**
+ * Send get version request to the firmware.
+ *
+ * [in] bp
+ * Pointer to bnxt handle
+ *
+ * [in] dev
+ * Pointer to the associated device
+ *
+ * [in/out] parms
+ * Pointer to the version info parameter
+ *
+ * Returns:
+ * 0 on Success else internal Truflow error
+ */
+int
+tf_msg_get_version(struct bnxt *bp,
+ struct tf_dev_info *dev,
+ struct tf_get_version_parms *parms);
#endif /* _TF_MSG_H_ */
--
2.17.1
next prev parent reply other threads:[~2021-11-02 4:07 UTC|newest]
Thread overview: 118+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-10-01 5:59 [dpdk-dev] [PATCH 0/9] fixes and enhancements to Truflow Venkat Duvvuru
2021-10-01 5:59 ` [dpdk-dev] [PATCH 1/9] net/bnxt: add nat support for dest IP and port combination Venkat Duvvuru
2021-10-01 5:59 ` [dpdk-dev] [PATCH 2/9] net/bnxt: support multi root capability flag Venkat Duvvuru
2021-10-01 5:59 ` [dpdk-dev] [PATCH 3/9] net/bnxt: fix the out of boundary issue in hash list Venkat Duvvuru
2021-10-01 5:59 ` [dpdk-dev] [PATCH 4/9] net/bnxt: add clear on read stats support for Thor Venkat Duvvuru
2021-10-01 5:59 ` [dpdk-dev] [PATCH 5/9] net/bnxt: add feature capability option for socket direct Venkat Duvvuru
2021-10-01 5:59 ` [dpdk-dev] [PATCH 6/9] net/bnxt: enable wildcard match for ingress flows Venkat Duvvuru
2021-10-01 5:59 ` [dpdk-dev] [PATCH 7/9] net/bnxt: support inner IP header for GRE tunnel flows Venkat Duvvuru
2021-10-01 5:59 ` [dpdk-dev] [PATCH 8/9] net/bnxt: get Truflow version Venkat Duvvuru
2021-10-01 5:59 ` [dpdk-dev] [PATCH 9/9] net/bnxt: increase scaling numbers on Thor Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 00/19] fixes and enhancements to Truflow Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 01/19] net/bnxt: add NAT support for dest IP and port combination Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 02/19] net/bnxt: add support for multi root capability Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 03/19] net/bnxt: fix the out of boundary issue in hash list Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 04/19] net/bnxt: add clear on read support Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 05/19] net/bnxt: add capability option for socket redirect Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 06/19] net/bnxt: enable wildcard match for ingress flows Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 07/19] net/bnxt: support inner IP header for GRE tunnel flows Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 08/19] net/bnxt: get TruFlow version Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 09/19] net/bnxt: increase flow scale for Thor Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 10/19] net/bnxt: remove accumulation of stats devargs argument Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 11/19] net/bnxt: fix clang compiler warnings Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 12/19] net/bnxt: updated the log messages Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 13/19] net/bnxt: add support for socket redirect feature Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 14/19] net/bnxt: delete the VF pair before VF representor alloc Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 15/19] net/bnxt: add new API TruFlow get SRAM resources Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 16/19] net/bnxt: add TruFlow and AFM SRAM partitioning support Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 17/19] net/bnxt: add Tx TruFlow table config for p4 Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 18/19] net/bnxt: remove 2-slice WC entries for scale Venkat Duvvuru
2021-10-26 5:05 ` [dpdk-dev] [PATCH v2 19/19] net/bnxt: check for mismatch of control and physical port Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 00/20] fixes and enhancements to Truflow Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 01/20] net/bnxt: add NAT support for dest IP and port combination Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 02/20] net/bnxt: add support for multi root capability Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 03/20] net/bnxt: fix the out of boundary issue in hash list Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 04/20] net/bnxt: add clear on read support Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 05/20] net/bnxt: add capability option for socket redirect Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 06/20] net/bnxt: enable wildcard match for ingress flows Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 07/20] net/bnxt: support inner IP header for GRE tunnel flows Venkat Duvvuru
2021-11-02 4:05 ` Venkat Duvvuru [this message]
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 09/20] net/bnxt: increase flow scale for Thor Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 10/20] net/bnxt: remove accumulation of stats devargs argument Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 11/20] net/bnxt: fix clang compiler warnings Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 12/20] net/bnxt: updated the log messages Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 13/20] net/bnxt: add support for socket direct feature Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 14/20] net/bnxt: delete the VF pair before VF representor alloc Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 15/20] net/bnxt: add new API TruFlow get SRAM resources Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 16/20] net/bnxt: add TruFlow and AFM SRAM partitioning support Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 17/20] net/bnxt: add Tx TruFlow table config for p4 device Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 18/20] net/bnxt: remove 2-slice WC entries for scale Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 19/20] net/bnxt: check for mismatch of control and physical port Venkat Duvvuru
2021-11-02 4:05 ` [dpdk-dev] [PATCH v3 20/20] net/bnxt: use enum for bank ID Venkat Duvvuru
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 00/20] fixes and enhancements to Truflow Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 01/20] net/bnxt: add NAT support for dest IP and port combination Ajit Khaparde
2021-11-03 13:24 ` Ferruh Yigit
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 02/20] net/bnxt: add support for multi root capability Ajit Khaparde
2021-11-03 13:24 ` Ferruh Yigit
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 03/20] net/bnxt: fix out of bounds issue in hash list Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 04/20] net/bnxt: add clear on read support Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 05/20] net/bnxt: add capability option for socket redirect Ajit Khaparde
2021-11-03 13:24 ` Ferruh Yigit
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 06/20] net/bnxt: enable wildcard match for ingress flows Ajit Khaparde
2021-11-03 13:24 ` Ferruh Yigit
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 07/20] net/bnxt: support inner IP header for GRE tunnel flows Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 08/20] net/bnxt: get TruFlow version Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 09/20] net/bnxt: increase flow scale for Thor Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 10/20] net/bnxt: remove devargs for stats accumulation Ajit Khaparde
2021-11-03 13:24 ` Ferruh Yigit
2021-11-03 13:35 ` Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 11/20] net/bnxt: fix clang compiler warnings Ajit Khaparde
2021-11-03 13:24 ` Ferruh Yigit
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 12/20] net/bnxt: update log messages in TruFlow path Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 13/20] net/bnxt: add support for socket direct feature Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 14/20] net/bnxt: modify VF representor alloc sequence Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 15/20] net/bnxt: add new TruFlow API to get SRAM resources Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 16/20] net/bnxt: add TruFlow and AFM SRAM partitioning support Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 17/20] net/bnxt: add Tx TruFlow table config for P4 device Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 18/20] net/bnxt: remove 2 slice WC entries Ajit Khaparde
2021-11-03 13:24 ` Ferruh Yigit
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 19/20] net/bnxt: check mismatch of control and physical port Ajit Khaparde
2021-11-03 0:52 ` [dpdk-dev] [PATCH v4 20/20] net/bnxt: use enum for bank ID Ajit Khaparde
2021-11-03 3:40 ` [dpdk-dev] [PATCH v4 00/20] fixes and enhancements to Truflow Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 00/22] " Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 01/22] net/bnxt: add NAT support for dest IP and port combination Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 02/22] net/bnxt: add support for multi root capability Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 03/22] net/bnxt: fix out of bounds issue in hash list Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 04/22] net/bnxt: add clear on read support Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 05/22] net/bnxt: add capability option for socket redirect Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 06/22] net/bnxt: remove unused functions Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 07/22] net/bnxt: address ISO C90 compilation error Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 08/22] net/bnxt: enable wildcard match for ingress flows Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 09/22] net/bnxt: support inner IP header for GRE tunnel flows Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 10/22] net/bnxt: get TruFlow version Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 11/22] net/bnxt: increase flow scale for Thor Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 12/22] net/bnxt: remove devargs for stats accumulation Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 13/22] net/bnxt: fix clang compiler warnings Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 14/22] net/bnxt: update log messages in TruFlow path Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 15/22] net/bnxt: add support for socket direct feature Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 16/22] net/bnxt: modify VF representor alloc sequence Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 17/22] net/bnxt: add new TruFlow API to get SRAM resources Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 18/22] net/bnxt: add TruFlow and AFM SRAM partitioning support Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 19/22] net/bnxt: add Tx TruFlow table config for P4 device Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 20/22] net/bnxt: remove 2 slice wildcard entries Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 21/22] net/bnxt: check mismatch of control and physical port Ajit Khaparde
2021-11-04 21:58 ` [dpdk-dev] [PATCH v5 22/22] net/bnxt: use enum for bank ID Ajit Khaparde
2021-11-05 0:57 ` [dpdk-dev] [PATCH v5 00/22] fixes and enhancements to Truflow Ajit Khaparde
2021-11-05 11:10 ` Ferruh Yigit
2021-11-05 11:30 ` Thomas Monjalon
2021-11-05 16:55 ` [dpdk-dev] [PATCH] doc: update release notes for bnxt PMD Ajit Khaparde
2021-11-05 18:14 ` Ferruh Yigit
2021-11-05 18:22 ` Ajit Khaparde
2021-11-05 18:38 ` Ferruh Yigit
2021-11-05 18:41 ` Ajit Khaparde
2021-11-05 18:42 ` Ferruh Yigit
2021-11-05 18:48 ` Ajit Khaparde
2021-11-05 16:57 ` [dpdk-dev] [PATCH v5 00/22] fixes and enhancements to Truflow Ajit Khaparde
2021-11-05 17:20 ` Ferruh Yigit
2021-11-05 18:46 ` [dpdk-dev] [PATCH] doc: update for bnxt PMD Ajit Khaparde
2021-11-17 3:59 ` Ajit Khaparde
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20211102040556.7840-9-venkatkumar.duvvuru@broadcom.com \
--to=venkatkumar.duvvuru@broadcom.com \
--cc=dev@dpdk.org \
--cc=jay.ding@broadcom.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).