Skip to content

Commit

Permalink
block: mark early_lookup_bdev as __init
Browse files Browse the repository at this point in the history
early_lookup_bdev is now only used during the early boot code as it
should, so mark it __init to not waste run time memory on it.

Signed-off-by: Christoph Hellwig <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Jens Axboe <[email protected]>
  • Loading branch information
Christoph Hellwig authored and axboe committed Jun 5, 2023
1 parent 8d03187 commit 2577f53
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 11 deletions.
19 changes: 9 additions & 10 deletions block/early-lookup.c
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// SPDX-License-Identifier: GPL-2.0-only
/*
* Code for looking up block devices in the early boot code before mounting the
* root file system. Unfortunately currently also abused in a few other places.
* root file system.
*/
#include <linux/blkdev.h>
#include <linux/ctype.h>
Expand All @@ -18,7 +18,7 @@ struct uuidcmp {
*
* Returns 1 if the device matches, and 0 otherwise.
*/
static int match_dev_by_uuid(struct device *dev, const void *data)
static int __init match_dev_by_uuid(struct device *dev, const void *data)
{
struct block_device *bdev = dev_to_bdev(dev);
const struct uuidcmp *cmp = data;
Expand All @@ -42,7 +42,7 @@ static int match_dev_by_uuid(struct device *dev, const void *data)
*
* Returns the matching dev_t on success or 0 on failure.
*/
static int devt_from_partuuid(const char *uuid_str, dev_t *devt)
static int __init devt_from_partuuid(const char *uuid_str, dev_t *devt)
{
struct uuidcmp cmp;
struct device *dev = NULL;
Expand Down Expand Up @@ -98,7 +98,7 @@ static int devt_from_partuuid(const char *uuid_str, dev_t *devt)
*
* Returns 1 if the device matches, and 0 otherwise.
*/
static int match_dev_by_label(struct device *dev, const void *data)
static int __init match_dev_by_label(struct device *dev, const void *data)
{
struct block_device *bdev = dev_to_bdev(dev);
const char *label = data;
Expand All @@ -108,7 +108,7 @@ static int match_dev_by_label(struct device *dev, const void *data)
return 1;
}

static int devt_from_partlabel(const char *label, dev_t *devt)
static int __init devt_from_partlabel(const char *label, dev_t *devt)
{
struct device *dev;

Expand All @@ -120,7 +120,7 @@ static int devt_from_partlabel(const char *label, dev_t *devt)
return 0;
}

static dev_t blk_lookup_devt(const char *name, int partno)
static dev_t __init blk_lookup_devt(const char *name, int partno)
{
dev_t devt = MKDEV(0, 0);
struct class_dev_iter iter;
Expand Down Expand Up @@ -149,7 +149,7 @@ static dev_t blk_lookup_devt(const char *name, int partno)
return devt;
}

static int devt_from_devname(const char *name, dev_t *devt)
static int __init devt_from_devname(const char *name, dev_t *devt)
{
int part;
char s[32];
Expand Down Expand Up @@ -193,7 +193,7 @@ static int devt_from_devname(const char *name, dev_t *devt)
return -EINVAL;
}

static int devt_from_devnum(const char *name, dev_t *devt)
static int __init devt_from_devnum(const char *name, dev_t *devt)
{
unsigned maj, min, offset;
char *p, dummy;
Expand Down Expand Up @@ -240,7 +240,7 @@ static int devt_from_devnum(const char *name, dev_t *devt)
* name contains slashes, the device name has them replaced with
* bangs.
*/
int early_lookup_bdev(const char *name, dev_t *devt)
int __init early_lookup_bdev(const char *name, dev_t *devt)
{
if (strncmp(name, "PARTUUID=", 9) == 0)
return devt_from_partuuid(name + 9, devt);
Expand All @@ -250,7 +250,6 @@ int early_lookup_bdev(const char *name, dev_t *devt)
return devt_from_devname(name + 5, devt);
return devt_from_devnum(name, devt);
}
EXPORT_SYMBOL_GPL(early_lookup_bdev);

static char __init *bdevt_str(dev_t devt, char *buf)
{
Expand Down
2 changes: 1 addition & 1 deletion include/linux/blkdev.h
Original file line number Diff line number Diff line change
Expand Up @@ -1500,7 +1500,7 @@ int sync_blockdev_nowait(struct block_device *bdev);
void sync_bdevs(bool wait);
void bdev_statx_dioalign(struct inode *inode, struct kstat *stat);
void printk_all_partitions(void);
int early_lookup_bdev(const char *pathname, dev_t *dev);
int __init early_lookup_bdev(const char *pathname, dev_t *dev);
#else
static inline void invalidate_bdev(struct block_device *bdev)
{
Expand Down

0 comments on commit 2577f53

Please sign in to comment.