[PATCH v1 1/3] scsi: Implement get_blk() function
Varadarajan Narayanan
quic_varada at quicinc.com
Wed Apr 2 17:56:21 CEST 2025
On Tue, Apr 01, 2025 at 06:29:31PM +0200, Heinrich Schuchardt wrote:
> On 01.04.25 10:00, Varadarajan Narayanan wrote:
> > Add a function to obtain the block device for SCSI.
> >
> > Signed-off-by: Varadarajan Narayanan <quic_varada at quicinc.com>
> > ---
> > drivers/scsi/scsi-uclass.c | 30 ++++++++++++++++++++++++++++++
> > include/scsi.h | 12 ++++++++++++
> > 2 files changed, 42 insertions(+)
> >
> > diff --git a/drivers/scsi/scsi-uclass.c b/drivers/scsi/scsi-uclass.c
> > index 1ee8236c05c..c2e34082bce 100644
> > --- a/drivers/scsi/scsi-uclass.c
> > +++ b/drivers/scsi/scsi-uclass.c
> > @@ -10,7 +10,9 @@
> >
> > #define LOG_CATEGORY UCLASS_SCSI
> >
> > +#include <blk.h>
> > #include <dm.h>
> > +#include <part.h>
> > #include <scsi.h>
> >
> > int scsi_exec(struct udevice *dev, struct scsi_cmd *pccb)
> > @@ -23,6 +25,34 @@ int scsi_exec(struct udevice *dev, struct scsi_cmd *pccb)
> > return ops->exec(dev, pccb);
> > }
> >
> > +int scsi_get_blk(const char *partition_name,
> > + struct blk_desc **blk_desc_ptr,
> > + struct disk_partition *part_info_ptr)
> > +{
> > + static int is_scsi_scanned;
> > + struct blk_desc *blk;
> > + int i, ret;
> > +
> > + if (!is_scsi_scanned) {
> > + scsi_scan(false /* no verbose */);
> > + is_scsi_scanned = 1;
> > + }
> > +
> > + for (i = 0; i < blk_find_max_devnum(UCLASS_SCSI) + 1; i++) {
> > + ret = blk_get_desc(UCLASS_SCSI, i, &blk);
> > + if (ret)
> > + continue;
> > +
> > + ret = part_get_info_by_name(blk, partition_name, part_info_ptr);
> > + if (ret > 0) {
> > + *blk_desc_ptr = blk;
> > + return 0;
> > + }
> > + }
> > +
> > + return -1;
> > +}
> > +
> > int scsi_bus_reset(struct udevice *dev)
> > {
> > struct scsi_ops *ops = scsi_get_ops(dev);
> > diff --git a/include/scsi.h b/include/scsi.h
> > index b18ae37b861..1ba55516588 100644
> > --- a/include/scsi.h
> > +++ b/include/scsi.h
> > @@ -9,6 +9,7 @@
> > #include <asm/cache.h>
> > #include <bouncebuf.h>
> > #include <linux/dma-direction.h>
> > +#include <part.h>
> >
> > struct udevice;
> >
> > @@ -349,6 +350,17 @@ int scsi_scan(bool verbose);
> > */
> > int scsi_scan_dev(struct udevice *dev, bool verbose);
> >
> > +/**
> > + * scsi_get_blk() - Provides SCSI partition information.
> > + *
> > + * @partition_name: Partition name for fetching its info
>
> Partition names cannot be expected to be unique.
> UUIDs should be.
Will change to UUID and post a new version.
Thanks
Varada
More information about the U-Boot
mailing list