* If @pfd_ino is not destined to be set, pass it as NULL.
*
* Return: On success, 0 is returned.
- * On failure, a negative errno number will be returned.
+ * On failure, -1 is returned and errno is set to indicate the issue.
*/
int ul_parse_pid_str(char *pidstr, pid_t *pid_num, uint64_t *pfd_ino)
{
char *end = NULL;
int64_t num = 0;
- if (!pidstr || !*pidstr || !pid_num)
- return -EINVAL;
+ if (!pidstr || !*pidstr || !pid_num) {
+ errno = EINVAL;
+ return -1;
+ }
num = strtoimax(pidstr, &end, 10);
- if (errno == 0 && ((num && num < 1) || (num && num > SINT_MAX(pid_t))))
- return -ERANGE;
+ if (num == 0 && end == pidstr) {
+ errno = EINVAL;
+ return -1;
+ }
+
+ if (errno == ERANGE || (num <= 0 || num > SINT_MAX(pid_t))) {
+ errno = ERANGE;
+ return -1;
+ }
+
*pid_num = (pid_t) num;
if (*end == ':' && pfd_ino) {
rc = ul_strtou64(++end, pfd_ino, 10);
- if (rc != 0)
- return -ERANGE;
+ if (rc != 0 || *pfd_ino == 0) {
+ errno = EINVAL;
+ return -1;
+ }
*end = '\0';
}
- if (errno != 0 || ((end && *end != '\0') || pidstr >= end))
- return -EINVAL;
+
+ if (end && *end != '\0') {
+ errno = EINVAL;
+ return -1;
+ }
return 0;
}