/* * This file is part of the UCB release of Plan 9. It is subject to the license * terms in the LICENSE file found in the top-level directory of this * distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No * part of the UCB release of Plan 9, including this file, may be copied, * modified, propagated, or distributed except according to the terms contained * in the LICENSE file. */ #include #include int32_t jehanne_readn(int f, void *av, int32_t n) { char *a; int32_t m, t; a = av; t = 0; while(t < n){ m = jehanne_read(f, a+t, n-t); if(m <= 0){ if(t == 0) return m; break; } t += m; } return t; }