#include #if CONFIG_HAL_BOARD == HAL_BOARD_LINUX #include "RCOutput.h" #include #include #include #include #include #include #include #include #include #include #include using namespace Linux; #define PWM_CHAN_COUNT 12 int chan_pru_map[]= {10,8,11,9,7,6,5,4,3,2,1,0}; //chan_pru_map[CHANNEL_NUM] = PRU_REG_R30/31_NUM; int pru_chan_map[]= {11,10,9,8,7,6,5,4,1,3,0,2}; //pru_chan_map[PRU_REG_R30/31_NUM] = CHANNEL_NUM; static const AP_HAL::HAL& hal = AP_HAL_BOARD_DRIVER; void LinuxRCOutput::init(void* machtnicht) { int mem_fd; mem_fd = open("/dev/mem", O_RDWR|O_SYNC); sharedMem_cmd = (struct pwm_cmd *) mmap(0, 0x1000, PROT_READ|PROT_WRITE, MAP_SHARED, mem_fd, PRUSS_SHAREDRAM_BASE); close(mem_fd); } void LinuxRCOutput::set_freq(uint32_t chmask, uint16_t freq_hz) //LSB corresponds to CHAN_1 { int i; unsigned long tick=TICK_PER_S/(unsigned long)freq_hz; for(i=0;i<12;i++){ if(chmask&(1<periodhi[chan_pru_map[i]][0]=tick; } } } uint16_t LinuxRCOutput::get_freq(uint8_t ch) { return TICK_PER_S/sharedMem_cmd->periodhi[chan_pru_map[ch]][0]; } void LinuxRCOutput::enable_ch(uint8_t ch) { sharedMem_cmd->enmask |= 1<enmask &= !(1<periodhi[chan_pru_map[ch]][1] = TICK_PER_US*period_us; sharedMem_cmd->magic = PWM_CMD_MAGIC; } void LinuxRCOutput::write(uint8_t ch, uint16_t* period_us, uint8_t len) { int i; for(i=0;iperiodhi[chan_pru_map[ch]][1]/TICK_PER_US); } void LinuxRCOutput::read(uint16_t* period_us, uint8_t len) { int i; for(i=0;iperiodhi[chan_pru_map[i]][1]/TICK_PER_US; } } #endif