123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- /*====================================================================*
- Copyright (c) 2013,2021 Qualcomm Technologies, Inc.
- All Rights Reserved.
- Confidential and Proprietary - Qualcomm Technologies, Inc.
- ******************************************************************
- 2013 Qualcomm Atheros, Inc.
- *--------------------------------------------------------------------*/
- /*====================================================================*
- *
- * signed pev_cm_slac_match (struct session * session, struct channel * channel, struct message * message);
- *
- * slac.h
- *
- * send CM_SLAC_MATCH.REQ and receive CM_SLAC_MATCH.CNF; store NMK
- * and NID in the session variable so that PEV-HLE can configure
- * PEV-PLC to form a network with EVSE-PLC;
- *
- *--------------------------------------------------------------------*/
- #ifndef PEV_CM_SLAC_MATCH_SOURCE
- #define PEV_CM_SLAC_MATCH_SOURCE
- #include <string.h>
- #include <errno.h>
- #include "../ether/channel.h"
- #include "../tools/memory.h"
- #include "../tools/error.h"
- #include "../tools/flags.h"
- #include "../slac/slac.h"
- signed pev_cm_slac_match (struct session * session, struct channel * channel, struct message * message)
- {
- struct cm_slac_match_request * request = (struct cm_slac_match_request *) (message);
- struct cm_slac_match_confirm * confirm = (struct cm_slac_match_confirm *) (message);
- debug (0, __func__, "--> CM_SLAC_MATCH.REQ");
- memset (message, 0, sizeof (* message));
- EthernetHeader (& request->ethernet, session->EVSE_MAC, channel->host, channel->type);
- HomePlugHeader1 (& request->homeplug, HOMEPLUG_MMV, (CM_SLAC_MATCH | MMTYPE_REQ));
- request->APPLICATION_TYPE = session->APPLICATION_TYPE;
- request->SECURITY_TYPE = session->SECURITY_TYPE;
- request->MVFLength = HTOLE16 (sizeof (request->MatchVarField));
- memcpy (request->MatchVarField.PEV_ID, session->PEV_ID, sizeof (request->MatchVarField.PEV_ID));
- memcpy (request->MatchVarField.PEV_MAC, session->PEV_MAC, sizeof (request->MatchVarField.PEV_MAC));
- memcpy (request->MatchVarField.RunID, session->RunID, sizeof (request->MatchVarField.RunID));
- if (sendmessage (channel, message, sizeof (* request)) <= 0)
- {
- return (debug (1, __func__, CHANNEL_CANTSEND));
- }
- if (readmessage (channel, message, HOMEPLUG_MMV, (CM_SLAC_MATCH | MMTYPE_CNF)) > 0)
- {
- if (! memcmp (session->RunID, confirm->MatchVarField.RunID, sizeof (session->RunID)))
- {
- debug (0, __func__, "<-- CM_SLAC_MATCH.CNF");
- #if SLAC_DEBUG
- if (_anyset (session->flags, SLAC_VERBOSE))
- {
- char string [256];
- debug (0, __func__, "CM_SLAC_MATCH.CNF.APPLICATION_TYPE %d", confirm->APPLICATION_TYPE);
- debug (0, __func__, "CM_SLAC_MATCH.CNF.SECURITY_TYPE %d", confirm->SECURITY_TYPE);
- debug (0, __func__, "CM_SLAC_MATCH.CNF.MVFLength %d", LE16TOH (confirm->MVFLength));
- debug (0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.PEV_ID %s", HEXSTRING (string, confirm->MatchVarField.PEV_ID));
- debug (0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.PEV_MAC %s", HEXSTRING (string, confirm->MatchVarField.PEV_MAC));
- debug (0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.EVSE_ID %s", HEXSTRING (string, confirm->MatchVarField.EVSE_ID));
- debug (0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.EVSE_MAC %s", HEXSTRING (string, confirm->MatchVarField.EVSE_MAC));
- debug (0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.RunID %s", HEXSTRING (string, confirm->MatchVarField.RunID));
- debug (0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.NID %s", HEXSTRING (string, confirm->MatchVarField.NID));
- debug (0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.NMK %s", HEXSTRING (string, confirm->MatchVarField.NMK));
- }
- #endif
- memcpy (session->EVSE_ID, confirm->MatchVarField.EVSE_ID, sizeof (session->EVSE_ID));
- memcpy (session->EVSE_MAC, confirm->MatchVarField.EVSE_MAC, sizeof (session->EVSE_MAC));
- memcpy (session->NMK, confirm->MatchVarField.NMK, sizeof (session->NMK));
- memcpy (session->NID, confirm->MatchVarField.NID, sizeof (session->NID));
- return (0);
- }
- }
- return (debug (session->exit, __func__, "<-- CM_SLAC_MATCH.CNF ?"));
- }
- signed pev_cm_slac_match_req(struct session* session, struct channel* channel, struct message* message)
- {
- struct cm_slac_match_request* request = (struct cm_slac_match_request*)(message);
- debug(0, __func__, "--> CM_SLAC_MATCH.REQ");
- memset(message, 0, sizeof(*message));
- EthernetHeader(&request->ethernet, session->EVSE_MAC, channel->host, channel->type);
- HomePlugHeader1(&request->homeplug, HOMEPLUG_MMV, (CM_SLAC_MATCH | MMTYPE_REQ));
- request->APPLICATION_TYPE = session->APPLICATION_TYPE;
- request->SECURITY_TYPE = session->SECURITY_TYPE;
- request->MVFLength = HTOLE16(sizeof(request->MatchVarField));
- memcpy(request->MatchVarField.PEV_ID, session->PEV_ID, sizeof(request->MatchVarField.PEV_ID));
- memcpy(request->MatchVarField.PEV_MAC, session->PEV_MAC, sizeof(request->MatchVarField.PEV_MAC));
- memcpy(request->MatchVarField.RunID, session->RunID, sizeof(request->MatchVarField.RunID));
- if (sendmessage(channel, message, sizeof(*request)) <= 0)
- {
- return (debug(1, __func__, CHANNEL_CANTSEND));
- }
- return 0;
- }
- signed pev_cm_slac_match_cnf(struct session* session, struct channel* channel, struct message* message)
- {
- struct cm_slac_match_confirm* confirm = (struct cm_slac_match_confirm*)(message);
- if (!memcmp(session->RunID, confirm->MatchVarField.RunID, sizeof(session->RunID)))
- {
- debug(0, __func__, "<-- CM_SLAC_MATCH.CNF");
- #if SLAC_DEBUG
- if (_anyset(session->flags, SLAC_VERBOSE))
- {
- char string[256];
- debug(0, __func__, "CM_SLAC_MATCH.CNF.APPLICATION_TYPE %d", confirm->APPLICATION_TYPE);
- debug(0, __func__, "CM_SLAC_MATCH.CNF.SECURITY_TYPE %d", confirm->SECURITY_TYPE);
- debug(0, __func__, "CM_SLAC_MATCH.CNF.MVFLength %d", LE16TOH(confirm->MVFLength));
- debug(0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.PEV_ID %s", HEXSTRING(string, confirm->MatchVarField.PEV_ID));
- debug(0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.PEV_MAC %s", HEXSTRING(string, confirm->MatchVarField.PEV_MAC));
- debug(0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.EVSE_ID %s", HEXSTRING(string, confirm->MatchVarField.EVSE_ID));
- debug(0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.EVSE_MAC %s", HEXSTRING(string, confirm->MatchVarField.EVSE_MAC));
- debug(0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.RunID %s", HEXSTRING(string, confirm->MatchVarField.RunID));
- debug(0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.NID %s", HEXSTRING(string, confirm->MatchVarField.NID));
- debug(0, __func__, "CM_SLAC_MATCH.CNF.MatchVarField.NMK %s", HEXSTRING(string, confirm->MatchVarField.NMK));
- }
- #endif
- memcpy(session->EVSE_ID, confirm->MatchVarField.EVSE_ID, sizeof(session->EVSE_ID));
- memcpy(session->EVSE_MAC, confirm->MatchVarField.EVSE_MAC, sizeof(session->EVSE_MAC));
- memcpy(session->NMK, confirm->MatchVarField.NMK, sizeof(session->NMK));
- memcpy(session->NID, confirm->MatchVarField.NID, sizeof(session->NID));
- return (0);
- }
- return (debug(session->exit, __func__, "<-- CM_SLAC_MATCH.CNF ?"));
- }
- #endif
|