Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
F
Firmware
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Alberto Ruiz Garcia
Firmware
Commits
e18fe0a8
Commit
e18fe0a8
authored
8 years ago
by
Lorenz Meier
Browse files
Options
Downloads
Patches
Plain Diff
Port PWM command to POSIX
parent
8fd27fdd
No related branches found
Branches containing commit
No related tags found
Tags containing commit
No related merge requests found
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
src/systemcmds/pwm/pwm.c
+160
-113
160 additions, 113 deletions
src/systemcmds/pwm/pwm.c
with
160 additions
and
113 deletions
src/systemcmds/pwm/pwm.c
+
160
−
113
View file @
e18fe0a8
...
@@ -38,6 +38,8 @@
...
@@ -38,6 +38,8 @@
*/
*/
#include
<px4_config.h>
#include
<px4_config.h>
#include
<px4_tasks.h>
#include
<px4_posix.h>
#include
<stdio.h>
#include
<stdio.h>
#include
<stdlib.h>
#include
<stdlib.h>
...
@@ -49,7 +51,9 @@
...
@@ -49,7 +51,9 @@
#include
<sys/ioctl.h>
#include
<sys/ioctl.h>
#include
<sys/stat.h>
#include
<sys/stat.h>
#ifdef __PX4_NUTTX
#include
<nuttx/fs/ioctl.h>
#include
<nuttx/fs/ioctl.h>
#endif
#include
<arch/board/board.h>
#include
<arch/board/board.h>
...
@@ -69,44 +73,44 @@ usage(const char *reason)
...
@@ -69,44 +73,44 @@ usage(const char *reason)
warnx
(
"%s"
,
reason
);
warnx
(
"%s"
,
reason
);
}
}
errx
(
1
,
PX4_INFO
(
"usage:
\n
"
"usage:
\n
"
"pwm arm|disarm|rate|failsafe|disarmed|min|max|test|steps|info ...
\n
"
"pwm arm|disarm|rate|failsafe|disarmed|min|max|test|steps|info ...
\n
"
"
\n
"
"
\n
"
"arm
\t\t\t\t
Arm output
\n
"
"arm
\t\t\t\t
Arm output
\n
"
"disarm
\t\t\t\t
Disarm output
\n
"
"disarm
\t\t\t\t
Disarm output
\n
"
"
\n
"
"
\n
"
"rate ...
\t\t\t
Configure PWM rates
\n
"
"rate ...
\t\t\t
Configure PWM rates
\n
"
"
\t
[-g <channel group>]
\t
(e.g. 0,1,2)
\n
"
"
\t
[-g <channel group>]
\t
(e.g. 0,1,2)
\n
"
"
\t
[-m <channel mask> ]
\t
(e.g. 0xF)
\n
"
"
\t
[-m <channel mask> ]
\t
(e.g. 0xF)
\n
"
"
\t
[-a]
\t\t\t
Configure all outputs
\n
"
"
\t
[-a]
\t\t\t
Configure all outputs
\n
"
"
\t
-r <alt_rate>
\t\t
PWM rate (50 to 400 Hz)
\n
"
"
\t
-r <alt_rate>
\t\t
PWM rate (50 to 400 Hz)
\n
"
"
\n
"
"
\n
"
"failsafe ...
\t\t\t
Failsafe PWM
\n
"
"failsafe ...
\t\t\t
Failsafe PWM
\n
"
"disarmed ...
\t\t\t
Disarmed PWM
\n
"
"disarmed ...
\t\t\t
Disarmed PWM
\n
"
"min ...
\t\t\t\t
Minimum PWM
\n
"
"min ...
\t\t\t\t
Minimum PWM
\n
"
"max ...
\t\t\t\t
Maximum PWM
\n
"
"max ...
\t\t\t\t
Maximum PWM
\n
"
// "trim ...\t\t\tTrim PWM\n"
// "trim ...\t\t\tTrim PWM\n"
"
\t
[-e]
\t\t\t
robust error handling
\n
"
"
\t
[-e]
\t\t\t
robust error handling
\n
"
"
\t
[-c <channels>]
\t\t
(e.g. 1234)
\n
"
"
\t
[-c <channels>]
\t\t
(e.g. 1234)
\n
"
"
\t
[-m <channel mask> ]
\t
(e.g. 0xF)
\n
"
"
\t
[-m <channel mask> ]
\t
(e.g. 0xF)
\n
"
"
\t
[-a]
\t\t\t
Configure all outputs
\n
"
"
\t
[-a]
\t\t\t
Configure all outputs
\n
"
"
\t
-p <pwm value>
\t\t
PWM value
\n
"
"
\t
-p <pwm value>
\t\t
PWM value
\n
"
"
\n
"
"
\n
"
"test ...
\t\t\t
Directly set PWM
\n
"
"test ...
\t\t\t
Directly set PWM
\n
"
"
\t
[-c <channels>]
\t\t
(e.g. 1234)
\n
"
"
\t
[-c <channels>]
\t\t
(e.g. 1234)
\n
"
"
\t
[-m <channel mask> ]
\t
(e.g. 0xF)
\n
"
"
\t
[-m <channel mask> ]
\t
(e.g. 0xF)
\n
"
"
\t
[-a]
\t\t\t
Configure all outputs
\n
"
"
\t
[-a]
\t\t\t
Configure all outputs
\n
"
"
\t
-p <pwm value>
\t\t
PWM value
\n
"
"
\t
-p <pwm value>
\t\t
PWM value
\n
"
"
\n
"
"
\n
"
"steps ...
\t\t\t
Run 5 steps
\n
"
"steps ...
\t\t\t
Run 5 steps
\n
"
"
\t
[-c <channels>]
\t\t
(e.g. 1234)
\n
"
"
\t
[-c <channels>]
\t\t
(e.g. 1234)
\n
"
"
\n
"
"
\n
"
"info
\t\t\t\t
Print information
\n
"
"info
\t\t\t\t
Print information
\n
"
"
\n
"
"
\n
"
"
\t
-v
\t\t\t
Verbose
\n
"
"
\t
-v
\t\t\t
Verbose
\n
"
"
\t
-d <dev>
\t\t
(default "
PWM_OUTPUT0_DEVICE_PATH
")
\n
"
"
\t
-d <dev>
\t\t
(default "
PWM_OUTPUT0_DEVICE_PATH
")
\n
"
);
);
}
}
...
@@ -131,11 +135,13 @@ get_parameter_value(const char *option, const char *paramDescription)
...
@@ -131,11 +135,13 @@ get_parameter_value(const char *option, const char *paramDescription)
result_value
=
pwm_parm
;
result_value
=
pwm_parm
;
}
else
{
}
else
{
errx
(
gret
,
"PARAM '%s' LOAD FAIL"
,
paramDescription
);
PX4_ERR
(
"PARAM '%s' LOAD FAIL"
,
paramDescription
);
return
gret
;
}
}
}
else
{
}
else
{
errx
(
1
,
"PARAM '%s' NAME NOT FOUND"
,
paramName
);
PX4_ERR
(
"PARAM '%s' NAME NOT FOUND"
,
paramName
);
return
1
;
}
}
}
else
{
}
else
{
...
@@ -143,7 +149,8 @@ get_parameter_value(const char *option, const char *paramDescription)
...
@@ -143,7 +149,8 @@ get_parameter_value(const char *option, const char *paramDescription)
result_value
=
strtoul
(
option
,
&
ep
,
0
);
result_value
=
strtoul
(
option
,
&
ep
,
0
);
if
(
*
ep
!=
'\0'
)
{
if
(
*
ep
!=
'\0'
)
{
errx
(
1
,
"BAD '%s'"
,
paramDescription
);
PX4_ERR
(
"BAD '%s'"
,
paramDescription
);
return
1
;
}
}
}
}
...
@@ -170,6 +177,7 @@ pwm_main(int argc, char *argv[])
...
@@ -170,6 +177,7 @@ pwm_main(int argc, char *argv[])
if
(
argc
<
2
)
{
if
(
argc
<
2
)
{
usage
(
NULL
);
usage
(
NULL
);
return
1
;
}
}
while
((
ch
=
getopt
(
argc
-
1
,
&
argv
[
1
],
"d:vec:g:m:ap:r:"
))
!=
EOF
)
{
while
((
ch
=
getopt
(
argc
-
1
,
&
argv
[
1
],
"d:vec:g:m:ap:r:"
))
!=
EOF
)
{
...
@@ -179,6 +187,7 @@ pwm_main(int argc, char *argv[])
...
@@ -179,6 +187,7 @@ pwm_main(int argc, char *argv[])
if
(
NULL
==
strstr
(
optarg
,
"/dev/"
))
{
if
(
NULL
==
strstr
(
optarg
,
"/dev/"
))
{
warnx
(
"device %s not valid"
,
optarg
);
warnx
(
"device %s not valid"
,
optarg
);
usage
(
NULL
);
usage
(
NULL
);
return
1
;
}
}
dev
=
optarg
;
dev
=
optarg
;
...
@@ -209,6 +218,7 @@ pwm_main(int argc, char *argv[])
...
@@ -209,6 +218,7 @@ pwm_main(int argc, char *argv[])
if
((
*
ep
!=
'\0'
)
||
(
group
>=
32
))
{
if
((
*
ep
!=
'\0'
)
||
(
group
>=
32
))
{
usage
(
"bad channel_group value"
);
usage
(
"bad channel_group value"
);
return
1
;
}
}
alt_channel_groups
|=
(
1
<<
group
);
alt_channel_groups
|=
(
1
<<
group
);
...
@@ -222,6 +232,7 @@ pwm_main(int argc, char *argv[])
...
@@ -222,6 +232,7 @@ pwm_main(int argc, char *argv[])
if
(
*
ep
!=
'\0'
)
{
if
(
*
ep
!=
'\0'
)
{
usage
(
"BAD set_mask VAL"
);
usage
(
"BAD set_mask VAL"
);
return
1
;
}
}
break
;
break
;
...
@@ -261,15 +272,16 @@ pwm_main(int argc, char *argv[])
...
@@ -261,15 +272,16 @@ pwm_main(int argc, char *argv[])
}
}
/* open for ioctl only */
/* open for ioctl only */
int
fd
=
open
(
dev
,
0
);
int
fd
=
px4_
open
(
dev
,
0
);
if
(
fd
<
0
)
{
if
(
fd
<
0
)
{
err
(
1
,
"can't open %s"
,
dev
);
PX4_ERR
(
"can't open %s"
,
dev
);
return
1
;
}
}
/* get the number of servo channels */
/* get the number of servo channels */
unsigned
servo_count
;
unsigned
servo_count
;
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_COUNT
,
(
unsigned
long
)
&
servo_count
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_COUNT
,
(
unsigned
long
)
&
servo_count
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
PX4_ERR
(
"PWM_SERVO_GET_COUNT"
);
PX4_ERR
(
"PWM_SERVO_GET_COUNT"
);
...
@@ -278,14 +290,14 @@ pwm_main(int argc, char *argv[])
...
@@ -278,14 +290,14 @@ pwm_main(int argc, char *argv[])
if
(
!
strcmp
(
argv
[
1
],
"arm"
))
{
if
(
!
strcmp
(
argv
[
1
],
"arm"
))
{
/* tell safety that its ok to disable it with the switch */
/* tell safety that its ok to disable it with the switch */
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_ARM_OK
,
0
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_ARM_OK
,
0
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_SET_ARM_OK"
);
err
(
1
,
"PWM_SERVO_SET_ARM_OK"
);
}
}
/* tell IO that the system is armed (it will output values if safety is off) */
/* tell IO that the system is armed (it will output values if safety is off) */
ret
=
ioctl
(
fd
,
PWM_SERVO_ARM
,
0
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_ARM
,
0
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_ARM"
);
err
(
1
,
"PWM_SERVO_ARM"
);
...
@@ -295,11 +307,11 @@ pwm_main(int argc, char *argv[])
...
@@ -295,11 +307,11 @@ pwm_main(int argc, char *argv[])
warnx
(
"Outputs armed"
);
warnx
(
"Outputs armed"
);
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"disarm"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"disarm"
))
{
/* disarm, but do not revoke the SET_ARM_OK flag */
/* disarm, but do not revoke the SET_ARM_OK flag */
ret
=
ioctl
(
fd
,
PWM_SERVO_DISARM
,
0
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_DISARM
,
0
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_DISARM"
);
err
(
1
,
"PWM_SERVO_DISARM"
);
...
@@ -309,13 +321,13 @@ pwm_main(int argc, char *argv[])
...
@@ -309,13 +321,13 @@ pwm_main(int argc, char *argv[])
warnx
(
"Outputs disarmed"
);
warnx
(
"Outputs disarmed"
);
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"rate"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"rate"
))
{
/* change alternate PWM rate */
/* change alternate PWM rate */
if
(
alt_rate
>
0
)
{
if
(
alt_rate
>
0
)
{
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_UPDATE_RATE
,
alt_rate
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_UPDATE_RATE
,
alt_rate
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
PX4_ERR
(
"PWM_SERVO_SET_UPDATE_RATE (check rate for sanity)"
);
PX4_ERR
(
"PWM_SERVO_SET_UPDATE_RATE (check rate for sanity)"
);
...
@@ -325,7 +337,7 @@ pwm_main(int argc, char *argv[])
...
@@ -325,7 +337,7 @@ pwm_main(int argc, char *argv[])
/* directly supplied channel mask */
/* directly supplied channel mask */
if
(
set_mask
>
0
)
{
if
(
set_mask
>
0
)
{
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_SELECT_UPDATE_RATE
,
set_mask
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_SELECT_UPDATE_RATE
,
set_mask
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
PX4_ERR
(
"PWM_SERVO_SET_SELECT_UPDATE_RATE"
);
PX4_ERR
(
"PWM_SERVO_SET_SELECT_UPDATE_RATE"
);
...
@@ -341,7 +353,7 @@ pwm_main(int argc, char *argv[])
...
@@ -341,7 +353,7 @@ pwm_main(int argc, char *argv[])
if
((
1
<<
group
)
&
alt_channel_groups
)
{
if
((
1
<<
group
)
&
alt_channel_groups
)
{
uint32_t
group_mask
;
uint32_t
group_mask
;
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_RATEGROUP
(
group
),
(
unsigned
long
)
&
group_mask
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_RATEGROUP
(
group
),
(
unsigned
long
)
&
group_mask
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
PX4_ERR
(
"PWM_SERVO_GET_RATEGROUP(%u)"
,
group
);
PX4_ERR
(
"PWM_SERVO_GET_RATEGROUP(%u)"
,
group
);
...
@@ -352,7 +364,7 @@ pwm_main(int argc, char *argv[])
...
@@ -352,7 +364,7 @@ pwm_main(int argc, char *argv[])
}
}
}
}
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_SELECT_UPDATE_RATE
,
mask
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_SELECT_UPDATE_RATE
,
mask
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
PX4_ERR
(
"PWM_SERVO_SET_SELECT_UPDATE_RATE"
);
PX4_ERR
(
"PWM_SERVO_SET_SELECT_UPDATE_RATE"
);
...
@@ -360,16 +372,18 @@ pwm_main(int argc, char *argv[])
...
@@ -360,16 +372,18 @@ pwm_main(int argc, char *argv[])
}
}
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"min"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"min"
))
{
if
(
set_mask
==
0
)
{
if
(
set_mask
==
0
)
{
usage
(
"min: no channels set"
);
usage
(
"min: no channels set"
);
return
1
;
}
}
if
(
pwm_value
==
0
)
{
if
(
pwm_value
==
0
)
{
usage
(
"min: no PWM value provided"
);
usage
(
"min: no PWM value provided"
);
return
1
;
}
}
struct
pwm_output_values
pwm_values
;
struct
pwm_output_values
pwm_values
;
...
@@ -379,10 +393,11 @@ pwm_main(int argc, char *argv[])
...
@@ -379,10 +393,11 @@ pwm_main(int argc, char *argv[])
pwm_values
.
channel_count
=
servo_count
;
pwm_values
.
channel_count
=
servo_count
;
/* first get current state before modifying it */
/* first get current state before modifying it */
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_MIN_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_MIN_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
errx
(
ret
,
"failed get min values"
);
PX4_ERR
(
"failed get min values"
);
return
1
;
}
}
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
...
@@ -397,10 +412,11 @@ pwm_main(int argc, char *argv[])
...
@@ -397,10 +412,11 @@ pwm_main(int argc, char *argv[])
if
(
pwm_values
.
channel_count
==
0
)
{
if
(
pwm_values
.
channel_count
==
0
)
{
usage
(
"min: no channels provided"
);
usage
(
"min: no channels provided"
);
return
1
;
}
else
{
}
else
{
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_MIN_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_MIN_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
PX4_ERR
(
"failed setting min values (%d)"
,
ret
);
PX4_ERR
(
"failed setting min values (%d)"
,
ret
);
...
@@ -408,16 +424,18 @@ pwm_main(int argc, char *argv[])
...
@@ -408,16 +424,18 @@ pwm_main(int argc, char *argv[])
}
}
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"max"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"max"
))
{
if
(
set_mask
==
0
)
{
if
(
set_mask
==
0
)
{
usage
(
"no channels set"
);
usage
(
"no channels set"
);
return
1
;
}
}
if
(
pwm_value
==
0
)
{
if
(
pwm_value
==
0
)
{
usage
(
"no PWM value provided"
);
usage
(
"no PWM value provided"
);
return
1
;
}
}
struct
pwm_output_values
pwm_values
;
struct
pwm_output_values
pwm_values
;
...
@@ -427,10 +445,11 @@ pwm_main(int argc, char *argv[])
...
@@ -427,10 +445,11 @@ pwm_main(int argc, char *argv[])
pwm_values
.
channel_count
=
servo_count
;
pwm_values
.
channel_count
=
servo_count
;
/* first get current state before modifying it */
/* first get current state before modifying it */
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_MAX_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_MAX_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
errx
(
ret
,
"failed get max values"
);
PX4_ERR
(
"failed get max values"
);
return
1
;
}
}
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
...
@@ -445,10 +464,11 @@ pwm_main(int argc, char *argv[])
...
@@ -445,10 +464,11 @@ pwm_main(int argc, char *argv[])
if
(
pwm_values
.
channel_count
==
0
)
{
if
(
pwm_values
.
channel_count
==
0
)
{
usage
(
"max: no PWM channels"
);
usage
(
"max: no PWM channels"
);
return
1
;
}
else
{
}
else
{
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_MAX_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_MAX_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
PX4_ERR
(
"failed setting max values (%d)"
,
ret
);
PX4_ERR
(
"failed setting max values (%d)"
,
ret
);
...
@@ -456,12 +476,13 @@ pwm_main(int argc, char *argv[])
...
@@ -456,12 +476,13 @@ pwm_main(int argc, char *argv[])
}
}
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"disarmed"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"disarmed"
))
{
if
(
set_mask
==
0
)
{
if
(
set_mask
==
0
)
{
usage
(
"no channels set"
);
usage
(
"no channels set"
);
return
1
;
}
}
if
(
pwm_value
==
0
)
{
if
(
pwm_value
==
0
)
{
...
@@ -475,10 +496,11 @@ pwm_main(int argc, char *argv[])
...
@@ -475,10 +496,11 @@ pwm_main(int argc, char *argv[])
pwm_values
.
channel_count
=
servo_count
;
pwm_values
.
channel_count
=
servo_count
;
/* first get current state before modifying it */
/* first get current state before modifying it */
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_DISARMED_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_DISARMED_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
errx
(
ret
,
"failed get disarmed values"
);
PX4_ERR
(
"failed get disarmed values"
);
return
ret
;
}
}
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
...
@@ -493,10 +515,11 @@ pwm_main(int argc, char *argv[])
...
@@ -493,10 +515,11 @@ pwm_main(int argc, char *argv[])
if
(
pwm_values
.
channel_count
==
0
)
{
if
(
pwm_values
.
channel_count
==
0
)
{
usage
(
"disarmed: no PWM channels"
);
usage
(
"disarmed: no PWM channels"
);
return
1
;
}
else
{
}
else
{
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_DISARMED_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_DISARMED_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
PX4_ERR
(
"failed setting disarmed values (%d)"
,
ret
);
PX4_ERR
(
"failed setting disarmed values (%d)"
,
ret
);
...
@@ -504,16 +527,18 @@ pwm_main(int argc, char *argv[])
...
@@ -504,16 +527,18 @@ pwm_main(int argc, char *argv[])
}
}
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"failsafe"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"failsafe"
))
{
if
(
set_mask
==
0
)
{
if
(
set_mask
==
0
)
{
usage
(
"no channels set"
);
usage
(
"no channels set"
);
return
1
;
}
}
if
(
pwm_value
==
0
)
{
if
(
pwm_value
==
0
)
{
usage
(
"failsafe: no PWM provided"
);
usage
(
"failsafe: no PWM provided"
);
return
1
;
}
}
struct
pwm_output_values
pwm_values
;
struct
pwm_output_values
pwm_values
;
...
@@ -523,10 +548,11 @@ pwm_main(int argc, char *argv[])
...
@@ -523,10 +548,11 @@ pwm_main(int argc, char *argv[])
pwm_values
.
channel_count
=
servo_count
;
pwm_values
.
channel_count
=
servo_count
;
/* first get current state before modifying it */
/* first get current state before modifying it */
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_FAILSAFE_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_FAILSAFE_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
errx
(
ret
,
"failed get failsafe values"
);
PX4_ERR
(
"failed get failsafe values"
);
return
1
;
}
}
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
...
@@ -541,26 +567,30 @@ pwm_main(int argc, char *argv[])
...
@@ -541,26 +567,30 @@ pwm_main(int argc, char *argv[])
if
(
pwm_values
.
channel_count
==
0
)
{
if
(
pwm_values
.
channel_count
==
0
)
{
usage
(
"failsafe: no PWM channels"
);
usage
(
"failsafe: no PWM channels"
);
return
1
;
}
else
{
}
else
{
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_FAILSAFE_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_FAILSAFE_PWM
,
(
long
unsigned
int
)
&
pwm_values
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
errx
(
ret
,
"BAD input VAL"
);
PX4_ERR
(
"BAD input VAL"
);
return
1
;
}
}
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"test"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"test"
))
{
if
(
set_mask
==
0
)
{
if
(
set_mask
==
0
)
{
usage
(
"no channels set"
);
usage
(
"no channels set"
);
return
1
;
}
}
if
(
pwm_value
==
0
)
{
if
(
pwm_value
==
0
)
{
usage
(
"no PWM provided"
);
usage
(
"no PWM provided"
);
return
1
;
}
}
/* get current servo values */
/* get current servo values */
...
@@ -569,10 +599,11 @@ pwm_main(int argc, char *argv[])
...
@@ -569,10 +599,11 @@ pwm_main(int argc, char *argv[])
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
ret
=
ioctl
(
fd
,
PWM_SERVO_GET
(
i
),
(
unsigned
long
)
&
last_spos
.
values
[
i
]);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET
(
i
),
(
unsigned
long
)
&
last_spos
.
values
[
i
]);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_GET(%d)"
,
i
);
PX4_ERR
(
"PWM_SERVO_GET(%d)"
,
i
);
return
1
;
}
}
}
}
...
@@ -588,10 +619,11 @@ pwm_main(int argc, char *argv[])
...
@@ -588,10 +619,11 @@ pwm_main(int argc, char *argv[])
while
(
1
)
{
while
(
1
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
if
(
set_mask
&
1
<<
i
)
{
if
(
set_mask
&
1
<<
i
)
{
ret
=
ioctl
(
fd
,
PWM_SERVO_SET
(
i
),
pwm_value
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET
(
i
),
pwm_value
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_SET(%d)"
,
i
);
PX4_ERR
(
"PWM_SERVO_SET(%d)"
,
i
);
return
1
;
}
}
}
}
}
}
...
@@ -608,29 +640,31 @@ pwm_main(int argc, char *argv[])
...
@@ -608,29 +640,31 @@ pwm_main(int argc, char *argv[])
/* reset output to the last value */
/* reset output to the last value */
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
if
(
set_mask
&
1
<<
i
)
{
if
(
set_mask
&
1
<<
i
)
{
ret
=
ioctl
(
fd
,
PWM_SERVO_SET
(
i
),
last_spos
.
values
[
i
]);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET
(
i
),
last_spos
.
values
[
i
]);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_SET(%d)"
,
i
);
PX4_ERR
(
"PWM_SERVO_SET(%d)"
,
i
);
return
1
;
}
}
}
}
}
}
warnx
(
"User abort
\n
"
);
warnx
(
"User abort
\n
"
);
exit
(
0
)
;
return
0
;
}
}
}
}
usleep
(
2000
);
usleep
(
2000
);
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"steps"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"steps"
))
{
if
(
set_mask
==
0
)
{
if
(
set_mask
==
0
)
{
usage
(
"no channels set"
);
usage
(
"no channels set"
);
return
1
;
}
}
/* get current servo values */
/* get current servo values */
...
@@ -638,10 +672,11 @@ pwm_main(int argc, char *argv[])
...
@@ -638,10 +672,11 @@ pwm_main(int argc, char *argv[])
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
ret
=
ioctl
(
fd
,
PWM_SERVO_GET
(
i
),
(
unsigned
long
)
&
last_spos
.
values
[
i
]);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET
(
i
),
(
unsigned
long
)
&
last_spos
.
values
[
i
]);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_GET(%d)"
,
i
);
PX4_ERR
(
"PWM_SERVO_GET(%d)"
,
i
);
return
1
;
}
}
}
}
...
@@ -687,10 +722,11 @@ pwm_main(int argc, char *argv[])
...
@@ -687,10 +722,11 @@ pwm_main(int argc, char *argv[])
val
=
off
;
val
=
off
;
}
}
ret
=
ioctl
(
fd
,
PWM_SERVO_SET
(
i
),
val
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET
(
i
),
val
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_SET(%d)"
,
i
);
PX4_ERR
(
"PWM_SERVO_SET(%d)"
,
i
);
return
1
;
}
}
}
}
}
}
...
@@ -707,16 +743,17 @@ pwm_main(int argc, char *argv[])
...
@@ -707,16 +743,17 @@ pwm_main(int argc, char *argv[])
/* reset output to the last value */
/* reset output to the last value */
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
if
(
set_mask
&
1
<<
i
)
{
if
(
set_mask
&
1
<<
i
)
{
ret
=
ioctl
(
fd
,
PWM_SERVO_SET
(
i
),
last_spos
.
values
[
i
]);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET
(
i
),
last_spos
.
values
[
i
]);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_SET(%d)"
,
i
);
PX4_ERR
(
"PWM_SERVO_SET(%d)"
,
i
);
return
1
;
}
}
}
}
}
}
warnx
(
"User abort
\n
"
);
warnx
(
"User abort
\n
"
);
exit
(
0
)
;
return
0
;
}
}
}
}
...
@@ -742,7 +779,7 @@ pwm_main(int argc, char *argv[])
...
@@ -742,7 +779,7 @@ pwm_main(int argc, char *argv[])
}
}
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"info"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"info"
))
{
...
@@ -753,22 +790,25 @@ pwm_main(int argc, char *argv[])
...
@@ -753,22 +790,25 @@ pwm_main(int argc, char *argv[])
uint32_t
info_alt_rate
;
uint32_t
info_alt_rate
;
uint32_t
info_alt_rate_mask
;
uint32_t
info_alt_rate_mask
;
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_DEFAULT_UPDATE_RATE
,
(
unsigned
long
)
&
info_default_rate
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_DEFAULT_UPDATE_RATE
,
(
unsigned
long
)
&
info_default_rate
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_GET_DEFAULT_UPDATE_RATE"
);
PX4_ERR
(
"PWM_SERVO_GET_DEFAULT_UPDATE_RATE"
);
return
1
;
}
}
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_UPDATE_RATE
,
(
unsigned
long
)
&
info_alt_rate
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_UPDATE_RATE
,
(
unsigned
long
)
&
info_alt_rate
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_GET_UPDATE_RATE"
);
PX4_ERR
(
"PWM_SERVO_GET_UPDATE_RATE"
);
return
1
;
}
}
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_SELECT_UPDATE_RATE
,
(
unsigned
long
)
&
info_alt_rate_mask
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_SELECT_UPDATE_RATE
,
(
unsigned
long
)
&
info_alt_rate_mask
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_GET_SELECT_UPDATE_RATE"
);
PX4_ERR
(
"PWM_SERVO_GET_SELECT_UPDATE_RATE"
);
return
1
;
}
}
struct
pwm_output_values
failsafe_pwm
;
struct
pwm_output_values
failsafe_pwm
;
...
@@ -781,41 +821,46 @@ pwm_main(int argc, char *argv[])
...
@@ -781,41 +821,46 @@ pwm_main(int argc, char *argv[])
struct
pwm_output_values
trim_pwm
;
struct
pwm_output_values
trim_pwm
;
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_FAILSAFE_PWM
,
(
unsigned
long
)
&
failsafe_pwm
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_FAILSAFE_PWM
,
(
unsigned
long
)
&
failsafe_pwm
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_GET_FAILSAFE_PWM"
);
PX4_ERR
(
"PWM_SERVO_GET_FAILSAFE_PWM"
);
return
1
;
}
}
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_DISARMED_PWM
,
(
unsigned
long
)
&
disarmed_pwm
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_DISARMED_PWM
,
(
unsigned
long
)
&
disarmed_pwm
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_GET_DISARMED_PWM"
);
PX4_ERR
(
"PWM_SERVO_GET_DISARMED_PWM"
);
return
1
;
}
}
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_MIN_PWM
,
(
unsigned
long
)
&
min_pwm
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_MIN_PWM
,
(
unsigned
long
)
&
min_pwm
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_GET_MIN_PWM"
);
PX4_ERR
(
"PWM_SERVO_GET_MIN_PWM"
);
return
1
;
}
}
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_MAX_PWM
,
(
unsigned
long
)
&
max_pwm
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_MAX_PWM
,
(
unsigned
long
)
&
max_pwm
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_GET_MAX_PWM"
);
PX4_ERR
(
"PWM_SERVO_GET_MAX_PWM"
);
return
1
;
}
}
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_TRIM_PWM
,
(
unsigned
long
)
&
trim_pwm
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_TRIM_PWM
,
(
unsigned
long
)
&
trim_pwm
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
err
(
1
,
"PWM_SERVO_GET_TRIM_PWM"
);
PX4_ERR
(
"PWM_SERVO_GET_TRIM_PWM"
);
return
1
;
}
}
/* print current servo values */
/* print current servo values */
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
servo_position_t
spos
;
servo_position_t
spos
;
ret
=
ioctl
(
fd
,
PWM_SERVO_GET
(
i
),
(
unsigned
long
)
&
spos
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET
(
i
),
(
unsigned
long
)
&
spos
);
if
(
ret
==
OK
)
{
if
(
ret
==
OK
)
{
printf
(
"channel %u: %u us"
,
i
+
1
,
spos
);
printf
(
"channel %u: %u us"
,
i
+
1
,
spos
);
...
@@ -842,7 +887,7 @@ pwm_main(int argc, char *argv[])
...
@@ -842,7 +887,7 @@ pwm_main(int argc, char *argv[])
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
servo_count
;
i
++
)
{
uint32_t
group_mask
;
uint32_t
group_mask
;
ret
=
ioctl
(
fd
,
PWM_SERVO_GET_RATEGROUP
(
i
),
(
unsigned
long
)
&
group_mask
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_GET_RATEGROUP
(
i
),
(
unsigned
long
)
&
group_mask
);
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
break
;
break
;
...
@@ -860,22 +905,23 @@ pwm_main(int argc, char *argv[])
...
@@ -860,22 +905,23 @@ pwm_main(int argc, char *argv[])
}
}
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"forcefail"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"forcefail"
))
{
if
(
argc
<
3
)
{
if
(
argc
<
3
)
{
errx
(
1
,
"arg missing [on|off]"
);
PX4_ERR
(
"arg missing [on|off]"
);
return
1
;
}
else
{
}
else
{
if
(
!
strcmp
(
argv
[
2
],
"on"
))
{
if
(
!
strcmp
(
argv
[
2
],
"on"
))
{
/* force failsafe */
/* force failsafe */
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_FORCE_FAILSAFE
,
1
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_FORCE_FAILSAFE
,
1
);
}
else
{
}
else
{
/* force failsafe */
/* force failsafe */
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_FORCE_FAILSAFE
,
0
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_FORCE_FAILSAFE
,
0
);
}
}
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
...
@@ -883,22 +929,23 @@ pwm_main(int argc, char *argv[])
...
@@ -883,22 +929,23 @@ pwm_main(int argc, char *argv[])
}
}
}
}
exit
(
0
)
;
return
0
;
}
else
if
(
!
strcmp
(
argv
[
1
],
"terminatefail"
))
{
}
else
if
(
!
strcmp
(
argv
[
1
],
"terminatefail"
))
{
if
(
argc
<
3
)
{
if
(
argc
<
3
)
{
errx
(
1
,
"arg missing [on|off]"
);
PX4_ERR
(
"arg missing [on|off]"
);
return
1
;
}
else
{
}
else
{
if
(
!
strcmp
(
argv
[
2
],
"on"
))
{
if
(
!
strcmp
(
argv
[
2
],
"on"
))
{
/* force failsafe */
/* force failsafe */
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_TERMINATION_FAILSAFE
,
1
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_TERMINATION_FAILSAFE
,
1
);
}
else
{
}
else
{
/* force failsafe */
/* force failsafe */
ret
=
ioctl
(
fd
,
PWM_SERVO_SET_TERMINATION_FAILSAFE
,
0
);
ret
=
px4_
ioctl
(
fd
,
PWM_SERVO_SET_TERMINATION_FAILSAFE
,
0
);
}
}
if
(
ret
!=
OK
)
{
if
(
ret
!=
OK
)
{
...
@@ -906,7 +953,7 @@ pwm_main(int argc, char *argv[])
...
@@ -906,7 +953,7 @@ pwm_main(int argc, char *argv[])
}
}
}
}
exit
(
0
)
;
return
0
;
}
}
usage
(
NULL
);
usage
(
NULL
);
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment