Skip to content

Commit

Permalink
pps: using ERR_PTR instead of NULL while pps_register_source fails
Browse files Browse the repository at this point in the history
pps_register_source() has keeps error codes in a local variable,
but it does not make use of the code. This patch let it return
the errcode in case of failure.

Suggested-by: Richard Cochran <[email protected]>
Signed-off-by: YueHaibing <[email protected]>
Acked-by: Rodolfo Giometti <[email protected]>
Signed-off-by: Greg Kroah-Hartman <[email protected]>
  • Loading branch information
YueHaibing authored and gregkh committed Nov 27, 2018
1 parent eb30abe commit 3b1ad36
Show file tree
Hide file tree
Showing 5 changed files with 10 additions and 9 deletions.
4 changes: 2 additions & 2 deletions drivers/pps/clients/pps-gpio.c
Original file line number Diff line number Diff line change
Expand Up @@ -158,10 +158,10 @@ static int pps_gpio_probe(struct platform_device *pdev)
if (data->capture_clear)
pps_default_params |= PPS_CAPTURECLEAR | PPS_OFFSETCLEAR;
data->pps = pps_register_source(&data->info, pps_default_params);
if (data->pps == NULL) {
if (IS_ERR(data->pps)) {
dev_err(&pdev->dev, "failed to register IRQ %d as PPS source\n",
data->irq);
return -EINVAL;
return PTR_ERR(data->pps);
}

/* register IRQ interrupt handler */
Expand Down
4 changes: 2 additions & 2 deletions drivers/pps/clients/pps-ktimer.c
Original file line number Diff line number Diff line change
Expand Up @@ -80,9 +80,9 @@ static int __init pps_ktimer_init(void)
{
pps = pps_register_source(&pps_ktimer_info,
PPS_CAPTUREASSERT | PPS_OFFSETASSERT);
if (pps == NULL) {
if (IS_ERR(pps)) {
pr_err("cannot register PPS source\n");
return -ENOMEM;
return PTR_ERR(pps);
}

timer_setup(&ktimer, pps_ktimer_event, 0);
Expand Down
4 changes: 2 additions & 2 deletions drivers/pps/clients/pps-ldisc.c
Original file line number Diff line number Diff line change
Expand Up @@ -72,9 +72,9 @@ static int pps_tty_open(struct tty_struct *tty)

pps = pps_register_source(&info, PPS_CAPTUREBOTH | \
PPS_OFFSETASSERT | PPS_OFFSETCLEAR);
if (pps == NULL) {
if (IS_ERR(pps)) {
pr_err("cannot register PPS source \"%s\"\n", info.path);
return -ENOMEM;
return PTR_ERR(pps);
}
pps->lookup_cookie = tty;

Expand Down
2 changes: 1 addition & 1 deletion drivers/pps/clients/pps_parport.c
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,7 @@ static void parport_attach(struct parport *port)

device->pps = pps_register_source(&info,
PPS_CAPTUREBOTH | PPS_OFFSETASSERT | PPS_OFFSETCLEAR);
if (device->pps == NULL) {
if (IS_ERR(device->pps)) {
pr_err("couldn't register PPS source\n");
goto err_release_dev;
}
Expand Down
5 changes: 3 additions & 2 deletions drivers/pps/kapi.c
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,8 @@ static void pps_echo_client_default(struct pps_device *pps, int event,
* source is described by info's fields and it will have, as default PPS
* parameters, the ones specified into default_params.
*
* The function returns, in case of success, the PPS device. Otherwise NULL.
* The function returns, in case of success, the PPS device. Otherwise
* ERR_PTR(errno).
*/

struct pps_device *pps_register_source(struct pps_source_info *info,
Expand Down Expand Up @@ -135,7 +136,7 @@ struct pps_device *pps_register_source(struct pps_source_info *info,
pps_register_source_exit:
pr_err("%s: unable to register source\n", info->name);

return NULL;
return ERR_PTR(err);
}
EXPORT_SYMBOL(pps_register_source);

Expand Down

0 comments on commit 3b1ad36

Please sign in to comment.