2021-03-03 19:48:19 +01:00
|
|
|
/****************************************************************************
|
|
|
|
* apps/examples/foc/foc_device.c
|
|
|
|
*
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the
|
|
|
|
* License. You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <fcntl.h>
|
2021-05-24 11:41:49 +02:00
|
|
|
#include <assert.h>
|
2023-02-04 14:56:06 +01:00
|
|
|
#include <unistd.h>
|
2021-03-03 19:48:19 +01:00
|
|
|
|
|
|
|
#include "foc_debug.h"
|
|
|
|
#include "foc_device.h"
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Public Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
2021-10-31 11:30:30 +01:00
|
|
|
* Name: foc_device_init
|
2021-03-03 19:48:19 +01:00
|
|
|
****************************************************************************/
|
|
|
|
|
2021-10-31 11:30:30 +01:00
|
|
|
int foc_device_init(FAR struct foc_device_s *dev, int id)
|
2021-03-03 19:48:19 +01:00
|
|
|
{
|
2021-10-31 11:30:30 +01:00
|
|
|
char devpath[32];
|
|
|
|
int ret = OK;
|
|
|
|
struct foc_cfg_s cfg;
|
2021-03-03 19:48:19 +01:00
|
|
|
|
|
|
|
DEBUGASSERT(dev);
|
|
|
|
|
|
|
|
/* Get FOC devpath */
|
|
|
|
|
2023-03-05 16:55:15 +01:00
|
|
|
snprintf(devpath, sizeof(devpath), "%s%d",
|
|
|
|
CONFIG_EXAMPLES_FOC_DEVPATH, id);
|
2021-03-03 19:48:19 +01:00
|
|
|
|
|
|
|
/* Open FOC device */
|
|
|
|
|
|
|
|
dev->fd = open(devpath, 0);
|
|
|
|
if (dev->fd <= 0)
|
|
|
|
{
|
|
|
|
PRINTF("ERROR: open %s failed %d\n", devpath, errno);
|
|
|
|
ret = -errno;
|
|
|
|
goto errout;
|
|
|
|
}
|
|
|
|
|
2021-10-31 10:54:22 +01:00
|
|
|
/* Get device info */
|
|
|
|
|
|
|
|
ret = foc_dev_getinfo(dev->fd, &dev->info);
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
PRINTF("ERROR: foc_dev_getinfo failed %d!\n", ret);
|
|
|
|
goto errout;
|
|
|
|
}
|
|
|
|
|
2021-10-31 11:30:30 +01:00
|
|
|
/* Get FOC device configuration */
|
|
|
|
|
|
|
|
cfg.pwm_freq = (CONFIG_EXAMPLES_FOC_PWM_FREQ);
|
|
|
|
cfg.notifier_freq = (CONFIG_EXAMPLES_FOC_NOTIFIER_FREQ);
|
|
|
|
|
|
|
|
/* Print FOC device configuration */
|
|
|
|
|
|
|
|
foc_cfg_print(&cfg);
|
|
|
|
|
|
|
|
/* Configure FOC device */
|
|
|
|
|
|
|
|
ret = foc_dev_setcfg(dev->fd, &cfg);
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
PRINTFV("ERROR: foc_dev_setcfg %d!\n", ret);
|
|
|
|
goto errout;
|
|
|
|
}
|
|
|
|
|
2023-10-20 16:31:27 +02:00
|
|
|
#ifdef CONFIG_EXAMPLES_FOC_PERF
|
|
|
|
/* Initialize perf */
|
|
|
|
|
|
|
|
foc_perf_init(&dev->perf);
|
|
|
|
#endif
|
|
|
|
|
2021-03-03 19:48:19 +01:00
|
|
|
errout:
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************************
|
2021-10-31 11:30:30 +01:00
|
|
|
* Name: foc_device_deinit
|
2021-03-03 19:48:19 +01:00
|
|
|
****************************************************************************/
|
|
|
|
|
2021-10-31 11:30:30 +01:00
|
|
|
int foc_device_deinit(FAR struct foc_device_s *dev)
|
2021-03-03 19:48:19 +01:00
|
|
|
{
|
|
|
|
int ret = OK;
|
|
|
|
|
|
|
|
DEBUGASSERT(dev);
|
|
|
|
|
2021-10-31 10:54:22 +01:00
|
|
|
/* Stop FOC device */
|
|
|
|
|
|
|
|
ret = foc_dev_stop(dev->fd);
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
PRINTF("ERROR: foc_dev_stop %d!\n", ret);
|
|
|
|
}
|
|
|
|
|
2021-03-03 19:48:19 +01:00
|
|
|
if (dev->fd > 0)
|
|
|
|
{
|
|
|
|
close(dev->fd);
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
2021-10-31 11:30:30 +01:00
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: foc_device_start
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
int foc_device_start(FAR struct foc_device_s *dev, bool state)
|
|
|
|
{
|
|
|
|
int ret = OK;
|
|
|
|
|
|
|
|
DEBUGASSERT(dev);
|
|
|
|
|
|
|
|
if (state == true)
|
|
|
|
{
|
|
|
|
ret = foc_dev_start(dev->fd);
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
PRINTFV("ERROR: foc_dev_start failed %d!\n", ret);
|
|
|
|
goto errout;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
ret = foc_dev_stop(dev->fd);
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
PRINTFV("ERROR: foc_dev_stop failed %d!\n", ret);
|
|
|
|
goto errout;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
errout:
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: foc_dev_state_get
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
int foc_dev_state_get(FAR struct foc_device_s *dev)
|
|
|
|
{
|
|
|
|
int ret = OK;
|
|
|
|
|
|
|
|
DEBUGASSERT(dev);
|
|
|
|
|
|
|
|
/* Get FOC state - blocking */
|
|
|
|
|
|
|
|
ret = foc_dev_getstate(dev->fd, &dev->state);
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
PRINTFV("ERROR: foc_dev_getstate failed %d!\n", ret);
|
|
|
|
goto errout;
|
|
|
|
}
|
|
|
|
|
2023-10-20 16:31:27 +02:00
|
|
|
#ifdef CONFIG_EXAMPLES_FOC_PERF
|
|
|
|
foc_perf_start(&dev->perf);
|
|
|
|
#endif
|
|
|
|
|
2021-10-31 11:30:30 +01:00
|
|
|
errout:
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: foc_dev_params_set
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
int foc_dev_params_set(FAR struct foc_device_s *dev)
|
|
|
|
{
|
|
|
|
int ret = OK;
|
|
|
|
|
|
|
|
DEBUGASSERT(dev);
|
|
|
|
|
|
|
|
/* Write FOC parameters */
|
|
|
|
|
|
|
|
ret = foc_dev_setparams(dev->fd, &dev->params);
|
|
|
|
if (ret < 0)
|
|
|
|
{
|
|
|
|
PRINTFV("ERROR: foc_dev_setparams failed %d!\n", ret);
|
|
|
|
goto errout;
|
|
|
|
}
|
|
|
|
|
2023-10-20 16:31:27 +02:00
|
|
|
#ifdef CONFIG_EXAMPLES_FOC_PERF
|
|
|
|
foc_perf_end(&dev->perf);
|
|
|
|
#endif
|
|
|
|
|
2021-10-31 11:30:30 +01:00
|
|
|
errout:
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: foc_dev_state_handle
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
int foc_dev_state_handle(FAR struct foc_device_s *dev, FAR bool *flag)
|
|
|
|
{
|
|
|
|
int ret = OK;
|
|
|
|
|
|
|
|
DEBUGASSERT(dev);
|
|
|
|
DEBUGASSERT(flag);
|
|
|
|
|
|
|
|
if (dev->state.fault > 0)
|
|
|
|
{
|
|
|
|
PRINTF("FAULT = %d\n", dev->state.fault);
|
|
|
|
*flag = true;
|
|
|
|
|
|
|
|
/* Clear fault state */
|
|
|
|
|
|
|
|
ret = foc_dev_clearfault(dev->fd);
|
|
|
|
if (ret != OK)
|
|
|
|
{
|
|
|
|
goto errout;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
*flag = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
errout:
|
|
|
|
return ret;
|
|
|
|
}
|