From nobody Tue Feb 08 15:13:55 2022 X-Original-To: dev-commits-src-branches@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 1092719C3608; Tue, 8 Feb 2022 15:13:57 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4JtRP02BLYz4dQ7; Tue, 8 Feb 2022 15:13:56 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1644333236; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=33V0UxndoLiIZyScoGHc9ntg2IpFB6J6JljXtQu3pgQ=; b=eM3tGF64GyLC9nhlMEwnY1xYroyb+HukO0Axsfm7Fv9yjakFDKsyeKLwsM4ZaJld3j4nno oO/TLhjbK2T9aS/hBU8zXcMSQUURPcYz65wtN+C5IRQ7dXix93JPCvgCOrNX46ruRlr5VT 7X+Sss35WDrHI0uHH3WQB73ulrGwobV0V9WACJU5Rv+6n/Jx/Fbwei+44+LCo9sps2lC9Q 6jOJCYs+VzG5p4+eCBoMxHUuDWW/jcv4R3FXK+dTKhvi1Ux0ZAFpmiawCsxWTpwSpxMdjK TrpJQL90VnYZCb7PBc2FEhFVJNuhPZi0rb5cJlxKgrKh09yl/RpynadkiLdztg== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 122911BB8F; Tue, 8 Feb 2022 15:13:56 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.16.1/8.16.1) with ESMTP id 218FDthJ020612; Tue, 8 Feb 2022 15:13:55 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.16.1/8.16.1/Submit) id 218FDt28020611; Tue, 8 Feb 2022 15:13:55 GMT (envelope-from git) Date: Tue, 8 Feb 2022 15:13:55 GMT Message-Id: <202202081513.218FDt28020611@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org From: Hans Petter Selasky Subject: git: 4deb6e4fab29 - stable/13 - mlx5en: Implement helper functions to open and close TLS TIR context. List-Id: Commits to the stable branches of the FreeBSD src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-branches List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-src-branches@freebsd.org X-BeenThere: dev-commits-src-branches@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: hselasky X-Git-Repository: src X-Git-Refname: refs/heads/stable/13 X-Git-Reftype: branch X-Git-Commit: 4deb6e4fab29ff268f45de186a7123f3bd96ba52 Auto-Submitted: auto-generated ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1644333236; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=33V0UxndoLiIZyScoGHc9ntg2IpFB6J6JljXtQu3pgQ=; b=ijQaqmFA1vY9Mip9iS6X9QH1/KYb0cIK/rH2BL3+s8Ol48wkTj0EmAptELe+T+Z+xjMaZk 051GKvzFi+jXR7zTYF1IgjqIi1bQd6VBbNJ/pBd3gOodC+T7vcUG8XoYBFmbty5nasx36M Ge+dWHSrD+rLp9Ufdq26FIW1FVej8tmaWpO1sjvt6sEnesq/1AfK6F4e51M9QygKfVndWf twW57m7HrGXodyiVMTcO181cRpLIc/2fEYS3JA/lOdjiQxqCXbQwSz1FhxXma3BpBInBTR /0KxX90ZGuyg5VZE5ut4X4DdvOk7/S1Xi/F0HMOkAG8wdXAICejw/Q8eW7FsLA== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1644333236; a=rsa-sha256; cv=none; b=VEGjx0Ipe+Qp88M3mmOkQ3R2G4I2bydVg+Vt32y82sTmqRg2hk1xGkPM8Zl+lF8emr7nx1 JSZHDzI6YZD2eotFS0N5GI+dkZCcsHqQg/VL8OobAHcY7ZhQkdmtKbI4uZyGZtL60LaWYz nrg2CLvkOahI/7434HwHHIcyXtp9n3AsnZNViUfLr0EUKQIHRvFfV/1jjf2uM3lquTyRLP 2Zgi8tl6uLj0eRR5mM/Gq4cDbOYfPGsAThrjb8QHsLrbJ1M92HHH4xQqI4bY05Itjurthj EZpN+UKrC1haGe/rN/6gYw7PTh1jJHywM6Ln3Td9cBGKKjLoFb1ckSlz/bHCgw== ARC-Authentication-Results: i=1; mx1.freebsd.org; none X-ThisMailContainsUnwantedMimeParts: N The branch stable/13 has been updated by hselasky: URL: https://cgit.FreeBSD.org/src/commit/?id=4deb6e4fab29ff268f45de186a7123f3bd96ba52 commit 4deb6e4fab29ff268f45de186a7123f3bd96ba52 Author: Hans Petter Selasky AuthorDate: 2022-02-08 15:08:52 +0000 Commit: Hans Petter Selasky CommitDate: 2022-02-08 15:08:52 +0000 mlx5en: Implement helper functions to open and close TLS TIR context. Sponsored by: NVIDIA Networking (cherry picked from commit 21228c67ab10570ed63becf6a8b63418fe5f8a83) --- sys/dev/mlx5/mlx5_core/mlx5_tls.c | 31 ++++++++++++++++++++++++++++++- sys/dev/mlx5/tls.h | 4 +++- 2 files changed, 33 insertions(+), 2 deletions(-) diff --git a/sys/dev/mlx5/mlx5_core/mlx5_tls.c b/sys/dev/mlx5/mlx5_core/mlx5_tls.c index 74cedb7feb38..0665a4133b45 100644 --- a/sys/dev/mlx5/mlx5_core/mlx5_tls.c +++ b/sys/dev/mlx5/mlx5_core/mlx5_tls.c @@ -1,5 +1,5 @@ /*- - * Copyright (c) 2019, Mellanox Technologies, Ltd. All rights reserved. + * Copyright (c) 2019-2021, Mellanox Technologies, Ltd. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -120,3 +120,32 @@ void mlx5_tls_close_tis(struct mlx5_core_dev *mdev, u32 tisn) mlx5_core_destroy_tis(mdev, tisn); } + +int mlx5_tls_open_tir(struct mlx5_core_dev *mdev, int tdn, int rqtn, u32 *p_tirn) +{ + u32 in[MLX5_ST_SZ_DW(create_tir_in)] = {}; + void *tirc = MLX5_ADDR_OF(create_tir_in, in, tir_context); + int err; + + MLX5_SET(tirc, tirc, transport_domain, tdn); + MLX5_SET(tirc, tirc, disp_type, MLX5_TIRC_DISP_TYPE_INDIRECT); + MLX5_SET(tirc, tirc, rx_hash_fn, MLX5_TIRC_RX_HASH_FN_HASH_INVERTED_XOR8); + MLX5_SET(tirc, tirc, indirect_table, rqtn); + MLX5_SET(tirc, tirc, tls_en, 1); + MLX5_SET(tirc, tirc, self_lb_en, + MLX5_TIRC_SELF_LB_EN_ENABLE_UNICAST | + MLX5_TIRC_SELF_LB_EN_ENABLE_MULTICAST); + + err = mlx5_core_create_tir(mdev, in, sizeof(in), p_tirn); + if (err) + return (err); + else if (*p_tirn == 0) + return (-EINVAL); + else + return (0); /* success */ +} + +void mlx5_tls_close_tir(struct mlx5_core_dev *mdev, u32 tirn) +{ + mlx5_core_destroy_tir(mdev, tirn); +} diff --git a/sys/dev/mlx5/tls.h b/sys/dev/mlx5/tls.h index 86f56e1aebaa..d9e62540b8fe 100644 --- a/sys/dev/mlx5/tls.h +++ b/sys/dev/mlx5/tls.h @@ -1,5 +1,5 @@ /*- - * Copyright (c) 2019, Mellanox Technologies, Ltd. All rights reserved. + * Copyright (c) 2019-2021, Mellanox Technologies, Ltd. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -35,5 +35,7 @@ int mlx5_encryption_key_create(struct mlx5_core_dev *mdev, u32 pdn, int mlx5_encryption_key_destroy(struct mlx5_core_dev *mdev, u32 oid); int mlx5_tls_open_tis(struct mlx5_core_dev *mdev, int tc, int tdn, int pdn, u32 *p_tisn); void mlx5_tls_close_tis(struct mlx5_core_dev *mdev, u32 tisn); +int mlx5_tls_open_tir(struct mlx5_core_dev *mdev, int tdn, int rqtn, u32 *p_tirn); +void mlx5_tls_close_tir(struct mlx5_core_dev *mdev, u32 tirn); #endif /* __MLX5_TLS_H__ */