Re: [PATCH v4] mmc : general purpose partition support.
From: NamJae Jeon
Date: Fri Sep 30 2011 - 19:27:36 EST
2011/10/1 Andrei E. Warkentin <andrey.warkentin@xxxxxxxxx>:
> Hi Namjae,
>
> Why don't you update card->nr_parts inside mmc_part_add? You're making
> this too complicated. There
> is also no need for the part_cfg array.
>
> 2011/9/30 Namjae Jeon <linkinjeon@xxxxxxxxx>:
>> It allows gerneral purpose partitions in MMC Device.
>> And I try to simpliy make mmc_blk_alloc_parts using mmc_part structure suggested by Andrei Warkentin.
>> After patching, we can see general purpose partitions like this.
>>> cat /proc/partitions
>> Â Â Â Â Â179 0 847872 mmcblk0
>> Â Â Â Â Â179 192 4096 mmcblk0gp3
>> Â Â Â Â Â179 160 4096 mmcblk0gp2
>> Â Â Â Â Â179 128 4096 mmcblk0gp1
>> Â Â Â Â Â179 96 Â1052672 mmcblk0gp0
>> Â Â Â Â Â179 64 Â1024 mmcblk0boot1
>> Â Â Â Â Â179 32 Â1024 mmcblk0boot0
>>
>> Signed-off-by: Namjae Jeon <linkinjeon@xxxxxxxxx>
>> ---
>
>>
>> +/* partition configuration array */
>> +static const unsigned int part_cfg[] = {
>> + Â Â Â 0x1, Â Â0x2, Â Â0x4, Â Â0x5, Â Â0x6, Â Â7,
>> +};
>> +
>
> No need. Plus this is obscure.
>
>> - Â Â Â Â Â Â Â card->ext_csd.boot_size = ext_csd[EXT_CSD_BOOT_MULT] << 17;
>> + Â Â Â Â Â Â Â if (ext_csd[EXT_CSD_BOOT_MULT]) {
>> + Â Â Â Â Â Â Â Â Â Â Â card->nr_parts = MMC_NUM_BOOT_PARTITION;
>> + Â Â Â Â Â Â Â Â Â Â Â for (idx = 0, part_num = 0;
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â idx < MMC_NUM_BOOT_PARTITION; idx++,
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â part_num++) {
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â part_size = ext_csd[EXT_CSD_BOOT_MULT] << 17;
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â mmc_part_add(card, part_size, part_cfg[idx],
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â "boot%d", idx, part_num, true);
>> + Â Â Â Â Â Â Â Â Â Â Â }
>> + Â Â Â Â Â Â Â }
>> Â Â Â Â}
>
> There is no need for part_num (you have idx for that). And there is no
> need for passing the actual array
> index either - that's why you have mmc_part_add: it will do
> card->parts[card->nr_parts++] = new_part.
>
> Â Â Â Â Â Â Â if (ext_csd[EXT_CSD_BOOT_MULT]) {
> Â Â Â Â Â Â Â Â Â Â Â for (idx = 0, part_num = 0;
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â idx < MMC_NUM_BOOT_PARTITION; idx++) {
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â part_size = ext_csd[EXT_CSD_BOOT_MULT] << 17;
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â mmc_part_add(card, part_size,
> EXT_CSD_PART_CONFIG_ACC_BOOT0 + idx,
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â "boot%d", idx, true);
> Â Â Â Â Â Â Â Â Â Â Â }
> Â Â Â Â Â Â Â }
>
>
>> + Â Â Â Â Â Â Â if (ext_csd[EXT_CSD_PARTITION_SUPPORT] & 0x1) {
>> + Â Â Â Â Â Â Â Â Â Â Â u8 hc_erase_grp_sz =
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â ext_csd[EXT_CSD_HC_ERASE_GRP_SIZE];
>> + Â Â Â Â Â Â Â Â Â Â Â u8 hc_wp_grp_sz =
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â ext_csd[EXT_CSD_HC_WP_GRP_SIZE];
>> +
>> + Â Â Â Â Â Â Â Â Â Â Â card->ext_csd.enhanced_area_en = 1;
>> +
>> + Â Â Â Â Â Â Â Â Â Â Â card->nr_parts += MMC_NUM_GP_PARTITION;
>> + Â Â Â Â Â Â Â Â Â Â Â for (part_num = 0, gp_size_mult = 143;
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â idx < card->nr_parts;
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â idx++, part_num++, gp_size_mult += 3) {
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â if (!ext_csd[gp_size_mult] &&
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â !ext_csd[gp_size_mult + 1] &&
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â !ext_csd[gp_size_mult + 2])
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â continue;
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â part_size = (ext_csd[gp_size_mult + 2] << 16) +
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â (ext_csd[gp_size_mult + 1] << 8) +
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â ext_csd[gp_size_mult];
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â part_size *= (size_t)(hc_erase_grp_sz *
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â hc_wp_grp_sz);
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â part_size <<= 19;
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â mmc_part_add(card, part_size, part_cfg[idx],
>> + Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â "gp%d", idx, part_num, false);
>> + Â Â Â Â Â Â Â Â Â Â Â }
>> + Â Â Â Â Â Â Â }
>
> Same story: get rid of part_num, don't touch card->nr_parts, and get
> rid of part_cfg array access.
>
> Â Â Â Â Â Â Â Â Â Â Â card->ext_csd.enhanced_area_en = 1;
> Â Â Â Â Â Â Â Â Â Â Â for (idx = 0, gp_size_mult = 143;
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â idx < MMC_NUM_GP_PARTITION;
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â idx++, gp_size_mult += 3) {
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â if (!ext_csd[gp_size_mult] &&
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â !ext_csd[gp_size_mult + 1] &&
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â !ext_csd[gp_size_mult + 2])
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â continue;
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â part_size = (ext_csd[gp_size_mult + 2] << 16) +
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â (ext_csd[gp_size_mult + 1] << 8) +
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â ext_csd[gp_size_mult];
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â part_size *= (size_t)(hc_erase_grp_sz *
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â hc_wp_grp_sz);
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â part_size <<= 19;
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â mmc_part_add(card, part_size, idx +
> EXT_CSD_PART_CONFIG_ACC_GP0,
> Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â "gp%d", idx, false);
> Â Â Â Â Â Â Â Â Â Â Â }
> Â Â Â Â Â Â Â }
>
>
>> Â/*
>> + * This function fill contents in mmc_part.
>> + */
>> +static inline void mmc_part_add(struct mmc_card *card, unsigned int size,
>> + Â Â Â unsigned int part_cfg, char *name, int idx, int part_num, bool ro)
>> +{
>> + Â Â Â card->part[idx].size = size;
>> + Â Â Â card->part[idx].cookie = part_cfg;
>> + Â Â Â sprintf(card->part[idx].name, name, part_num);
>> + Â Â Â card->part[idx].force_ro = ro;
>> +}
>
> static inline void mmc_part_add(struct mmc_card *card, unsigned int size,
> Â Â Â unsigned int part_cfg, char *name, int idx, bool ro)
> {
> Â Â Â card->part[card->nr_parts].size = size;
> Â Â Â card->part[card->nr_parts].cookie = part_cfg;
> Â Â Â sprintf(card->part[card->nr_parts].name, name, idx);
> Â Â Â card->part[card->nr_parts].force_ro = ro;
> Â Â Â card->nr_parts++;
> }
>
>> Â#define EXT_CSD_PART_CONFIG_ACC_MASK Â (0x7)
>> -#define EXT_CSD_PART_CONFIG_ACC_BOOT0 Â(0x1)
>> -#define EXT_CSD_PART_CONFIG_ACC_BOOT1 Â(0x2)
>>
>
> I'd also keep the MMC_NUM_BOOT_PARTITION and MMC_NUM_GP_PARTITION defs
> at the same location.
Why should this def move to mmc.h ?
this area where there are ext csd fields.
>
> /* The number of MMC physical partitions
> Â* It consist of boot partitions(2), general purpose partitions(4) in MMC v4.4
> Â*/
> #define MMC_NUM_BOOT_PARTITION 2
> #define MMC_NUM_GP_PARTITION Â 4
>
> #define EXT_CSD_PART_CONFIG_ACC_BOOT0 Â(0x1)
> #define EXT_CSD_PART_CONFIG_ACC_GP0 Â Â Â (0x4)
>
> A
>
¢éì®&Þ~º&¶¬+-±éÝ¥w®Ë±Êâmébìdz¹Þ)í
æèw*jg¬±¨¶Ýj/êäz¹Þà2Þ¨èÚ&¢)ß«a¶Úþø®G«éh®æj:+v¨wèÙ>W±êÞiÛaxPjØm¶ÿÃ-»+ùd_