Commit 882cdcb5 authored by Jakub Kicinski's avatar Jakub Kicinski Committed by David S. Miller

nfp: nsp: use fractional size of the buffer

NSP expresses the buffer size in MB and 4 kB blocks.  For small
buffers the kB part may make a difference, so count it in.
Signed-off-by: default avatarJakub Kicinski <jakub.kicinski@netronome.com>
Reviewed-by: default avatarDirk van der Merwe <dirk.vandermerwe@netronome.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 1e301a14
...@@ -49,6 +49,7 @@ ...@@ -49,6 +49,7 @@
#define NSP_DFLT_BUFFER_ADDRESS GENMASK_ULL(39, 0) #define NSP_DFLT_BUFFER_ADDRESS GENMASK_ULL(39, 0)
#define NSP_DFLT_BUFFER_CONFIG 0x20 #define NSP_DFLT_BUFFER_CONFIG 0x20
#define NSP_DFLT_BUFFER_SIZE_4KB GENMASK_ULL(15, 8)
#define NSP_DFLT_BUFFER_SIZE_MB GENMASK_ULL(7, 0) #define NSP_DFLT_BUFFER_SIZE_MB GENMASK_ULL(7, 0)
#define NSP_MAGIC 0xab10 #define NSP_MAGIC 0xab10
...@@ -413,8 +414,8 @@ static int nfp_nsp_command(struct nfp_nsp *state, u16 code) ...@@ -413,8 +414,8 @@ static int nfp_nsp_command(struct nfp_nsp *state, u16 code)
static int static int
nfp_nsp_command_buf(struct nfp_nsp *nsp, struct nfp_nsp_command_buf_arg *arg) nfp_nsp_command_buf(struct nfp_nsp *nsp, struct nfp_nsp_command_buf_arg *arg)
{ {
unsigned int def_size, max_size;
struct nfp_cpp *cpp = nsp->cpp; struct nfp_cpp *cpp = nsp->cpp;
unsigned int max_size;
u64 reg, cpp_buf; u64 reg, cpp_buf;
int ret, err; int ret, err;
u32 cpp_id; u32 cpp_id;
...@@ -433,11 +434,11 @@ nfp_nsp_command_buf(struct nfp_nsp *nsp, struct nfp_nsp_command_buf_arg *arg) ...@@ -433,11 +434,11 @@ nfp_nsp_command_buf(struct nfp_nsp *nsp, struct nfp_nsp_command_buf_arg *arg)
return err; return err;
max_size = max(arg->in_size, arg->out_size); max_size = max(arg->in_size, arg->out_size);
if (FIELD_GET(NSP_DFLT_BUFFER_SIZE_MB, reg) * SZ_1M < max_size) { def_size = FIELD_GET(NSP_DFLT_BUFFER_SIZE_MB, reg) * SZ_1M +
nfp_err(cpp, "NSP: default buffer too small for command 0x%04x (%llu < %u)\n", FIELD_GET(NSP_DFLT_BUFFER_SIZE_4KB, reg) * SZ_4K;
arg->arg.code, if (def_size < max_size) {
FIELD_GET(NSP_DFLT_BUFFER_SIZE_MB, reg) * SZ_1M, nfp_err(cpp, "NSP: default buffer too small for command 0x%04x (%u < %u)\n",
max_size); arg->arg.code, def_size, max_size);
return -EINVAL; return -EINVAL;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment