⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 smi.h

📁 SNMP++程序源码 for ll .8snmp++2_8.tar.Z 嵌入式linux环境下的SNMP开发代码
💻 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 + -