- return NSS_STATUS_TRYAGAIN;
- }
-
- if (fct_start == NULL &&
- __nss_group_lookup(&startp, fct_name, &fct_start) != 0) {
- free(*buffer);
- *buffer = NULL;
- return NSS_STATUS_UNAVAIL;
- }
- nip = startp;
- fct.ptr = fct_start;
- do {
- morebuf:
- if (fct.l == _nss_nonlocal_getgrnam_r)
- status = NSS_STATUS_NOTFOUND;
- else
- status = DL_CALL_FCT(fct.l, (name, grp, *buffer, buflen, errnop));
- if (status == NSS_STATUS_TRYAGAIN && *errnop == ERANGE) {
- free(*buffer);
- buflen *= 2;
- *buffer = malloc(buflen);
- if (*buffer == NULL) {
- *errnop = ENOMEM;
- errno = old_errno;
- return NSS_STATUS_TRYAGAIN;
- }
- goto morebuf;
- }
- } while (__nss_next(&nip, fct_name, &fct.ptr, status, 0) == 0);
+ status = check_nonlocal_gid(user, gid, errnop);
+ } else
+ errno = old_errno;
+ if (status != NSS_STATUS_SUCCESS)
+ return status;