 43ea6a9ce8
			
		
	
	
		43ea6a9ce8
		
	
	
	
	
		
			
			other, user-includable config files. It only defines names that don't pollute the users namespace (start with _). <minix/config.h> still works like always; it includes sys_config.h now and defines the 'messy' names (such as CHIP) as the 'cleaner' names (such as _MINIX_CHIP). Changed some of the other include files to use sys_config.h and the 'cleaner' names. This solves some (past and future) compilation problems.
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
| /*
 | |
| The following macro definitions convert to and from the network standard byte
 | |
| order. The macros with their name in lower case guarantee to evaluate their
 | |
| argument exactly once. The function of the macros is encoded in their names;
 | |
| htons means convert a (unsigned) short in host byte order to network byte order.
 | |
| */
 | |
| 
 | |
| #ifndef _NET__HTON_H
 | |
| #define _NET__HTON_H
 | |
| 
 | |
| #include <minix/sys_config.h>
 | |
| 
 | |
| extern u16_t _tmp;
 | |
| extern u32_t _tmp_l;
 | |
| 
 | |
| /* Find out about the byte order. */
 | |
| 
 | |
| /* assume <minix/config.h> is included, let's check */
 | |
| #if (_MINIX_CHIP == 0)
 | |
| #include "_MINIX_CHIP macro not set, include <minix/config.h>"
 | |
| #endif
 | |
| 
 | |
| #if (_MINIX_CHIP == _CHIP_INTEL)
 | |
| #define LITTLE_ENDIAN	1
 | |
| #endif
 | |
| 
 | |
| #if (_MINIX_CHIP == _CHIP_M68000 || _MINIX_CHIP == _CHIP_SPARC)
 | |
| #define BIG_ENDIAN	1
 | |
| #endif
 | |
| 
 | |
| #if (LITTLE_ENDIAN) && (BIG_ENDIAN)
 | |
| #include "both LITTLE_ENDIAN and BIG_ENDIAN are defined"
 | |
| 			/* LITTLE_ENDIAN and BIG_ENDIAN are both defined */
 | |
| #endif
 | |
| 
 | |
| #if !(LITTLE_ENDIAN) && !(BIG_ENDIAN)
 | |
| #include "neither LITTLE_ENDIAN nor BIG_ENDIAN is defined"
 | |
| 			/* LITTLE_ENDIAN and BIG_ENDIAN are both NOT defined */
 | |
| #endif
 | |
| 
 | |
| #if LITTLE_ENDIAN
 | |
| #define HTONS(x) ( ( (((unsigned short)(x)) >>8) & 0xff) | \
 | |
| 		((((unsigned short)(x)) & 0xff)<<8) )
 | |
| #define NTOHS(x) ( ( (((unsigned short)(x)) >>8) & 0xff) | \
 | |
| 		((((unsigned short)(x)) & 0xff)<<8) )
 | |
| #define HTONL(x) ((((x)>>24) & 0xffL) | (((x)>>8) & 0xff00L) | \
 | |
| 		(((x)<<8) & 0xff0000L) | (((x)<<24) & 0xff000000L))
 | |
| #define NTOHL(x) ((((x)>>24) & 0xffL) | (((x)>>8) & 0xff00L) | \
 | |
| 		(((x)<<8) & 0xff0000L) | (((x)<<24) & 0xff000000L))
 | |
| 
 | |
| #if _WORD_SIZE > 2
 | |
| #define htons(x) (_tmp=(x), ((_tmp>>8) & 0xff) | ((_tmp<<8) & 0xff00))
 | |
| #define ntohs(x) (_tmp=(x), ((_tmp>>8) & 0xff) | ((_tmp<<8) & 0xff00))
 | |
| #define htonl(x) (_tmp_l=(x), ((_tmp_l>>24) & 0xffL) | \
 | |
| 		((_tmp_l>>8) & 0xff00L) | \
 | |
| 		((_tmp_l<<8) & 0xff0000L) | ((_tmp_l<<24) & 0xff000000L))
 | |
| #define ntohl(x) (_tmp_l=(x), ((_tmp_l>>24) & 0xffL) \
 | |
| 		| ((_tmp_l>>8) & 0xff00L) | \
 | |
| 		((_tmp_l<<8) & 0xff0000L) | ((_tmp_l<<24) & 0xff000000L))
 | |
| 
 | |
| #else /* _WORD_SIZE == 2 */
 | |
| /* The above macros are too unwieldy for a 16-bit machine. */
 | |
| u16_t htons(u16_t x);
 | |
| u16_t ntohs(u16_t x);
 | |
| u32_t htonl(u32_t x);
 | |
| u32_t ntohl(u32_t x);
 | |
| #endif /* _WORD_SIZE == 2 */
 | |
| 
 | |
| #endif /* LITTLE_ENDIAN */
 | |
| 
 | |
| #if BIG_ENDIAN
 | |
| #define htons(x) (x)
 | |
| #define HTONS(x) (x)
 | |
| #define ntohs(x) (x)
 | |
| #define NTOHS(x) (x)
 | |
| #define htonl(x) (x)
 | |
| #define HTONL(x) (x)
 | |
| #define ntohl(x) (x)
 | |
| #define NTOHL(x) (x)
 | |
| #endif /* BIG_ENDIAN */
 | |
| 
 | |
| #endif /* _NET__HTON_H */
 |