summaryrefslogtreecommitdiff
path: root/drivers/gator/daemon/Sender.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gator/daemon/Sender.cpp')
-rw-r--r--drivers/gator/daemon/Sender.cpp106
1 files changed, 0 insertions, 106 deletions
diff --git a/drivers/gator/daemon/Sender.cpp b/drivers/gator/daemon/Sender.cpp
deleted file mode 100644
index 9792c3677a3..00000000000
--- a/drivers/gator/daemon/Sender.cpp
+++ /dev/null
@@ -1,106 +0,0 @@
-/**
- * Copyright (C) ARM Limited 2010-2012. All rights reserved.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- */
-
-#include <string.h>
-#include <sys/socket.h>
-#include <netinet/in.h>
-#include <sys/types.h>
-#include <arpa/inet.h>
-#include <stdlib.h>
-#include <unistd.h>
-#include "Sender.h"
-#include "Logging.h"
-#include "SessionData.h"
-
-extern void handleException();
-
-Sender::Sender(OlySocket* socket) {
- dataFile = NULL;
- dataSocket = NULL;
-
- // Set up the socket connection
- if (socket) {
- char streamline[64] = {0};
- dataSocket = socket;
-
- // Receive magic sequence - can wait forever
- // Streamline will send data prior to the magic sequence for legacy support, which should be ignored for v4+
- while (strcmp("STREAMLINE", streamline) != 0) {
- if (dataSocket->receiveString(streamline, sizeof(streamline)) == -1) {
- logg->logError(__FILE__, __LINE__, "Socket disconnected");
- handleException();
- }
- }
-
- // Send magic sequence - must be done first, afterwhich error messages can be sent
- char magic[] = {'G', 'A', 'T', 'O', 'R', '\n'};
- dataSocket->send(magic, sizeof(magic));
-
- gSessionData->mWaitingOnCommand = true;
- logg->logMessage("Completed magic sequence");
- }
-
- pthread_mutex_init(&sendMutex, NULL);
-}
-
-Sender::~Sender() {
- delete dataSocket;
- dataSocket = NULL;
- if (dataFile) {
- fclose(dataFile);
- }
-}
-
-void Sender::createDataFile(char* apcDir) {
- if (apcDir == NULL)
- return;
-
- dataFileName = (char*)malloc(strlen(apcDir) + 12);
- sprintf(dataFileName, "%s/0000000000", apcDir);
- dataFile = fopen(dataFileName, "wb");
- if (!dataFile) {
- logg->logError(__FILE__, __LINE__, "Failed to open binary file: %s", dataFileName);
- handleException();
- }
-}
-
-void Sender::writeData(const char* data, int length, int type) {
- if (length < 0 || (data == NULL && length > 0)) {
- return;
- }
-
- // Multiple threads call writeData()
- pthread_mutex_lock(&sendMutex);
-
- // Send data over the socket connection
- if (dataSocket) {
- // Start alarm
- alarm(8);
-
- // Send data over the socket, sending the type and size first
- logg->logMessage("Sending data with length %d", length);
- dataSocket->send((char*)&type, 1);
- dataSocket->send((char*)&length, sizeof(length));
- dataSocket->send((char*)data, length);
-
- // Stop alarm
- alarm(0);
- }
-
- // Write data to disk as long as it is not meta data
- if (dataFile && type == RESPONSE_APC_DATA) {
- logg->logMessage("Writing data with length %d", length);
- // Send data to the data file, storing the size first
- if ((fwrite((char*)&length, 1, sizeof(length), dataFile) != sizeof(length)) || (fwrite(data, 1, length, dataFile) != (unsigned int)length)) {
- logg->logError(__FILE__, __LINE__, "Failed writing binary file %s", dataFileName);
- handleException();
- }
- }
-
- pthread_mutex_unlock(&sendMutex);
-}