Blob Blame History Raw
/*
 *
 * 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_addr.h>

#include "ipmi_msg.h"


cIpmiMsg::cIpmiMsg()
  : m_netfn( eIpmiNetfnChassis ), m_cmd( eIpmiCmdGetChassisCapabilities ),
    m_data_len( 0 ), m_sa( 0 ), m_chan ( 0 )
{
}


cIpmiMsg::cIpmiMsg( tIpmiNetfn netfn, tIpmiCmd cmd,
                    unsigned short data_len, unsigned char *data,
                    unsigned char sa, unsigned char chan )
  : 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 );
     }
  if (chan != 0) {
     m_sa = sa;
     m_chan = chan;
  } else {
     m_sa = dIpmiBmcSlaveAddr;  //0x20
     m_chan = 0;
  }
}


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;
}