📄 smi.h
字号:
/*=================================================================== Copyright (c) 1999 Hewlett-Packard Company ATTENTION: USE OF THIS SOFTWARE IS SUBJECT TO THE FOLLOWING TERMS. Permission to use, copy, modify, distribute and/or sell this software and/or its documentation is hereby granted without fee. User agrees to display the above copyright notice and this license notice in all copies of the software and any documentation of the software. User agrees to assume all liability for the use of the software; Hewlett-Packard makes no representations about the suitability of this software for any purpose. It is provided "AS-IS without warranty of any kind,either express or implied. User hereby grants a royalty-free license to any and all derivatives based upon this software code base. SNMP++ S M I . H SMI DEFINITIONS VERSION: 2.8 RCS INFO: $Header: smi.h,v 1.18 96/08/16 11:04:29 hmgr Exp $ AUTHOR: Peter E Mellquist LANGUAGE: ANSI C++ OPERATING SYSTEMS: MS-Windows Win32 BSD UNIX DESCRIPTION: Address class definition. Encapsulates various network addresses into easy to use, safe and portable classes. =====================================================================*/#ifndef _SMIDEF#define _SMIDEF #define WINFAR #define STRCAT strcat#define STRLEN strlen#define MEMCPY memcpy#define STRCPY strcpy #define STRCMP strcmp#define MEMCMP memcmp #define XPORT // HANDLE needs to be defined for each type of platform// for win32 - HANDLE is a HWND// for unix - HANDLE is an unsigned long// unix and win32 ( Windu compile , unix takes presedence )#ifdef WIN32#ifndef SNMPHANDLE#define SNMPHANDLE HWND#endif#define DLLOPT __declspec(dllexport)#endif#ifdef __unix#ifndef SNMPHANDLE#define SNMPHANDLE unsigned long#define DLLOPT#endif#endif#ifndef TRUE#define TRUE 1#endif#ifndef FALSE#define FALSE 0#endif //----------[ ASN/BER Base Types ]-----------------------------------------// Basic Encoding Rules (BER)// (used in forming SYNTAXes and certain SNMP types/values) #define aSN_UNIVERSAL (0x00)#define aSN_APPLICATION (0x40)#define aSN_CONTEXT (0x80)#define aSN_PRIVATE (0xC0)#define aSN_PRIMITIVE (0x00)#define aSN_CONSTRUCTOR (0x20) //------[ SNMP ObjectSyntax Values ]---------------------------------------#define sNMP_SYNTAX_SEQUENCE (aSN_CONTEXT | aSN_CONSTRUCTOR | 0x10) //-------------------------------------------------------------------------// These values are used in the "syntax" member // of the smiVALUE structure which follows. // Note: UInt32 is indistinguishable from Gauge32 per SNMPv2 Draft Standard// NsapAddr is obsoleted as unique SMI type per SNMPv2 Draft Standard#define sNMP_SYNTAX_INT (aSN_UNIVERSAL | aSN_PRIMITIVE | 0x02)#define sNMP_SYNTAX_BITS (aSN_UNIVERSAL | aSN_PRIMITIVE | 0x03)#define sNMP_SYNTAX_OCTETS (aSN_UNIVERSAL | aSN_PRIMITIVE | 0x04)#define sNMP_SYNTAX_NULL (aSN_UNIVERSAL | aSN_PRIMITIVE | 0x05)#define sNMP_SYNTAX_OID (aSN_UNIVERSAL | aSN_PRIMITIVE | 0x06)#define sNMP_SYNTAX_INT32 sNMP_SYNTAX_INT#define sNMP_SYNTAX_IPADDR (aSN_APPLICATION | aSN_PRIMITIVE | 0x00)#define sNMP_SYNTAX_CNTR32 (aSN_APPLICATION | aSN_PRIMITIVE | 0x01)#define sNMP_SYNTAX_GAUGE32 (aSN_APPLICATION | aSN_PRIMITIVE | 0x02)#define sNMP_SYNTAX_TIMETICKS (aSN_APPLICATION | aSN_PRIMITIVE | 0x03)#define sNMP_SYNTAX_OPAQUE (aSN_APPLICATION | aSN_PRIMITIVE | 0x04)#define sNMP_SYNTAX_CNTR64 (aSN_APPLICATION | aSN_PRIMITIVE | 0x06)#define sNMP_SYNTAX_UINT32 (aSN_APPLICATION | aSN_PRIMITIVE | 0x07)//-------------------------------------------------------------------------//---------------[ Exception conditions for SNMPv2 ]-----------------------// support SNMP v2#define sNMP_SYNTAX_NOSUCHOBJECT (aSN_CONTEXT | aSN_PRIMITIVE | 0x00)#define sNMP_SYNTAX_NOSUCHINSTANCE (aSN_CONTEXT | aSN_PRIMITIVE | 0x01)#define sNMP_SYNTAX_ENDOFMIBVIEW (aSN_CONTEXT | aSN_PRIMITIVE | 0x02)//--------------[ different types of PDU's ]-------------------------------#define sNMP_PDU_GET (aSN_CONTEXT | aSN_CONSTRUCTOR | 0x0)#define sNMP_PDU_GETNEXT (aSN_CONTEXT | aSN_CONSTRUCTOR | 0x1)#define sNMP_PDU_RESPONSE (aSN_CONTEXT | aSN_CONSTRUCTOR | 0x2)#define sNMP_PDU_SET (aSN_CONTEXT | aSN_CONSTRUCTOR | 0x3)#define sNMP_PDU_V1TRAP (aSN_CONTEXT | aSN_CONSTRUCTOR | 0x4)#define sNMP_PDU_GETBULK (aSN_CONTEXT | aSN_CONSTRUCTOR | 0x5)#define sNMP_PDU_INFORM (aSN_CONTEXT | aSN_CONSTRUCTOR | 0x6)#define sNMP_PDU_TRAP (aSN_CONTEXT | aSN_CONSTRUCTOR | 0x7) //------[ smi typedefs ]---------------------------------------------------// SNMP-related types from RFC1442 (SMI) typedef unsigned char SmiBYTE, WINFAR *SmiLPBYTE;//-------------------------------------------------------------------------// SNMP-related types from RFC1442 (SMI) // inttypedef long SmiINT, WINFAR *SmiLPINT;// int 32typedef SmiINT SmiINT32, WINFAR *SmiLPINT32;// unit32typedef unsigned long SmiUINT32, WINFAR *SmiLPUINT32;// octet structtypedef struct { SmiUINT32 len; SmiLPBYTE ptr;} SmiOCTETS, WINFAR *SmiLPOCTETS;// bits typedef SmiOCTETS SmiBITS, WINFAR *SmiLPBITS;// SMI oid structtypedef struct { SmiUINT32 len; SmiLPUINT32 ptr;} SmiOID, WINFAR *SmiLPOID;// ipaddr typedef SmiOCTETS SmiIPADDR, WINFAR *SmiLPIPADDR;// 32bit countertypedef SmiUINT32 SmiCNTR32, WINFAR *SmiLPCNTR32;// gaugetypedef SmiUINT32 SmiGAUGE32, WINFAR *SmiLPGAUGE32;// timetickstypedef SmiUINT32 SmiTIMETICKS, WINFAR *SmiLPTIMETICKS;// opaquetypedef SmiOCTETS SmiOPAQUE, WINFAR *SmiLPOPAQUE;// nsapaddrtypedef SmiOCTETS SmiNSAPADDR, WINFAR *SmiLPNSAPADDR;// 64 bit countertypedef struct { SmiUINT32 hipart; SmiUINT32 lopart;} SmiCNTR64, WINFAR *SmiLPCNTR64; #endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -