if (IS_ERR(adapter->ptp_clock)) {
                adapter->ptp_clock = NULL;
                e_err("ptp_clock_register failed\n");
-       } else {
+       } else if (adapter->ptp_clock) {
                e_info("registered PHC clock\n");
        }
 }
 
                pf->ptp_clock = NULL;
                dev_err(&pf->pdev->dev, "%s: ptp_clock_register failed\n",
                        __func__);
-       } else {
+       } else if (pf->ptp_clock) {
                struct timespec64 ts;
                u32 regval;
 
 
        if (IS_ERR(adapter->ptp_clock)) {
                adapter->ptp_clock = NULL;
                dev_err(&adapter->pdev->dev, "ptp_clock_register failed\n");
-       } else {
+       } else if (adapter->ptp_clock) {
                dev_info(&adapter->pdev->dev, "added PHC on %s\n",
                         adapter->netdev->name);
                adapter->ptp_flags |= IGB_PTP_ENABLED;
 
                adapter->ptp_clock = NULL;
                e_dev_err("ptp_clock_register failed\n");
                return err;
-       } else
+       } else if (adapter->ptp_clock)
                e_dev_info("registered PHC device on %s\n", netdev->name);
 
        /* set default timestamp mode to disabled here. We do this in
 
        if (IS_ERR(mdev->ptp_clock)) {
                mdev->ptp_clock = NULL;
                mlx4_err(mdev, "ptp_clock_register failed\n");
-       } else {
+       } else if (mdev->ptp_clock) {
                mlx4_info(mdev, "registered PHC clock\n");
        }
 
 
 
        tstamp->ptp = ptp_clock_register(&tstamp->ptp_info,
                                         &priv->mdev->pdev->dev);
-       if (IS_ERR_OR_NULL(tstamp->ptp)) {
+       if (IS_ERR(tstamp->ptp)) {
                mlx5_core_warn(priv->mdev, "ptp_clock_register failed %ld\n",
                               PTR_ERR(tstamp->ptp));
                tstamp->ptp = NULL;
 
                if (IS_ERR(ptp->phc_clock)) {
                        rc = PTR_ERR(ptp->phc_clock);
                        goto fail3;
-               }
-
-               INIT_WORK(&ptp->pps_work, efx_ptp_pps_worker);
-               ptp->pps_workwq = create_singlethread_workqueue("sfc_pps");
-               if (!ptp->pps_workwq) {
-                       rc = -ENOMEM;
-                       goto fail4;
+               } else if (ptp->phc_clock) {
+                       INIT_WORK(&ptp->pps_work, efx_ptp_pps_worker);
+                       ptp->pps_workwq = create_singlethread_workqueue("sfc_pps");
+                       if (!ptp->pps_workwq) {
+                               rc = -ENOMEM;
+                               goto fail4;
+                       }
                }
        }
        ptp->nic_ts_enabled = false;
 
        if (IS_ERR(priv->ptp_clock)) {
                priv->ptp_clock = NULL;
                pr_err("ptp_clock_register() failed on %s\n", priv->dev->name);
-       } else
+       } else if (priv->ptp_clock)
                pr_debug("Added PTP HW clock successfully on %s\n",
                         priv->dev->name);
 
 
  *
  * @info:   Structure describing the new clock.
  * @parent: Pointer to the parent device of the new clock.
+ *
+ * Returns a valid pointer on success or PTR_ERR on failure.  If PHC
+ * support is missing at the configuration level, this function
+ * returns NULL, and drivers are expected to gracefully handle that
+ * case separately.
  */
 
 extern struct ptp_clock *ptp_clock_register(struct ptp_clock_info *info,