*/
void stmmac_ptp_register(struct stmmac_priv *priv)
{
+ unsigned int pps_out_num = priv->dma_cap.pps_out_num;
int i;
- for (i = 0; i < priv->dma_cap.pps_out_num; i++) {
- if (i >= STMMAC_PPS_MAX)
- break;
- priv->pps[i].available = true;
+ if (pps_out_num > STMMAC_PPS_MAX) {
+ dev_warn(priv->device,
+ "pps outputs (%u) exceeds driver maximum, limiting to %u\n",
+ pps_out_num, STMMAC_PPS_MAX);
+ pps_out_num = STMMAC_PPS_MAX;
}
+ for (i = 0; i < pps_out_num; i++)
+ priv->pps[i].available = true;
+
/* Calculate the clock domain crossing (CDC) error if necessary */
priv->plat->cdc_error_adj = 0;
if (priv->plat->core_type == DWMAC_CORE_GMAC4)
/* Update the ptp clock parameters based on feature discovery, when
* available
*/
- if (priv->dma_cap.pps_out_num)
- priv->ptp_clock_ops.n_per_out = priv->dma_cap.pps_out_num;
+ if (pps_out_num)
+ priv->ptp_clock_ops.n_per_out = pps_out_num;
if (priv->dma_cap.aux_snapshot_n)
priv->ptp_clock_ops.n_ext_ts = priv->dma_cap.aux_snapshot_n;