#ifndef __DDS_H #define __DDS_H #include <hw/common.h> #include <generated/mem.h> /* Number of DDS channels to initialize */ #define DDS_CHANNEL_COUNT 8 /* Maximum number of commands in a batch */ #define DDS_MAX_BATCH 16 /* DDS core registers */ #define DDS_FTW0 0x0a #define DDS_FTW1 0x0b #define DDS_FTW2 0x0c #define DDS_FTW3 0x0d #define DDS_POW0 0x0e #define DDS_POW1 0x0f #define DDS_FUD 0x40 #define DDS_GPIO 0x41 enum { PHASE_MODE_CONTINUOUS = 0, PHASE_MODE_ABSOLUTE = 1, PHASE_MODE_TRACKING = 2 }; void dds_init_all(void); void dds_init(long long int timestamp, int channel); void dds_batch_enter(long long int timestamp); void dds_batch_exit(void); void dds_set(long long int timestamp, int channel, unsigned int ftw, unsigned int pow, int phase_mode); #endif /* __DDS_H */