[U-Boot] [PATCH 5/7] OMAP3: Add serial number based on die ID
Jean-Christophe PLAGNIOL-VILLARD
plagnioj at jcrosoft.com
Wed Feb 11 23:24:36 CET 2009
On 20:14 Thu 05 Feb , Dirk Behme wrote:
> Dear Jean-Christophe,
>
> Jean-Christophe PLAGNIOL-VILLARD wrote:
>> On 06:53 Mon 02 Feb , Dirk Behme wrote:
>>> Add serial number based on OMAP3 die ID.
>>>
>>> Signed-off-by: Dirk Behme <dirk.behme at googlemail.com>
>>>
>>> ---
>>> board/omap3/beagle/beagle.c | 2 ++
>>> board/omap3/evm/evm.c | 2 ++
>>> board/omap3/overo/overo.c | 2 ++
>>> board/omap3/pandora/pandora.c | 2 ++
>>> board/omap3/zoom1/zoom1.c | 1 +
>>> cpu/arm_cortexa8/omap3/sys_info.c | 27 +++++++++++++++++++++++++++
>>> include/asm-arm/arch-omap3/cpu.h | 13 +++++++++++++
>>> include/asm-arm/arch-omap3/omap3.h | 1 +
>>> include/asm-arm/arch-omap3/sys_proto.h | 1 +
>>> 9 files changed, 51 insertions(+)
>>>
>>> Index: u-boot-main/cpu/arm_cortexa8/omap3/sys_info.c
>>> ===================================================================
>>> --- u-boot-main.orig/cpu/arm_cortexa8/omap3/sys_info.c
>>> +++ u-boot-main/cpu/arm_cortexa8/omap3/sys_info.c
>>> @@ -36,6 +36,33 @@ static gpmc_csx_t *gpmc_cs_base = (gpmc_
>>> static sdrc_t *sdrc_base = (sdrc_t *)OMAP34XX_SDRC_BASE;
>>> static ctrl_t *ctrl_base = (ctrl_t *)OMAP34XX_CTRL_BASE;
>>> +/*****************************************************************
>>> + * serial_num_r(void) - read and set serial number based on DIE ID
>>> + *****************************************************************/
>>> +void serial_num_r(void)
>>> +{
>>> + ctrl_id_t *id_base = (ctrl_id_t *)OMAP34XX_ID_L4_IO_BASE;
>>> + char *uid_s, die_id[34];
>>> + u32 id[4];
>>> +
>>> + memset(die_id, 0, sizeof(die_id));
>>> +
>>> + uid_s = getenv("serial");
>> why not call a cat a cat?
>
> Why not give the cat a fitting name?
>
> The user gets a serial number, so we name it serial. How and where we
> get it from is hidden from user. It wouldn't help to name it "die ID"
> for user, nobody would know what this is. But serial number is clear to
> every body.
serial number is board specific not CPU specific
when you product board and need to track then, you need to have a serial number that
can not change even if you when the cpu.
>
>> IMHO why don't you report the die id?
>>> +
>>> + if (uid_s == NULL) {
>>> + id[3] = readl(&id_base->die_id_0);
>>> + id[2] = readl(&id_base->die_id_1);
>>> + id[1] = readl(&id_base->die_id_2);
>>> + id[0] = readl(&id_base->die_id_3);
>>> + sprintf(die_id, "%08x%08x%08x%08x", id[0], id[1], id[2], id[3]);
>>> + setenv("serial", die_id);
>>> + } else {
>>> + strncpy(die_id, uid_s, 34);
>> why copy it? why not simply print it
why do copy from a memory to an other instead of just update the pointer?
Best Regards,
J.
More information about the U-Boot
mailing list