Skip to content

Commit 64d2c22

Browse files
Dan Carpenterdavem330
Dan Carpenter
authored andcommitted
mlx5: use after free in mlx5_cmd_comp_handler()
We can't dereference "ent" after passing it to free_cmd(). Signed-off-by: Dan Carpenter <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 4ea7244 commit 64d2c22

File tree

1 file changed

+7
-4
lines changed
  • drivers/net/ethernet/mellanox/mlx5/core

1 file changed

+7
-4
lines changed

drivers/net/ethernet/mellanox/mlx5/core/cmd.c

Lines changed: 7 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1113,7 +1113,13 @@ void mlx5_cmd_comp_handler(struct mlx5_core_dev *dev, unsigned long vector)
11131113

11141114
for (i = 0; i < (1 << cmd->log_sz); i++) {
11151115
if (test_bit(i, &vector)) {
1116+
struct semaphore *sem;
1117+
11161118
ent = cmd->ent_arr[i];
1119+
if (ent->page_queue)
1120+
sem = &cmd->pages_sem;
1121+
else
1122+
sem = &cmd->sem;
11171123
ktime_get_ts(&ent->ts2);
11181124
memcpy(ent->out->first.data, ent->lay->out, sizeof(ent->lay->out));
11191125
dump_command(dev, ent, 0);
@@ -1136,10 +1142,7 @@ void mlx5_cmd_comp_handler(struct mlx5_core_dev *dev, unsigned long vector)
11361142
} else {
11371143
complete(&ent->done);
11381144
}
1139-
if (ent->page_queue)
1140-
up(&cmd->pages_sem);
1141-
else
1142-
up(&cmd->sem);
1145+
up(sem);
11431146
}
11441147
}
11451148
}

0 commit comments

Comments
 (0)