#include "globals.h"
#include <time.h>
#include <sys/time.h>


GlobalStruct globals = {
	.Flags.do_check_settings = 1,
	.Flags.attenuators_enabled = 1,
	.DefaultFlags.do_check_settings = 1,
	.DefaultFlags.attenuators_enabled = 1,

	.Registers.last_rise_time_relay_setting = 99,

	.Registers.last_relay_driver_settings[0] = -1,
	.Registers.last_relay_driver_settings[1] = -1,
	.Registers.last_relay_driver_settings[2] = -1,
	.Registers.last_relay_driver_settings[3] = -1,
	.Registers.last_relay_driver_settings[4] = -1,

	.Registers.gpib_input_buffer[0] = 0,
	.Registers.pending_output_message = NULL,

	.VxiLocks.locked_network_server = NO_SERVER_LOCKED,

	.MenuStatus.Nonstd_Display = YES
};


PwlStruct pwl_struct[pwl_max_types][max_channels];


long sec_timer (void)
{
	return (long)time(NULL);
}


unsigned long long ms_timer (void)
{
	struct timeval tv;
	gettimeofday(&tv, NULL);

	unsigned long long millisecondsSinceEpoch =
	        (unsigned long long)(tv.tv_sec) * 1000 +
	        (unsigned long long)(tv.tv_usec) / 1000;

	return millisecondsSinceEpoch;
}

const char* param_name[] = { "AMPL", "OS", "PW", "DELAY", "PERIOD", "BURST", "RISE", "SLEW", "DISTORT" };

void debug_new_parameter (int channel, int parameter, float requested)
{
	g_print_debug("chan %d, %s, requested %e, adjusted %e, polarity %d, range %d, word %d, aux %d, atten %d\n", 
		channel, param_name[parameter], requested,
		pwl_struct[parameter][channel].actual_value,
		pwl_struct[parameter][channel].actual_pol,
		pwl_struct[parameter][channel].range,
                pwl_struct[parameter][channel].word_out,
		pwl_struct[parameter][channel].word_out_aux,
		pwl_struct[parameter][channel].atten_range);
}