defs.h 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. /*
  2. * defs.h: initial definitions for PuTTY.
  3. *
  4. * The rule about this header file is that it can't depend on any
  5. * other header file in this code base. This is where we define
  6. * things, as much as we can, that other headers will want to refer
  7. * to, such as opaque structure types and their associated typedefs,
  8. * or macros that are used by other headers.
  9. */
  10. #ifndef PUTTY_DEFS_H
  11. #define PUTTY_DEFS_H
  12. #include <stddef.h>
  13. #include <stdint.h>
  14. #include <stdbool.h>
  15. #if defined _MSC_VER && _MSC_VER < 1800
  16. /* Work around lack of inttypes.h in older MSVC */
  17. #define PRIx32 "x"
  18. #define PRIu64 "I64u"
  19. #define PRIdMAX "I64d"
  20. #define PRIXMAX "I64X"
  21. #define SCNu64 "I64u"
  22. #else
  23. #include <inttypes.h>
  24. #endif
  25. typedef struct conf_tag Conf;
  26. typedef struct terminal_tag Terminal;
  27. typedef struct Filename Filename;
  28. typedef struct FontSpec FontSpec;
  29. typedef struct bufchain_tag bufchain;
  30. typedef struct strbuf strbuf;
  31. typedef struct RSAKey RSAKey;
  32. typedef struct BinarySink BinarySink;
  33. typedef struct BinarySource BinarySource;
  34. typedef struct IdempotentCallback IdempotentCallback;
  35. typedef struct SockAddr SockAddr;
  36. typedef struct Socket Socket;
  37. typedef struct Plug Plug;
  38. typedef struct SocketPeerInfo SocketPeerInfo;
  39. typedef struct Backend Backend;
  40. typedef struct BackendVtable BackendVtable;
  41. typedef struct Ldisc_tag Ldisc;
  42. typedef struct LogContext LogContext;
  43. typedef struct LogPolicy LogPolicy;
  44. typedef struct LogPolicyVtable LogPolicyVtable;
  45. typedef struct Seat Seat;
  46. typedef struct SeatVtable SeatVtable;
  47. typedef struct TermWin TermWin;
  48. typedef struct TermWinVtable TermWinVtable;
  49. typedef struct Ssh Ssh;
  50. typedef struct mp_int mp_int;
  51. typedef struct MontyContext MontyContext;
  52. typedef struct WeierstrassCurve WeierstrassCurve;
  53. typedef struct WeierstrassPoint WeierstrassPoint;
  54. typedef struct MontgomeryCurve MontgomeryCurve;
  55. typedef struct MontgomeryPoint MontgomeryPoint;
  56. typedef struct EdwardsCurve EdwardsCurve;
  57. typedef struct EdwardsPoint EdwardsPoint;
  58. typedef struct SftpServer SftpServer;
  59. typedef struct SftpServerVtable SftpServerVtable;
  60. typedef struct Channel Channel;
  61. typedef struct SshChannel SshChannel;
  62. typedef struct mainchan mainchan;
  63. typedef struct ssh_sharing_state ssh_sharing_state;
  64. typedef struct ssh_sharing_connstate ssh_sharing_connstate;
  65. typedef struct share_channel share_channel;
  66. typedef struct PortFwdManager PortFwdManager;
  67. typedef struct PortFwdRecord PortFwdRecord;
  68. typedef struct ConnectionLayer ConnectionLayer;
  69. typedef struct ssh_hashalg ssh_hashalg;
  70. typedef struct ssh_hash ssh_hash;
  71. typedef struct ssh_kex ssh_kex;
  72. typedef struct ssh_kexes ssh_kexes;
  73. typedef struct ssh_keyalg ssh_keyalg;
  74. typedef struct ssh_key ssh_key;
  75. typedef struct ssh_compressor ssh_compressor;
  76. typedef struct ssh_decompressor ssh_decompressor;
  77. typedef struct ssh_compression_alg ssh_compression_alg;
  78. typedef struct ssh2_userkey ssh2_userkey;
  79. typedef struct ssh2_macalg ssh2_macalg;
  80. typedef struct ssh2_mac ssh2_mac;
  81. typedef struct ssh_cipheralg ssh_cipheralg;
  82. typedef struct ssh_cipher ssh_cipher;
  83. typedef struct ssh2_ciphers ssh2_ciphers;
  84. typedef struct dh_ctx dh_ctx;
  85. typedef struct ecdh_key ecdh_key;
  86. typedef struct dlgparam dlgparam;
  87. typedef struct settings_w settings_w;
  88. typedef struct settings_r settings_r;
  89. typedef struct settings_e settings_e;
  90. typedef struct SessionSpecial SessionSpecial;
  91. /*
  92. * A small structure wrapping up a (pointer, length) pair so that it
  93. * can be conveniently passed to or from a function.
  94. */
  95. typedef struct ptrlen {
  96. const void *ptr;
  97. size_t len;
  98. } ptrlen;
  99. typedef struct logblank_t logblank_t;
  100. typedef struct BinaryPacketProtocol BinaryPacketProtocol;
  101. typedef struct PacketProtocolLayer PacketProtocolLayer;
  102. /* Do a compile-time type-check of 'to_check' (without evaluating it),
  103. * as a side effect of returning the value 'to_return'. Note that
  104. * although this macro double-*expands* to_return, it always
  105. * *evaluates* exactly one copy of it, so it's side-effect safe. */
  106. #define TYPECHECK(to_check, to_return) \
  107. (sizeof(to_check) ? (to_return) : (to_return))
  108. /* Return a pointer to the object of structure type 'type' whose field
  109. * with name 'field' is pointed at by 'object'. */
  110. #define container_of(object, type, field) \
  111. TYPECHECK(object == &((type *)0)->field, \
  112. ((type *)(((char *)(object)) - offsetof(type, field))))
  113. #if defined __GNUC__ || defined __clang__
  114. #define NORETURN __attribute__((__noreturn__))
  115. #else
  116. #define NORETURN
  117. #endif
  118. /* ----------------------------------------------------------------------
  119. * Platform-specific definitions.
  120. *
  121. * Most of these live in the per-platform header files, of which
  122. * puttyps.h selects the appropriate one. But some of the sources
  123. * (particularly standalone test applications) would prefer not to
  124. * have to include a per-platform header at all, because that makes it
  125. * more portable to platforms not supported by the code base as a
  126. * whole (for example, compiling purely computational parts of the
  127. * code for specialist platforms for test and analysis purposes). So
  128. * any definition that has to affect even _those_ modules will have to
  129. * go here, with the key constraint being that this code has to come
  130. * to _some_ decision even if the compilation platform is not a
  131. * recognised one at all.
  132. */
  133. /* Purely computational code uses smemclr(), so we have to make the
  134. * decision here about whether that's provided by utils.c or by a
  135. * platform implementation. We define PLATFORM_HAS_SMEMCLR to suppress
  136. * utils.c's definition. */
  137. #ifdef _WINDOWS
  138. /* Windows provides the API function 'SecureZeroMemory', which we use
  139. * unless the user has told us not to by defining NO_SECUREZEROMEMORY. */
  140. #ifndef NO_SECUREZEROMEMORY
  141. #define PLATFORM_HAS_SMEMCLR
  142. #endif
  143. #endif
  144. #endif /* PUTTY_DEFS_H */