breaking thread because it grew too big.

On Fri, May 04, 2012 at 07:48:42AM -0300, Mauro Carvalho Chehab wrote:

[ … ]

> +     memset(&pos, 0, sizeof(pos));
> +     row = 0;
> +     chn = 0;
> +     debugf4("%s: initializing %d %s\n", __func__, tot_dimms,
> +             per_rank ? "ranks" : "dimms");
> +     for (i = 0; i < tot_dimms; i++) {
> +             chan = &csi[row].channels[chn];
> +             dimm = EDAC_DIMM_PTR(layer, mci->dimms, n_layers,
> +                            pos[0], pos[1], pos[2]);
> +             dimm->mci = mci;
> +
> +             debugf2("%s: %d: %s%zd (%d:%d:%d): row %d, chan %d\n", __func__,
> +                     i, per_rank ? "rank" : "dimm", (dimm - mci->dimms),
> +                     pos[0], pos[1], pos[2], row, chn);
> +
> +             /* Copy DIMM location */
> +             for (j = 0; j < n_layers; j++)
> +                     dimm->location[j] = pos[j];
> +
> +             /* Link it to the csrows old API data */
> +             chan->dimm = dimm;
> +             dimm->csrow = row;
> +             dimm->cschannel = chn;
> +
> +             /* Increment csrow location */
> +             for (j = n_layers - 1; j >= 0; j--)
> +                     if (layers[j].is_virt_csrow)
> +                             break;

This looks fishy: the for-loop above iterates over layers[j] to break on
the first ->is_virt_csrow.

> +             row++;

And row here gets incremented unconditionally, independent from the loop
above. And you're not using any results from the loop: j gets reset
below in the next loop.

What's going on?

> +             if (row == tot_csrows) {
> +                     row = 0;
> +                     chn++;
> +             }
> +
> +             /* Increment dimm location */
> +             for (j = n_layers - 1; j >= 0; j--) {
> +                     pos[j]++;
> +                     if (pos[j] < layers[j].size)
> +                             break;
> +                     pos[j] = 0;
>               }
>       }
>  
> @@ -263,6 +373,46 @@ struct mem_ctl_info *edac_mc_alloc(unsigned sz_pvt, 
> unsigned nr_csrows,
>        */
>       return mci;
>  }
> +EXPORT_SYMBOL_GPL(new_edac_mc_alloc);
> +
> +/**
> + * edac_mc_alloc: Allocate and partially fill a struct mem_ctl_info structure
> + * @mc_num:          Memory controller number
> + * @n_layers:                Number of layers at the MC hierarchy
> + * layers:           Describes each layer as seen by the Memory Controller
> + * @size_pvt:                Size of private storage needed
> + *
> + *
> + * FIXME: drivers handle multi-rank memories in different ways: some
> + * drivers map multi-ranked DIMMs as one DIMM while others
> + * as several DIMMs.
> + *
> + * Everything is kmalloc'ed as one big chunk - more efficient.
> + * It can only be used if all structures have the same lifetime - otherwise
> + * you have to allocate and initialize your own structures.
> + *
> + * Use edac_mc_free() to free mc structures allocated by this function.
> + *
> + * Returns:
> + *   On failure: NULL
> + *   On success: struct mem_ctl_info pointer
> + */
> +

[ … ]

> +void edac_mc_handle_error(const enum hw_event_mc_err_type type,
> +                       struct mem_ctl_info *mci,
> +                       const unsigned long page_frame_number,
> +                       const unsigned long offset_in_page,
> +                       const unsigned long syndrome,
> +                       const int layer0,
> +                       const int layer1,
> +                       const int layer2,
> +                       const char *msg,
> +                       const char *other_detail,
> +                       const void *mcelog)
>  {
> -     int len = EDAC_MC_LABEL_LEN * 4;
> -     char labels[len + 1];
> -     char *pos = labels;
> -     int chan;
> -     int chars;
> -     char *label = NULL;
> +     /* FIXME: too much for stack: move it to some pre-alocated area */

I'm assuming all those new FIXMEs are going to be addressed soonish :)

Rest looks ok,
thanks.

-- 
Regards/Gruss,
Boris.

Advanced Micro Devices GmbH
Einsteinring 24, 85609 Dornach
GM: Alberto Bozzo
Reg: Dornach, Landkreis Muenchen
HRB Nr. 43632 WEEE Registernr: 129 19551
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to