From 1c59c5c4f4feaf43ef1868171305ca3fb7336bc1 Mon Sep 17 00:00:00 2001 From: Dhanya Thattil Date: Wed, 12 Dec 2018 11:20:39 +0100 Subject: [PATCH] in between --- .../ctbDetectorServer/MAX1932.h | 1 + .../jungfrauDetectorServer/MAX1932.h | 1 + .../slsDetectorServer/MAX1932.h | 64 +++++++++++++++++++ slsDetectorServers/slsDetectorServer/common.h | 44 +++++++++++++ 4 files changed, 110 insertions(+) create mode 120000 slsDetectorServers/ctbDetectorServer/MAX1932.h create mode 120000 slsDetectorServers/jungfrauDetectorServer/MAX1932.h create mode 100755 slsDetectorServers/slsDetectorServer/MAX1932.h create mode 100755 slsDetectorServers/slsDetectorServer/common.h diff --git a/slsDetectorServers/ctbDetectorServer/MAX1932.h b/slsDetectorServers/ctbDetectorServer/MAX1932.h new file mode 120000 index 000000000..8f7b239ea --- /dev/null +++ b/slsDetectorServers/ctbDetectorServer/MAX1932.h @@ -0,0 +1 @@ +../slsDetectorServer/MAX1932.h \ No newline at end of file diff --git a/slsDetectorServers/jungfrauDetectorServer/MAX1932.h b/slsDetectorServers/jungfrauDetectorServer/MAX1932.h new file mode 120000 index 000000000..8f7b239ea --- /dev/null +++ b/slsDetectorServers/jungfrauDetectorServer/MAX1932.h @@ -0,0 +1 @@ +../slsDetectorServer/MAX1932.h \ No newline at end of file diff --git a/slsDetectorServers/slsDetectorServer/MAX1932.h b/slsDetectorServers/slsDetectorServer/MAX1932.h new file mode 100755 index 000000000..7e6558838 --- /dev/null +++ b/slsDetectorServers/slsDetectorServer/MAX1932.h @@ -0,0 +1,64 @@ +#pragma once + +#include "commonServerFunctions.h" // blackfin.h, ansi.h + +/* MAX1932 HV DEFINES */ + +#define MAX1932_HV_NUMBITS (8) +#define MAX1932_HV_DATA_OFST (0) +#define MAX1932_HV_DATA_MSK (0x000000FF << MAX1932_HV_DATA_OFST) + +// on power up, dac = 0xff (1.25) + +uint32_t MAX1932_Reg = 0x0; +uint32_t MAX1932_CsMask = 0x0; +uint32_t MAX1932_ClkMask = 0x0; +uint32_t MAX1932_DigMask = 0x0; +int MAX1932_DigOffset = 0x0; + +/** + * Set Defines + * @param reg spi register + * @param cmsk chip select mask + * @param clkmsk clock output mask + * @param dmsk digital output mask + * @param dofst digital output offset + */ +void MAX1932_SetDefines(uint32_t reg, uint32_t cmsk, uint32_t clkmsk, uint32_t dmsk, int dofst) { + MAX1932_Reg = reg; + MAX1932_CsMask = cmsk; + MAX1932_ClkMask = clkmsk; + MAX1932_DigMask = dmsk; + MAX1932_DigOffset = dofst; +} + +/** + * Disable SPI + */ +void MAX1932_Disable() { + bus_w(MAX1932_Reg, bus_r(MAX1932_Reg) + | MAX1932_CsMask + | MAX1932_ClkMask + &~(MAX1932_DigMask)); +} + +/** + * Configure + */ +void MAX1932_Configure(){ + FILE_LOG(logINFOBLUE, ("Configuring MAX1932\n")); + +} + + +/** + * Set + * @param dacnum dac number + * @param data dac value to set + */ +void MAX1932_Set (int dacnum, int data) { + FILE_LOG(logDEBUG1, ("\tSetting dac %d to %d\n", dacnum, data)); + +} + + diff --git a/slsDetectorServers/slsDetectorServer/common.h b/slsDetectorServers/slsDetectorServer/common.h new file mode 100755 index 000000000..40905aade --- /dev/null +++ b/slsDetectorServers/slsDetectorServer/common.h @@ -0,0 +1,44 @@ +#pragma once + +/** + * Convert voltage to dac units + * @param voltage value in mv + * @param dacval pointer to value converted to dac units + * @param vmin minimum voltage in mV + * @param vmax maximum voltage in mV + * @param maximum number of steps + * @returns FAIL when voltage outside limits, OK if conversion successful + */ +int Common_VoltageToDac(int voltage, int* dacval, int vmin, int vmax, int nsteps) { + + // validate + if ((voltage < vmin) || (voltage > vmax)) { + FILE_LOG(logERROR, ("Voltage value (to convert to dac value) is outside bounds (%d to %d mV): %d\n", vmin, vmax, voltage)); + return FAIL; + } + + // convert + *dacval = (int)(((voltage - vmin) / (vmax - vmin)) * (nsteps - 1) + 0.5); + return OK; +} +/** + * Convert dac units to voltage + * @param dacval dac units + * @param voltage pointer to value converted to mV + * @param vmin minimum voltage in mV + * @param vmax maximum voltage in mV + * @param maximum number of steps + * @returns FAIL when voltage outside limits, OK if conversion successful + */ +int Common_DacToVoltage(int dacval, int* voltage, int vmin, int vmax, int nsteps) { + + // validate + if ((dacval < 0) || (dacval >= nsteps)) { + FILE_LOG(logERROR, ("Dac units (to convert to voltage) is outside bounds (0 to %d): %d\n", nsteps - 1, dacval)); + return FAIL; + } + + // convert + *voltage = vmin + (vmax - vmin) * dacval / (nsteps - 1); + return OK; +}