There should be no functionality change resulting from this patch.
Signed-off-by: Borislav Petkov <petkovbb@gmail.com>
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
 #define debug_log(fmt, args...) do {} while (0)
 #endif
 
+static inline int dev_is_idecd(ide_drive_t *drive)
+{
+       return (drive->media == ide_cdrom || drive->media == ide_optical) &&
+               !(drive->dev_flags & IDE_DFLAG_SCSI);
+}
+
 /*
  * Check whether we can support a device,
  * based on the ATAPI IDENTIFY command results.
 
        if (scsi)
                tf_flags = 0;
-       else if (drive->media == ide_cdrom || drive->media == ide_optical)
+       else if (dev_is_idecd(drive))
                tf_flags = IDE_TFLAG_OUT_NSECT | IDE_TFLAG_OUT_LBAL;
        else
                tf_flags = IDE_TFLAG_OUT_DEVICE;