mirror of
git://anongit.mindrot.org/openssh.git
synced 2024-11-26 03:54:12 +08:00
2f959b4cd1
- (bal) OpenBSD Sync - markus@cvs.openbsd.org 2001/01/10 22:56:22 [bufaux.h bufaux.c sftp-server.c sftp.h getput.h] cleanup sftp-server implementation: add buffer_get_int64, buffer_put_int64, GET_64BIT, PUT_64BIT parse SSH2_FILEXFER_ATTR_EXTENDED send SSH2_FX_EOF if readdir returns no more entries reply to SSH2_FXP_EXTENDED message use #defines from the draft move #definations to sftp.h more info: http://www.ietf.org/internet-drafts/draft-ietf-secsh-filexfer-00.txt - markus@cvs.openbsd.org 2001/01/10 19:43:20 [sshd.c] XXX - generate_empheral_server_key() is not safe against races, because it calls log() - markus@cvs.openbsd.org 2001/01/09 21:19:50 [packet.c] allow TCP_NDELAY for ipv6; from netbsd via itojun@
59 lines
1.9 KiB
C
59 lines
1.9 KiB
C
/*
|
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
|
* All rights reserved
|
|
* Macros for storing and retrieving data in msb first and lsb first order.
|
|
*
|
|
* As far as I am concerned, the code I have written for this software
|
|
* can be used freely for any purpose. Any derived versions of this
|
|
* software must be clearly marked as such, and if the derived work is
|
|
* incompatible with the protocol description in the RFC file, it must be
|
|
* called by a name other than "ssh" or "Secure Shell".
|
|
*/
|
|
|
|
/* RCSID("$OpenBSD: getput.h,v 1.7 2001/01/10 22:56:22 markus Exp $"); */
|
|
|
|
#ifndef GETPUT_H
|
|
#define GETPUT_H
|
|
|
|
/*------------ macros for storing/extracting msb first words -------------*/
|
|
|
|
#define GET_64BIT(cp) (((u_int64_t)(u_char)(cp)[0] << 56) | \
|
|
((u_int64_t)(u_char)(cp)[1] << 48) | \
|
|
((u_int64_t)(u_char)(cp)[2] << 40) | \
|
|
((u_int64_t)(u_char)(cp)[3] << 32) | \
|
|
((u_int64_t)(u_char)(cp)[4] << 24) | \
|
|
((u_int64_t)(u_char)(cp)[5] << 16) | \
|
|
((u_int64_t)(u_char)(cp)[6] << 8) | \
|
|
((u_int64_t)(u_char)(cp)[7]))
|
|
|
|
#define GET_32BIT(cp) (((u_long)(u_char)(cp)[0] << 24) | \
|
|
((u_long)(u_char)(cp)[1] << 16) | \
|
|
((u_long)(u_char)(cp)[2] << 8) | \
|
|
((u_long)(u_char)(cp)[3]))
|
|
|
|
#define GET_16BIT(cp) (((u_long)(u_char)(cp)[0] << 8) | \
|
|
((u_long)(u_char)(cp)[1]))
|
|
|
|
#define PUT_64BIT(cp, value) do { \
|
|
(cp)[0] = (value) >> 56; \
|
|
(cp)[1] = (value) >> 48; \
|
|
(cp)[2] = (value) >> 40; \
|
|
(cp)[3] = (value) >> 32; \
|
|
(cp)[4] = (value) >> 24; \
|
|
(cp)[5] = (value) >> 16; \
|
|
(cp)[6] = (value) >> 8; \
|
|
(cp)[7] = (value); } while (0)
|
|
|
|
#define PUT_32BIT(cp, value) do { \
|
|
(cp)[0] = (value) >> 24; \
|
|
(cp)[1] = (value) >> 16; \
|
|
(cp)[2] = (value) >> 8; \
|
|
(cp)[3] = (value); } while (0)
|
|
|
|
#define PUT_16BIT(cp, value) do { \
|
|
(cp)[0] = (value) >> 8; \
|
|
(cp)[1] = (value); } while (0)
|
|
|
|
#endif /* GETPUT_H */
|