Merge branch 'master' of https://github.com/dsiroky/mspdebug into dsiroky-master
This commit is contained in:
commit
1669f758de
|
@ -61,6 +61,9 @@ int bsllib_seq_do(sport_t fd, const char *seq)
|
|||
|
||||
int bsllib_seq_do_gpio(int rts, int dtr, const char *seq)
|
||||
{
|
||||
int was_rts_exported = gpio_is_exported(rts);
|
||||
int was_dtr_exported = gpio_is_exported(dtr);
|
||||
|
||||
gpio_export ( rts );
|
||||
gpio_set_dir ( rts, 1 );
|
||||
gpio_export ( dtr );
|
||||
|
@ -93,8 +96,14 @@ int bsllib_seq_do_gpio(int rts, int dtr, const char *seq)
|
|||
}
|
||||
}
|
||||
|
||||
gpio_unexport ( rts );
|
||||
gpio_unexport ( dtr );
|
||||
if (was_rts_exported == 0)
|
||||
{
|
||||
gpio_unexport ( rts );
|
||||
}
|
||||
if (was_dtr_exported == 0)
|
||||
{
|
||||
gpio_unexport ( dtr );
|
||||
}
|
||||
|
||||
delay_ms(50);
|
||||
|
||||
|
|
|
@ -36,6 +36,7 @@ struct flash_bsl_device {
|
|||
|
||||
sport_t serial_fd;
|
||||
int long_password;
|
||||
const struct device_args *args;
|
||||
|
||||
const char *seq;
|
||||
};
|
||||
|
@ -554,7 +555,15 @@ static void flash_bsl_destroy(device_t dev_base)
|
|||
{
|
||||
struct flash_bsl_device *dev = (struct flash_bsl_device *)dev_base;
|
||||
|
||||
bsllib_seq_do(dev->serial_fd, bsllib_seq_next(dev->seq));
|
||||
if ( dev->args->bsl_gpio_used )
|
||||
{
|
||||
bsllib_seq_do_gpio(dev->args->bsl_gpio_rts, dev->args->bsl_gpio_dtr,
|
||||
bsllib_seq_next(dev->seq));
|
||||
}
|
||||
else
|
||||
{
|
||||
bsllib_seq_do(dev->serial_fd, bsllib_seq_next(dev->seq));
|
||||
}
|
||||
sport_close(dev->serial_fd);
|
||||
free(dev);
|
||||
}
|
||||
|
@ -581,6 +590,7 @@ static device_t flash_bsl_open(const struct device_args *args)
|
|||
|
||||
memset(dev, 0, sizeof(*dev));
|
||||
dev->base.type = &device_flash_bsl;
|
||||
dev->args = args;
|
||||
|
||||
dev->serial_fd = sport_open(args->path, 9600, SPORT_EVEN_PARITY);
|
||||
if (SPORT_ISERR(dev->serial_fd)) {
|
||||
|
|
36
util/gpio.c
36
util/gpio.c
|
@ -18,6 +18,12 @@
|
|||
*
|
||||
* Daniel Beer <dlbeer@gmail.com>, 3 Mar 2015
|
||||
*/
|
||||
int gpio_is_exported ( unsigned int gpio )
|
||||
{
|
||||
printc_err("gpio: GPIO interface not supported on Windows\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
int gpio_export ( unsigned int gpio )
|
||||
{
|
||||
printc_err("gpio: GPIO interface not supported on Windows\n");
|
||||
|
@ -78,6 +84,36 @@ int gpio_open_fd (unsigned int gpio)
|
|||
#define SYSFS_GPIO_DIR "/sys/class/gpio"
|
||||
#define MAX_BUF 64
|
||||
|
||||
/**
|
||||
* @return 1 if the gpio is already exported, 0 otherwise, -1 on error
|
||||
*/
|
||||
int gpio_is_exported ( unsigned int gpio )
|
||||
{
|
||||
char dir_name[100] = {};
|
||||
snprintf(dir_name, sizeof(dir_name) - 1, SYSFS_GPIO_DIR "/gpio%d", gpio);
|
||||
|
||||
struct stat s;
|
||||
int err = stat(dir_name, &s);
|
||||
if(-1 == err)
|
||||
{
|
||||
if(errno == ENOENT)
|
||||
{
|
||||
return 0;
|
||||
} else {
|
||||
return -1;
|
||||
}
|
||||
} else {
|
||||
if(S_ISDIR(s.st_mode))
|
||||
{
|
||||
return 1;
|
||||
} else {
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
/**
|
||||
* Before a Linux application can configure and use a GPIO, the GPIO first has to be exported to user.
|
||||
* Each GPIO is not accessible from user space until the GPIO has been exported.
|
||||
|
|
|
@ -13,6 +13,7 @@
|
|||
#ifndef _GPIO_H
|
||||
#define _GPIO_H
|
||||
|
||||
int gpio_is_exported ( unsigned int gpio );
|
||||
int gpio_export ( unsigned int gpio );
|
||||
int gpio_unexport ( unsigned int gpio );
|
||||
int gpio_set_dir ( unsigned int gpio, unsigned int out_flag );
|
||||
|
|
Loading…
Reference in New Issue