mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-24 18:20:59 +00:00 
			
		
		
		
	Perform some minor fixups
This commit is contained in:
		
							parent
							
								
									ca88ce5026
								
							
						
					
					
						commit
						4e93750afd
					
				
					 9 changed files with 24 additions and 50 deletions
				
			
		|  | @ -22,6 +22,6 @@ | ||||||
| /**
 | /**
 | ||||||
|  * Returns absolute value of x. |  * Returns absolute value of x. | ||||||
|  */ |  */ | ||||||
| int(abs)(int x) { | int abs(int x) { | ||||||
|   return ABS(x); |   return ABS(x); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -21,15 +21,14 @@ | ||||||
| #include "libc/nt/files.h" | #include "libc/nt/files.h" | ||||||
| #include "libc/sysv/errfuns.h" | #include "libc/sysv/errfuns.h" | ||||||
| 
 | 
 | ||||||
| textwindows int sys_ftruncate_nt(int fd, uint64_t length) { | textwindows int sys_ftruncate_nt(int64_t handle, uint64_t length) { | ||||||
|   bool32 ok; |   bool32 ok; | ||||||
|   int64_t tell; |   int64_t tell; | ||||||
|   if (!__isfdkind(fd, kFdFile)) return ebadf(); |  | ||||||
|   tell = -1; |   tell = -1; | ||||||
|   if (SetFilePointerEx(g_fds.p[fd].handle, 0, &tell, kNtFileCurrent)) { |   if (SetFilePointerEx(handle, 0, &tell, kNtFileCurrent)) { | ||||||
|     ok = SetFilePointerEx(g_fds.p[fd].handle, length, NULL, kNtFileBegin) && |     ok = SetFilePointerEx(handle, length, NULL, kNtFileBegin) && | ||||||
|          SetEndOfFile(g_fds.p[fd].handle); |          SetEndOfFile(handle); | ||||||
|     SetFilePointerEx(g_fds.p[fd].handle, tell, NULL, kNtFileBegin); |     SetFilePointerEx(handle, tell, NULL, kNtFileBegin); | ||||||
|     return ok ? 0 : __winerr(); |     return ok ? 0 : __winerr(); | ||||||
|   } else { |   } else { | ||||||
|     return __winerr(); |     return __winerr(); | ||||||
|  |  | ||||||
|  | @ -19,6 +19,7 @@ | ||||||
| #include "libc/calls/calls.h" | #include "libc/calls/calls.h" | ||||||
| #include "libc/calls/internal.h" | #include "libc/calls/internal.h" | ||||||
| #include "libc/dce.h" | #include "libc/dce.h" | ||||||
|  | #include "libc/sysv/errfuns.h" | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|  * Changes size of file. |  * Changes size of file. | ||||||
|  | @ -31,9 +32,11 @@ | ||||||
|  * @asyncsignalsafe |  * @asyncsignalsafe | ||||||
|  */ |  */ | ||||||
| int ftruncate(int fd, int64_t length) { | int ftruncate(int fd, int64_t length) { | ||||||
|  |   if (fd < 0) return einval(); | ||||||
|   if (!IsWindows()) { |   if (!IsWindows()) { | ||||||
|     return sys_ftruncate(fd, length, length); |     return sys_ftruncate(fd, length, length); | ||||||
|   } else { |   } else { | ||||||
|     return sys_ftruncate_nt(fd, length); |     if (fd >= g_fds.n) return ebadf(); | ||||||
|  |     return sys_ftruncate_nt(g_fds.p[fd].handle, length); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -243,7 +243,7 @@ int sys_flock_nt(int, int) hidden; | ||||||
| int sys_fork_nt(void) hidden; | int sys_fork_nt(void) hidden; | ||||||
| int sys_fstat_nt(i64, struct stat *) hidden; | int sys_fstat_nt(i64, struct stat *) hidden; | ||||||
| int sys_fstatat_nt(int, const char *, struct stat *, uint32_t) hidden; | int sys_fstatat_nt(int, const char *, struct stat *, uint32_t) hidden; | ||||||
| int sys_ftruncate_nt(int, u64) hidden; | int sys_ftruncate_nt(i64, u64) hidden; | ||||||
| int sys_getppid_nt(void) hidden; | int sys_getppid_nt(void) hidden; | ||||||
| int sys_getpriority_nt(int) hidden; | int sys_getpriority_nt(int) hidden; | ||||||
| int sys_getrusage_nt(int, struct rusage *) hidden; | int sys_getrusage_nt(int, struct rusage *) hidden; | ||||||
|  |  | ||||||
|  | @ -17,7 +17,6 @@ | ||||||
| │ PERFORMANCE OF THIS SOFTWARE.                                                │ | │ PERFORMANCE OF THIS SOFTWARE.                                                │ | ||||||
| ╚─────────────────────────────────────────────────────────────────────────────*/ | ╚─────────────────────────────────────────────────────────────────────────────*/ | ||||||
| #include "libc/bits/bits.h" | #include "libc/bits/bits.h" | ||||||
| #include "libc/bits/safemacros.internal.h" |  | ||||||
| #include "libc/calls/calls.h" | #include "libc/calls/calls.h" | ||||||
| #include "libc/calls/internal.h" | #include "libc/calls/internal.h" | ||||||
| #include "libc/calls/struct/sysinfo.h" | #include "libc/calls/struct/sysinfo.h" | ||||||
|  | @ -41,8 +40,8 @@ int sysinfo(struct sysinfo *info) { | ||||||
|   } else { |   } else { | ||||||
|     rc = sys_sysinfo_nt(info); |     rc = sys_sysinfo_nt(info); | ||||||
|   } |   } | ||||||
|   info->procs = max(1, info->procs); |   info->procs = MAX(1, info->procs); | ||||||
|   info->mem_unit = max(1, info->mem_unit); |   info->mem_unit = MAX(1, info->mem_unit); | ||||||
|   info->totalram = max((8 * 1024 * 1024) / info->mem_unit, info->totalram); |   info->totalram = MAX((8 * 1024 * 1024) / info->mem_unit, info->totalram); | ||||||
|   return rc; |   return rc; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -32,9 +32,5 @@ | ||||||
|  * @asyncsignalsafe |  * @asyncsignalsafe | ||||||
|  */ |  */ | ||||||
| int wait3(int *opt_out_wstatus, int options, struct rusage *opt_out_rusage) { | int wait3(int *opt_out_wstatus, int options, struct rusage *opt_out_rusage) { | ||||||
|   if (!IsWindows()) { |   return wait4(-1, opt_out_wstatus, options, opt_out_rusage); | ||||||
|     return sys_wait4(-1, opt_out_wstatus, options, opt_out_rusage); |  | ||||||
|   } else { |  | ||||||
|     return enosys(); /* TODO(jart) */ |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -54,14 +54,8 @@ textwindows ssize_t sys_write_nt(struct Fd *fd, const struct iovec *iov, | ||||||
|       if (opt_offset != -1) opt_offset += rc; |       if (opt_offset != -1) opt_offset += rc; | ||||||
|       if (rc < iov[i].iov_len) break; |       if (rc < iov[i].iov_len) break; | ||||||
|     } |     } | ||||||
|     if (!total) assert(!__iovec_size(iov, iovlen)); |  | ||||||
|     return total; |     return total; | ||||||
|   } else { |   } else { | ||||||
|     if (WriteFile(fd->handle, NULL, 0, &wrote, |     return sys_write_nt_impl(fd, NULL, 0, opt_offset); | ||||||
|                   offset2overlap(opt_offset, &overlap))) { |  | ||||||
|       return 0; |  | ||||||
|     } else { |  | ||||||
|       return __winerr(); |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										11
									
								
								libc/mach.h
									
										
									
									
									
								
							
							
						
						
									
										11
									
								
								libc/mach.h
									
										
									
									
									
								
							|  | @ -24,7 +24,7 @@ | ||||||
|               █████████████ ████████░░███████░░░██████ ▓██████████ |               █████████████ ████████░░███████░░░██████ ▓██████████ | ||||||
|                █████████████ ██████░░░████████████  █████████████ |                █████████████ ██████░░░████████████  █████████████ | ||||||
| ╔────────────────────────────────────────────────────────────────────────────│─╗ | ╔────────────────────────────────────────────────────────────────────────────│─╗ | ||||||
| │ cosmopolitan § xnu's not unix » carnegie mellon mach microkernel         ─╬─│┼ | │ cosmopolitan § xnu's not unix! » carnegie mellon mach microkernel        ─╬─│┼ | ||||||
| ╚────────────────────────────────────────────────────────────────────────────│*/ | ╚────────────────────────────────────────────────────────────────────────────│*/ | ||||||
| 
 | 
 | ||||||
| #define XNU_SYSCALL_MASK_MACH     0x1000000 | #define XNU_SYSCALL_MASK_MACH     0x1000000 | ||||||
|  | @ -38,7 +38,12 @@ | ||||||
| #define kXnuNtNsBase     0x060 /* uint64_t */ | #define kXnuNtNsBase     0x060 /* uint64_t */ | ||||||
| #define kXnuNtGeneration 0x068 /* uint32_t */ | #define kXnuNtGeneration 0x068 /* uint32_t */ | ||||||
| 
 | 
 | ||||||
| bool swtch(void); | #if !(__ASSEMBLER__ + __LINKER__ + 0) | ||||||
| bool swtch_pri(int pri); | COSMOPOLITAN_C_START_ | ||||||
| 
 | 
 | ||||||
|  | bool swtch(void); | ||||||
|  | bool swtch_pri(int); | ||||||
|  | 
 | ||||||
|  | COSMOPOLITAN_C_END_ | ||||||
|  | #endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */ | ||||||
| #endif /* COSMOPOLITAN_LIBC_MACH_H_ */ | #endif /* COSMOPOLITAN_LIBC_MACH_H_ */ | ||||||
|  |  | ||||||
|  | @ -1,22 +0,0 @@ | ||||||
| /*-*- mode:c;indent-tabs-mode:nil;c-basic-offset:2;tab-width:8;coding:utf-8 -*-│
 |  | ||||||
| │vi: set net ft=c ts=2 sts=2 sw=2 fenc=utf-8                                :vi│ |  | ||||||
| ╞══════════════════════════════════════════════════════════════════════════════╡ |  | ||||||
| │ Copyright 2021 Justine Alexandra Roberts Tunney                              │ |  | ||||||
| │                                                                              │ |  | ||||||
| │ Permission to use, copy, modify, and/or distribute this software for         │ |  | ||||||
| │ any purpose with or without fee is hereby granted, provided that the         │ |  | ||||||
| │ above copyright notice and this permission notice appear in all copies.      │ |  | ||||||
| │                                                                              │ |  | ||||||
| │ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL                │ |  | ||||||
| │ WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED                │ |  | ||||||
| │ WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE             │ |  | ||||||
| │ AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL         │ |  | ||||||
| │ DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR        │ |  | ||||||
| │ PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER               │ |  | ||||||
| │ TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR             │ |  | ||||||
| │ PERFORMANCE OF THIS SOFTWARE.                                                │ |  | ||||||
| ╚─────────────────────────────────────────────────────────────────────────────*/ |  | ||||||
| 
 |  | ||||||
| unsigned hog(unsigned x) { |  | ||||||
|   return (x & 0xf000000) | (x & 0x0fff000) >> 12; |  | ||||||
| } |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue