1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
/*
*
* Copyright (c) 2003 by FORCE Computers.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. This
* file and program are licensed under a BSD style license. See
* the Copying file included with the OpenHPI distribution for
* full licensing terms.
*
* Authors:
* Thomas Kanngieser <thomas.kanngieser@fci.com>
*/
#include <string.h>
#include "ipmi_msg.h"
cIpmiMsg::cIpmiMsg()
: m_netfn( eIpmiNetfnChassis ), m_cmd( eIpmiCmdGetChassisCapabilities ),
m_data_len( 0 )
{
}
cIpmiMsg::cIpmiMsg( tIpmiNetfn netfn, tIpmiCmd cmd,
unsigned short data_len, unsigned char *data )
: m_netfn( netfn ), m_cmd( cmd )
{
if ( data_len <= dIpmiMaxMsgLength )
m_data_len = data_len;
else
m_data_len = dIpmiMaxMsgLength;
if ( data )
{
memcpy( m_data, data, m_data_len );
}
}
bool
cIpmiMsg::Equal( const cIpmiMsg &msg2 ) const
{
if ( m_netfn != msg2.m_netfn
|| m_cmd != msg2.m_cmd
|| m_data_len != msg2.m_data_len )
return false;
if ( m_data_len )
if ( memcmp( m_data, msg2.m_data, m_data_len ) )
return false;
return true;
}
|