123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- #ifndef FAILURE_SOURCE
- #define FAILURE_SOURCE
- #include <stdio.h>
- #include <stdarg.h>
- #include <stdlib.h>
- #include "../plc/plc.h"
- #include "../tools/error.h"
- #include "../tools/flags.h"
- #include "../tools/memory.h"
- #include "../mme/mme.h"
- #ifdef __GNUC__
- __attribute__ ((format (printf, 2, 3)))
- #endif
- void Failure (struct plc * plc, char const *format, ...)
- {
- if (_allclr (plc->flags, PLC_SILENCE))
- {
- char address [ETHER_ADDR_LEN * 3];
- struct channel * channel = (struct channel *)(plc->channel);
- struct message * message = (struct message *)(plc->message);
- struct __packed header_confirm
- {
- ethernet_hdr ethernet;
- qualcomm_hdr qualcomm;
- uint8_t MSTATUS;
- }
- * header = (struct header_confirm *)(message);
- hexdecode (header->ethernet.OSA, sizeof (header->ethernet.OSA), address, sizeof (address));
- fprintf (stderr, "%s %s ", channel->ifname, address);
- switch (LE16TOH (header->qualcomm.MMTYPE))
- {
- case VS_CONN_ADD | MMTYPE_CNF:
- case VS_CONN_MOD | MMTYPE_CNF:
- case VS_CONN_REL | MMTYPE_CNF:
- case VS_CONN_INFO | MMTYPE_CNF:
- {
- struct __packed header_confirm
- {
- struct ethernet_hdr ethernet;
- struct qualcomm_hdr qualcomm;
- uint32_t REQUEST;
- uint8_t MSTATUS;
- }
- * header = (struct header_confirm *)(message);
- if (header->MSTATUS)
- {
- fprintf (stderr, "%s (0x%02X): ", MMECode (header->qualcomm.MMTYPE, header->MSTATUS), header->MSTATUS);
- }
- }
- break;
- case VS_SELFTEST_RESULTS | MMTYPE_CNF:
- case VS_FORWARD_CONFIG | MMTYPE_CNF:
- {
- struct __packed header_confirm
- {
- struct ethernet_hdr ethernet;
- struct qualcomm_hdr qualcomm;
- uint8_t MVERSION;
- uint8_t RESULTCODE;
- }
- * header = (struct header_confirm *)(message);
- if (header->RESULTCODE)
- {
- fprintf (stderr, "%s (0x%02X): ", MMECode (header->qualcomm.MMTYPE, header->RESULTCODE), header->RESULTCODE);
- }
- }
- break;
- default:
- if (header->MSTATUS)
- {
- fprintf (stderr, "%s (0x%02X): ", MMECode (header->qualcomm.MMTYPE, header->MSTATUS), header->MSTATUS);
- }
- break;
- }
- if ((format) && (*format))
- {
- va_list arglist;
- va_start (arglist, format);
- vfprintf (stderr, format, arglist);
- va_end (arglist);
- }
- fprintf (stderr, "\n");
- }
- if (_anyset (plc->flags, PLC_BAILOUT))
- {
- if (_allclr (plc->flags, PLC_SILENCE))
- {
- error (1, 0, "Bailing Out!");
- }
- exit (1);
- }
- return;
- }
- #endif
|