diff options
Diffstat (limited to 'scripts/mod/file2alias.c')
| -rw-r--r-- | scripts/mod/file2alias.c | 40 | 
1 files changed, 40 insertions, 0 deletions
diff --git a/scripts/mod/file2alias.c b/scripts/mod/file2alias.c index 220213e603d..9cf2400580a 100644 --- a/scripts/mod/file2alias.c +++ b/scripts/mod/file2alias.c @@ -796,6 +796,38 @@ static int do_platform_entry(const char *filename,  	return 1;  } +static int do_mdio_entry(const char *filename, +			 struct mdio_device_id *id, char *alias) +{ +	int i; + +	alias += sprintf(alias, MDIO_MODULE_PREFIX); + +	for (i = 0; i < 32; i++) { +		if (!((id->phy_id_mask >> (31-i)) & 1)) +			*(alias++) = '?'; +		else if ((id->phy_id >> (31-i)) & 1) +			*(alias++) = '1'; +		else +			*(alias++) = '0'; +	} + +	/* Terminate the string */ +	*alias = 0; + +	return 1; +} + +/* Looks like: zorro:iN. */ +static int do_zorro_entry(const char *filename, struct zorro_device_id *id, +			  char *alias) +{ +	id->id = TO_NATIVE(id->id); +	strcpy(alias, "zorro:"); +	ADD(alias, "i", id->id != ZORRO_WILDCARD, id->id); +	return 1; +} +  /* Ignore any prefix, eg. some architectures prepend _ */  static inline int sym_is(const char *symbol, const char *name)  { @@ -943,6 +975,14 @@ void handle_moddevtable(struct module *mod, struct elf_info *info,  		do_table(symval, sym->st_size,  			 sizeof(struct platform_device_id), "platform",  			 do_platform_entry, mod); +	else if (sym_is(symname, "__mod_mdio_device_table")) +		do_table(symval, sym->st_size, +			 sizeof(struct mdio_device_id), "mdio", +			 do_mdio_entry, mod); +	else if (sym_is(symname, "__mod_zorro_device_table")) +		do_table(symval, sym->st_size, +			 sizeof(struct zorro_device_id), "zorro", +			 do_zorro_entry, mod);  	free(zeros);  }  | 
