habanalabs: avoid returning a valid handle if map_block() fails
authorTomer Tayar <ttayar@habana.ai>
Wed, 27 Jul 2022 06:04:13 +0000 (09:04 +0300)
committerOded Gabbay <ogabbay@kernel.org>
Sun, 18 Sep 2022 10:29:50 +0000 (13:29 +0300)
map_block() sets the block id handle even if get_hw_block_id() fails,
and in this case it uses block id 0 which might be a valid id.
Modify it to set the handle only if get_hw_block_id() succeeds.

Signed-off-by: Tomer Tayar <ttayar@habana.ai>
Reviewed-by: Oded Gabbay <ogabbay@kernel.org>
Signed-off-by: Oded Gabbay <ogabbay@kernel.org>
drivers/misc/habanalabs/common/memory.c

index 61bc1bf..0698c3c 100644 (file)
@@ -1418,18 +1418,23 @@ vm_type_err:
        return rc;
 }
 
-static int map_block(struct hl_device *hdev, u64 address, u64 *handle,
-                       u32 *size)
+static int map_block(struct hl_device *hdev, u64 address, u64 *handle, u32 *size)
 {
-       u32 block_id = 0;
+       u32 block_id;
        int rc;
 
+       *handle = 0;
+       if (size)
+               *size = 0;
+
        rc = hdev->asic_funcs->get_hw_block_id(hdev, address, size, &block_id);
+       if (rc)
+               return rc;
 
        *handle = block_id | HL_MMAP_TYPE_BLOCK;
        *handle <<= PAGE_SHIFT;
 
-       return rc;
+       return 0;
 }
 
 static void hw_block_vm_close(struct vm_area_struct *vma)