Mercurial > hg > fxanalyse
changeset 210:8ed253294405
Remove old AD9956 client code
author | Daniele Nicolodi <daniele.nicolodi@obspm.fr> |
---|---|
date | Mon, 31 Mar 2014 17:03:38 +0200 (2014-03-31) |
parents | 11a88d389705 |
children | f61fcffb4b93 |
files | DDS_Fox.c DDS_Fox.h |
diffstat | 2 files changed, 0 insertions(+), 468 deletions(-) [+] |
line wrap: on
line diff
--- a/DDS_Fox.c Mon Mar 31 17:03:38 2014 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,436 +0,0 @@ -#include <tcpsupp.h> -#include <ansi_c.h> -#include "DDS_Fox.h" - -// #define DEBUG 1 -#define CMD_SEP ";" -#define BASE_TIME 0.01 - -#define CMD_CONFIG_REG1 1 // cmd d'acces direct au rergistre 1 de config de la DDS (voir datasheet) -#define CMD_CONFIG_REG2 2 // cmd d'acces direct au rergistre 1 de config de la DDS (voir datasheet) -#define CMD_SINGLE_FREQ_PROF0 7 -#define CMD_PROFILE 15 // cmd de choix du profile de fonctionnement de la DDS (voir datasheet) -#define CMD_ATTENUATION 16 -#define CMD_RESET_DDS 17 -#define CMD_NOP 20 -#define CMD_FREQ_INF 21 -#define CMD_FREQ_SUP 22 -#define CMD_DF 23 -#define CMD_DT 24 -#define CMD_START_SWEEP 25 -#define CMD_STOP_SWEEP 26 -#define CMD_GET_FREQ 28 -#define CMD_SWEEP_SIGN 29 - -typedef struct { - char* action; - char* canal; - char* command; - char* value0; - char* value1; - char* value2; - char* value3; - char* value4; - char* value5; - char* value6; - char* value7; - char* value8; - char* value9; - char* value10; - char* value11; - char* value12; - char* value13; - char* value14; - char* value15; - char* value16; - char* value17; - char* value18; - char* value19; -} Command; - -static int SendCmd(char *Buffer, DDSParameter *Param); -static int RecvCmd(Command *Rd, char * Buffer, DDSParameter *Param); -static void init_command(Command *cmd); -static int parse_command(Command *cmd1, char *buf); -static void convert_double_6char (double fraction, unsigned char* octets); - -#define error(...) _error(__FILE__, __LINE__, __func__, __VA_ARGS__) - -void _error(const char *file, int line, const char *func, const char *frmt, ...) -{ - va_list args; - va_start(args, frmt); - fprintf(stderr, "ERROR: %s:%d:%s: ", file, line, func); - vfprintf(stderr, frmt, args); - fprintf(stderr, "\n"); - va_end(args); -} - -void DDSFox_Init(DDSParameter *Param, char *ip, int port) -{ - strcpy(Param->ip, ip); - Param->Port = 6665; - Param->Profil = 7; // configuration profile: single freq=0, sweep=7 - Param->Clock = 200000000; - Param->Delta_T = 0.01; - Param->SweepRate = 0.0; -} - -void DDSFox_Reset(DDSParameter *Param, double frequency) -{ - // set sweep rate to 0 - Param->SweepRate = 0.0; - // reset the DDS - DDSFox_DeviceReset(Param); - // set profile number 7 soft frequecy sweep - DDSFox_SetProfile(Param); - // set clock divider to 1 - DDSFox_SetDiv(Param, 1); - // set frequency - DDSFox_SetFreqInf(Param, frequency); - // set frequency upper bound to max value - DDSFox_SetFreqMax(Param); - // set sweep rate to 0 - DDSFox_SetDT(Param); - DDSFox_SetDf(Param); - DDSFox_SetSweepSign(Param); - // start sweep - DDSFox_StartSweep(Param); - // set frequency lower bound to min value - DDSFox_SetFreqMin(Param); - - return; -} - -void DDSFox_SetSweepRate(DDSParameter *Param, double sweepRate) -{ - Param->SweepRate = sweepRate; - DDSFox_SetDf(Param); - DDSFox_SetSweepSign(Param); -} - -void DDSFox_Set(DDSParameter *Param, double frequency, double sweepRate) -{ - // set desired frequency - DDSFox_SetFreqInf(Param, frequency); - // set frequency upper bound to max value - DDSFox_SetFreqMax(Param); - // set sweep rate to 0 - Param->SweepRate = 0.0; - DDSFox_SetDT(Param); - DDSFox_SetDf(Param); - DDSFox_SetSweepSign(Param); - // start sweep - DDSFox_StartSweep(Param); - // set frequency lower bound to min value - DDSFox_SetFreqMin(Param); - // set desired sweep rate - Param->SweepRate = sweepRate; - DDSFox_SetDf(Param); - DDSFox_SetSweepSign(Param); -} - -void DDSFox_Nop (DDSParameter *Param) -{ - // send NOP command - char request[255]; - sprintf(request, "set;%i;%i", 1, CMD_NOP); - SendCmd(request, Param); -} - -void DDSFox_SetProfile (DDSParameter *Param) -{ - char request[255]; - sprintf(request, "set;%i;%i;%i", 1, CMD_PROFILE, Param->Profil); - SendCmd(request, Param); -} - -void DDSFox_DeviceReset(DDSParameter *Param) -{ - char request[255]; - sprintf(request, "set;%i;%i", 1, CMD_RESET_DDS); - SendCmd(request, Param); -} - -void DDSFox_StopSweep(DDSParameter *Param) -{ - char Request[255]; - sprintf(Request,"set;%i;%i;%i",1,CMD_STOP_SWEEP,1); - SendCmd(Request, Param); - return ; -} - -void DDSFox_StartSweep(DDSParameter *Param) -{ - char Request[255]; - sprintf(Request,"set;%i;%i;%i",1,CMD_START_SWEEP,1); - SendCmd(Request, Param); - return ; -} - -void DDSFox_SetFreqMax (DDSParameter *Param) -{ - unsigned char octets[6]; - char Request[255]; - convert_double_6char(pow(2,48)/2,octets); // borne sup : clock / 2 - sprintf(Request,"set;%i;%i;%i;%i;%i;%i;%i;%i",1,CMD_FREQ_SUP, - *(octets+5),*(octets+4),*(octets+3),*(octets+2),*(octets+1),*octets); - SendCmd(Request, Param); - DDSFox_SetSweepSign (Param); - return ; -} - -void DDSFox_SetFreqMin (DDSParameter *Param) -{ - unsigned char octets[6]; - char Request[255]; - convert_double_6char(1,octets); // borne inf : ~0 - sprintf(Request,"set;%i;%i;%i;%i;%i;%i;%i;%i",1,CMD_FREQ_INF, - *(octets+5),*(octets+4),*(octets+3),*(octets+2),*(octets+1),*octets); - SendCmd(Request, Param); - DDSFox_SetSweepSign (Param); - return ; -} - -void DDSFox_SetFreqInf (DDSParameter *Param, double frequency) -{ - double word ; - unsigned char octets[6]; - char Request[255]; - word = pow(2,48)*(frequency / Param->Clock); - convert_double_6char(word, octets); - sprintf(Request,"set;%i;%i;%i;%i;%i;%i;%i;%i",1,CMD_FREQ_INF, - *(octets+5),*(octets+4),*(octets+3),*(octets+2),*(octets+1),*octets); - SendCmd(Request, Param); -} - -void DDSFox_SetFreqSup (DDSParameter *Param, double frequency) -{ - double word ; - unsigned char octets[6]; - char Request[255]; - word = pow(2,48)*(frequency / Param->Clock); - convert_double_6char(word, octets); - sprintf(Request,"set;%i;%i;%i;%i;%i;%i;%i;%i",1,CMD_FREQ_SUP, - *(octets+5),*(octets+4),*(octets+3),*(octets+2),*(octets+1),*octets); - SendCmd(Request, Param); -} - -static int GetSweepSign(DDSParameter *Param) -{ - if (Param->SweepRate >= 0.0) - return 0; - return 1; -} - -void DDSFox_SetSweepSign(DDSParameter *Param) -{ - char Request[255] ; - int SweepSign ; - SweepSign = GetSweepSign(Param) ; - sprintf(Request, "set;%i;%i;%i", 1, CMD_SWEEP_SIGN, SweepSign); - SendCmd(Request, Param) ; - return ; -} - -void DDSFox_SetDT(DDSParameter *Param) -{ - char Request[255]; - int dt= 0; - char FTW0[255]="0"; /**** sinon le fichier inf.xx est faux ***/ - dt = ((Param->Delta_T)/BASE_TIME) - 1 ; - sprintf(FTW0,"%ims",dt); - sprintf(Request,"set;%i;%i;%i;%s",1,CMD_DT, dt ,FTW0); - SendCmd(Request, Param) ; - return ; -} - -// Change le facteur de division de la clock. Argument: facteur de div, retourne rien -void DDSFox_SetDiv(DDSParameter *Param, int div) -{ - char Request[255]; - Command Rd; - char temp; - - int Div = 0; - // Div = log2(div) - while ((div >>= 1) > 1) - Div++; - - init_command(&Rd); - sprintf(Request,"get;%i;%i",1,CMD_CONFIG_REG2); - if (RecvCmd(&Rd, Request, Param) < 0) - return; - temp = atoi(Rd.value2) ; - temp = temp & 0x9F ; - temp = temp | Div << 5 ; - sprintf(Request,"set;%i;%i;%i;%i;%i;%i;%i",1,CMD_CONFIG_REG2,atoi(Rd.value0), - atoi(Rd.value1),temp,atoi(Rd.value3),atoi(Rd.value4)) ; - SendCmd(Request, Param) ; - return ; -} - -void DDSFox_SetDf(DDSParameter *Param) -{ - char Request[255]; - double word ; - unsigned char *octets; - word = pow(2,48)*(fabs(Param->SweepRate)*Param->Delta_T/Param->Clock); - octets=malloc(6*sizeof(unsigned char)); - convert_double_6char(word, octets); - sprintf(Request,"set;%i;%i;%i;%i;%i;%i;%i;%i",1,CMD_DF, - *(octets+5),*(octets+4),*(octets+3),*(octets+2),*(octets+1),*octets); - SendCmd(Request, Param); - free(octets); - return ; -} - -double DDSFox_ReadFreq(DDSParameter *Param) -{ - char Request[255]; - unsigned int OctetA, OctetB, OctetC, OctetD, OctetE, OctetF ; - double FreqRead ; - Command Rd; - init_command(&Rd); - sprintf(Request,"get;%i;%i",1,CMD_GET_FREQ); - if (RecvCmd(&Rd, Request, Param) == -1) - return -1.; - OctetA=atoi(Rd.value0); - OctetB=atoi(Rd.value1); - OctetC=atoi(Rd.value2); - OctetD=atoi(Rd.value3); - OctetE=atoi(Rd.value4); - OctetF=atoi(Rd.value5); - FreqRead = 1099511627776.0 * OctetA + 4294967296.0 * OctetB + 16777216.0 * OctetC + 65536.0 * OctetD + 256.0 * OctetE + 1.0 * OctetF; - FreqRead = FreqRead * Param->Clock / pow(2,48); - return(FreqRead); -} - -// TCP communication - -static unsigned int timeout = 0; // milliseconds - - -static int SendCmd(char *Buffer, DDSParameter *Param) -{ - unsigned int hConv=0; - char Response[255]; -#ifdef DEBUG - fprintf(stderr, "> %s\n", Buffer); -#endif - if (ConnectToTCPServer (&hConv, Param->Port, Param->ip, NULL, NULL, timeout) < 0) { - error("Connect failed"); - return -1; - } - if (ClientTCPWrite (hConv, Buffer, strlen(Buffer)+1, timeout) < 0) { - error("Write failed"); - return -1; - } - sprintf(Response," "); - if (ClientTCPRead (hConv, Response, 255, timeout) < 0) { - error("Read failed"); - return -1; - } -#ifdef DEBUG - fprintf(stderr, "< %s\n", Response); -#endif - if (strncmp("OK",Response,2)) { - error("Response failed %s %s", Buffer, Response); - return -1; - } - return 0; -} - -static int RecvCmd(Command *Rd, char * Buffer, DDSParameter *Param) -{ - unsigned int hConv=0; - char parsebuf[255]; - char Response[255]; -#ifdef DEBUG - fprintf(stderr, "> %s\n", Buffer); -#endif - if (ConnectToTCPServer (&hConv, Param->Port, Param->ip, NULL, NULL, timeout) < 0) { - error("Connect failed"); - return -1; - } - if (ClientTCPWrite (hConv, Buffer, strlen(Buffer)+1, timeout) < 0) { - error("Write failed"); - return -1; - } - sprintf(Response," "); - if (ClientTCPRead (hConv, Response, 255, timeout) < 0) { - error("Read failed"); - return -1; - } -#ifdef DEBUG - fprintf(stderr, "< %s\n", Response); -#endif - if (strncmp(Buffer,Response,strlen(Buffer))) { - error("Response failed %s %s", Buffer, Response); - return -1; - } - - sprintf(parsebuf,"%s",Response) ; - parse_command(Rd, parsebuf) ; - return 0; -} - -static void init_command(Command *cmd) -{ - memset(cmd, 0, sizeof(Command)); -} - -static int parse_command(Command *cmd1, char *buf) -{ - char* pointer; - int c = 0; - - pointer = strtok( buf, CMD_SEP ); - while( pointer ){ - if( c == 0 ){ - cmd1->action = pointer; - } - else if( c == 1 ){ - cmd1->canal = pointer; - } - else if( c == 2 ){ - cmd1->command = pointer; - } - else if( c == 3 ){ - cmd1->value0 = pointer; - } - else if( c == 4 ){ - cmd1->value1 = pointer; - } - else if( c == 5 ){ - cmd1->value2 = pointer; - } - else if( c == 6 ){ - cmd1->value3 = pointer; - } - else if( c == 7 ){ - cmd1->value4 = pointer; - } - else if( c == 8 ){ - cmd1->value5 = pointer; - } - else if( c == 9 ){ - cmd1->value6 = pointer; - } - else if( c == 10 ){ - cmd1->value7 = pointer; - } - pointer = strtok( NULL, CMD_SEP ); - c++; - } - return 0; -} - -// convert double into 6 bytes sent back by an unsigned char pointer -static void convert_double_6char (double fraction, unsigned char* octets) -{ - // 64 bits integer - unsigned long long x = fraction; - for (int i = 0; i < 6; i++) - octets[i] = (unsigned char)((x >> (i * 8)) & 0xFF); -}
--- a/DDS_Fox.h Mon Mar 31 17:03:38 2014 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,32 +0,0 @@ -struct ad9956 { - char ip[255]; - int Port; - double Clock; - double SweepRate; - double Delta_T; - unsigned int Profil; -}; - -typedef struct ad9956 DDSParameter; - -void DDSFox_Init(DDSParameter *Param, char *ip, int port); -void DDSFox_Reset(DDSParameter * Param, double frequency); -void DDSFox_SetSweepRate(DDSParameter *Param, double sweepRate); -void DDSFox_Set(DDSParameter *Param, double frequency, double sweepRate); -void DDSFox_Nop(DDSParameter *Param); -void DDSFox_SetProfile(DDSParameter *Param); -void DDSFox_SetDiv(DDSParameter *Param, int div); -void DDSFox_DeviceReset(DDSParameter * Param); -void DDSFox_SetFreq (DDSParameter * Param) ; -void DDSFox_SetFreqInf (DDSParameter *Param, double frequency) ; -void DDSFox_SetFreqSup (DDSParameter *Param, double frequency) ; -void DDSFox_SetFreqMax (DDSParameter *Param); -void DDSFox_SetFreqMin (DDSParameter *Param) ; -void DDSFox_SetDT(DDSParameter * Param); -void DDSFox_SetDf(DDSParameter * Param); -int DDSFox_GetSweepSign(DDSParameter * Param); -void DDSFox_SetSweepSign(DDSParameter * Param) ; -void DDSFox_StopSweep(DDSParameter * Param); -void DDSFox_StartSweep(DDSParameter * Param); -double DDSFox_ReadFreq(DDSParameter * Param); -