Copyright (C) 2011 and beyond by Yoctopuce Sarl, Switzerland.
Yoctopuce Sarl (hereafter Licensor) grants to you a perpetual non-exclusive license to use, modify, copy and integrate this file into your software for the sole purpose of interfacing with Yoctopuce products.
You may reproduce and distribute copies of this file in source or object form, as long as the sole purpose of this code is to interface with Yoctopuce products. You must retain this notice in the distributed source file.
You should refer to Yoctopuce General Terms and Conditions for additional information regarding your rights and obligations.
THE SOFTWARE AND DOCUMENTATION ARE PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT SHALL LICENSOR BE LIABLE FOR ANY INCIDENTAL, SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES, LOST PROFITS OR LOST DATA, COST OF PROCUREMENT OF SUBSTITUTE GOODS, TECHNOLOGY OR SERVICES, ANY CLAIMS BY THIRD PARTIES (INCLUDING BUT NOT LIMITED TO ANY DEFENSE THEREOF), ANY CLAIMS FOR INDEMNITY OR CONTRIBUTION, OR OTHER SIMILAR COSTS, WHETHER ASSERTED ON THE BASIS OF CONTRACT, TORT (INCLUDING NEGLIGENCE), BREACH OF WARRANTY, OR OTHERWISE.
-
build.bat
Automated build script for Windows
-
build.sh
Automated build script for UNIX platforms
-
FILES.txt
List of files contained in this archive
-
RELEASE.txt
Release notes
-
Binaries/GNUmakefile
GNU Makefile for all platforms
-
Binaries/make.bat
Batch to start make on Windows with right paths
-
Binaries/windows/
Directory that contains Windows 32 bits executables
-
Binaries/windows/amd64
Directory that contains Windows 64 bitsexecutables
-
Binaries/osx/
Directory that contains Max OS X executables
-
Binaries/linux/i386/
Directory that contains Linux Intel 32bit executables
-
Binaries/linux/x86_64/
Directory that contains Linux Intel 64bit executables
-
Binaries/linux/armel/
Directory that contains Linux ARM soft float executables
-
Binaries/linux/armhf/
Directory that contains Linux ARM hard float executables
-
Binaries/linux/aarch64/
Directory that contains Linux ARM 64 bits executables
-
Documentation/
API Reference, in HTML and PDF format
-
Examples/
Directory with sample programs in C++
-
Sources/
Source code of the high-level library (in C++)
-
Sources/yapi/
Source code of the low-level library (in C)
-
Sources/yapi/mbedtls
Source code of mbedTLS library (used for encryption)
-
udev_conf/
Udev rules for Linux (see Linux Release Notes)
The archive is shipped without precompiled libraries. If you want to build them from source, or to compile the examples, use the following command:
on Windows: build
build
on UNIX:
./build.sh
For more details, refer to the documentation specific to each product, which includes sample code with explanations, and a programming reference manual. In case of trouble, contact [email protected]
Have fun !
In order to compile the library you have to install the version 1.0 of libusb. Take care to use version 1.0 and not version 0.1. To install libusb 1.0 on Ubuntu, run "sudo apt-get install libusb-1.0-0-dev".
In order to work properly, the Yoctopuce VirtualHub and library need write access to all Yoctopuce devices. By default, Linux access rights for USB device are read only for all users, except root. If you want to avoid running VirtualHub as root, you need to add a new rule to your udev configuration.
To add a new udev rules to your Linux installation, you need to create a text file in the directory "/etc/udev/rules.d" following the naming pattern "##- arbitraryName.rules". Upon startup, udev will process all files in this directory with the extension ".rules" according to there alphabetical order. For instance, the file "51-first.rules" will be processed before the file "50- udev-default.rules". The file "50-udev-default.rules" is actually used to implement the default rules of the system. Therefore, to modify the default handling behaviour of the system, you have to create a file that start with a number lower than 50. Note that to add a rules to your udev configuration you have to be root.
In the sub directory udev_conf we have put two examples of rules that you can use as reference for your rules.
Example 1: 51-yoctopuce.rules
This rule will add write access to Yoctopuce USB devices for all users. Access rights for all other devices will be left unchanged. If this is what you want, copy the file "51-yoctopuce_all.rules" to the directory "/etc/udev/rules.d" and restart your system.
# udev rules to allow write access to all users for Yoctopuce USB devices
SUBSYSTEM=="usb", ATTR{idVendor}=="24e0", MODE="0666"
Example 2: 51-yoctopuce_group.rules
This rule will allow write access to Yoctopuce USB devices for all users of the group "yoctogoup". Access right for all other devices will be left unchanged. If this is what you want, you need to copy the file "51- yoctopuce_all.rules" to the directory "/etc/udev/rules.d" and restart your system.
# udev rules to allow write access to all users of "yoctogroup" for Yoctopuce USB devices
SUBSYSTEM=="usb", ATTR{idVendor}=="24e0", MODE="0664", GROUP="yoctogroup"
Yoctopuce library for C++ v2.0 uses Mbed TLS Library, which is subject to Apache License 2.0.
Apache License
Version 2.0, January 2004
http://www.apache.org/licenses/
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
1. Definitions.
"License" shall mean the terms and conditions for use, reproduction,
and distribution as defined by Sections 1 through 9 of this document.
"Licensor" shall mean the copyright owner or entity authorized by
the copyright owner that is granting the License.
"Legal Entity" shall mean the union of the acting entity and all
other entities that control, are controlled by, or are under common
control with that entity. For the purposes of this definition,
"control" means (i) the power, direct or indirect, to cause the
direction or management of such entity, whether by contract or
otherwise, or (ii) ownership of fifty percent (50%) or more of the
outstanding shares, or (iii) beneficial ownership of such entity.
"You" (or "Your") shall mean an individual or Legal Entity
exercising permissions granted by this License.
"Source" form shall mean the preferred form for making modifications,
including but not limited to software source code, documentation
source, and configuration files.
"Object" form shall mean any form resulting from mechanical
transformation or translation of a Source form, including but
not limited to compiled object code, generated documentation,
and conversions to other media types.
"Work" shall mean the work of authorship, whether in Source or
Object form, made available under the License, as indicated by a
copyright notice that is included in or attached to the work
(an example is provided in the Appendix below).
"Derivative Works" shall mean any work, whether in Source or Object
form, that is based on (or derived from) the Work and for which the
editorial revisions, annotations, elaborations, or other modifications
represent, as a whole, an original work of authorship. For the purposes
of this License, Derivative Works shall not include works that remain
separable from, or merely link (or bind by name) to the interfaces of,
the Work and Derivative Works thereof.
"Contribution" shall mean any work of authorship, including
the original version of the Work and any modifications or additions
to that Work or Derivative Works thereof, that is intentionally
submitted to Licensor for inclusion in the Work by the copyright owner
or by an individual or Legal Entity authorized to submit on behalf of
the copyright owner. For the purposes of this definition, "submitted"
means any form of electronic, verbal, or written communication sent
to the Licensor or its representatives, including but not limited to
communication on electronic mailing lists, source code control systems,
and issue tracking systems that are managed by, or on behalf of, the
Licensor for the purpose of discussing and improving the Work, but
excluding communication that is conspicuously marked or otherwise
designated in writing by the copyright owner as "Not a Contribution."
"Contributor" shall mean Licensor and any individual or Legal Entity
on behalf of whom a Contribution has been received by Licensor and
subsequently incorporated within the Work.
2. Grant of Copyright License. Subject to the terms and conditions of
this License, each Contributor hereby grants to You a perpetual,
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
copyright license to reproduce, prepare Derivative Works of,
publicly display, publicly perform, sublicense, and distribute the
Work and such Derivative Works in Source or Object form.
3. Grant of Patent License. Subject to the terms and conditions of
this License, each Contributor hereby grants to You a perpetual,
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
(except as stated in this section) patent license to make, have made,
use, offer to sell, sell, import, and otherwise transfer the Work,
where such license applies only to those patent claims licensable
by such Contributor that are necessarily infringed by their
Contribution(s) alone or by combination of their Contribution(s)
with the Work to which such Contribution(s) was submitted. If You
institute patent litigation against any entity (including a
cross-claim or counterclaim in a lawsuit) alleging that the Work
or a Contribution incorporated within the Work constitutes direct
or contributory patent infringement, then any patent licenses
granted to You under this License for that Work shall terminate
as of the date such litigation is filed.
4. Redistribution. You may reproduce and distribute copies of the
Work or Derivative Works thereof in any medium, with or without
modifications, and in Source or Object form, provided that You
meet the following conditions:
(a) You must give any other recipients of the Work or
Derivative Works a copy of this License; and
(b) You must cause any modified files to carry prominent notices
stating that You changed the files; and
(c) You must retain, in the Source form of any Derivative Works
that You distribute, all copyright, patent, trademark, and
attribution notices from the Source form of the Work,
excluding those notices that do not pertain to any part of
the Derivative Works; and
(d) If the Work includes a "NOTICE" text file as part of its
distribution, then any Derivative Works that You distribute must
include a readable copy of the attribution notices contained
within such NOTICE file, excluding those notices that do not
pertain to any part of the Derivative Works, in at least one
of the following places: within a NOTICE text file distributed
as part of the Derivative Works; within the Source form or
documentation, if provided along with the Derivative Works; or,
within a display generated by the Derivative Works, if and
wherever such third-party notices normally appear. The contents
of the NOTICE file are for informational purposes only and
do not modify the License. You may add Your own attribution
notices within Derivative Works that You distribute, alongside
or as an addendum to the NOTICE text from the Work, provided
that such additional attribution notices cannot be construed
as modifying the License.
You may add Your own copyright statement to Your modifications and
may provide additional or different license terms and conditions
for use, reproduction, or distribution of Your modifications, or
for any such Derivative Works as a whole, provided Your use,
reproduction, and distribution of the Work otherwise complies with
the conditions stated in this License.
5. Submission of Contributions. Unless You explicitly state otherwise,
any Contribution intentionally submitted for inclusion in the Work
by You to the Licensor shall be under the terms and conditions of
this License, without any additional terms or conditions.
Notwithstanding the above, nothing herein shall supersede or modify
the terms of any separate license agreement you may have executed
with Licensor regarding such Contributions.
6. Trademarks. This License does not grant permission to use the trade
names, trademarks, service marks, or product names of the Licensor,
except as required for reasonable and customary use in describing the
origin of the Work and reproducing the content of the NOTICE file.
7. Disclaimer of Warranty. Unless required by applicable law or
agreed to in writing, Licensor provides the Work (and each
Contributor provides its Contributions) on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
implied, including, without limitation, any warranties or conditions
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
PARTICULAR PURPOSE. You are solely responsible for determining the
appropriateness of using or redistributing the Work and assume any
risks associated with Your exercise of permissions under this License.
8. Limitation of Liability. In no event and under no legal theory,
whether in tort (including negligence), contract, or otherwise,
unless required by applicable law (such as deliberate and grossly
negligent acts) or agreed to in writing, shall any Contributor be
liable to You for damages, including any direct, indirect, special,
incidental, or consequential damages of any character arising as a
result of this License or out of the use or inability to use the
Work (including but not limited to damages for loss of goodwill,
work stoppage, computer failure or malfunction, or any and all
other commercial damages or losses), even if such Contributor
has been advised of the possibility of such damages.
9. Accepting Warranty or Additional Liability. While redistributing
the Work or Derivative Works thereof, You may choose to offer,
and charge a fee for, acceptance of support, warranty, indemnity,
or other liability obligations and/or rights consistent with this
License. However, in accepting such obligations, You may act only
on Your own behalf and on Your sole responsibility, not on behalf
of any other Contributor, and only if You agree to indemnify,
defend, and hold each Contributor harmless for any liability
incurred by, or claims asserted against, such Contributor by reason
of your accepting any such warranty or additional liability.
END OF TERMS AND CONDITIONS
APPENDIX: How to apply the Apache License to your work.
To apply the Apache License to your work, attach the following
boilerplate notice, with the fields enclosed by brackets "[]"
replaced with your own identifying information. (Don't include
the brackets!) The text should be enclosed in the appropriate
comment syntax for the file format. We also recommend that a
file or class name and description of purpose be included on the
same "printed page" as the copyright notice for easier
identification within third-party archives.
Copyright [yyyy] [name of copyright owner]
Licensed 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.
yoctolib_cpp's People
Forkers
rymurr ludovicrousseau stuart8c xiaojianwu aurelienballier magnus1973 giapdangle masadri silvenga odyx chantroimoi g-roch thomaswilliamwallace francknos anybotics timgroeneboom peppedxalto cristian-wpyoctolib_cpp's Issues
yFindColorLedCluster() and nextColorLedCluster() throw exception on YRGBLED2 with short serial numbers
We have some YRGBLED2 boards that have 5 character long serial numbers, for example YRGBLED2-C3E16. These boards can not be found using yFindColorLedCluster() or yFirstColorLedCluster() because an exception is thrown. We have lots of boards that look like YRGBLED2-121916 and they all work fine.
I just updated to the latest library release, latest VirtualHub and this is still happening, previously my library was from 2017.
Yocto3D accelerometer sometimes produces bogus readings
Hi,
I'm having some problems with the Yocto3D. I slightly modified the main.cpp for the example code to print out x, y, and z values for the accelerometer and am getting incorrect output. This happens more or less randomly, and whether it works or not seems to be determined at the time the USB cable is connected. That is, if it is working, I can stop and restart the program and everything will continue to work, but if it is producing incorrect output, stopping and restarting the program won't help.
I've seen this on both a 64bit laptop and a 32bit ARM machine, both running Ubuntu 14.04.
This is the output I'm getting for the x, y, and z acceleration values:
teichman@silicon:~/Desktop/yocto$ Examples/Doc-GettingStarted-Yocto-3D/Binary_Linux/64bits/demo any
tilt1
tilt2
compass acc gyro
-23.984 -23.964 -23.587
-23.984 -23.964 -23.587
-23.984 -23.964 -23.587
-23.984 -23.964 -23.587
-23.984 -23.964 -23.587
-23.984 -23.964 -23.587
-23.984 -23.964 -23.587
-23.984 -23.964 -23.587
yocto_dualpower.h: redefinition of enumerator 'Y_POWERSTATE_OFF'
It looks like it is not possible to do:
#include "yocto_display.h"
#include "yocto_dualpower.h"
Both header files define a conflicting enum Y_POWERSTATE_enum
.
One of the error I get is:
In file included from .../main.cpp:3:
.../Sources/yocto_dualpower.h:60:3: error: typedef redefinition with different types ('enum Y_POWERSTATE_enum' vs 'enum Y_POWERSTATE_enum')
} Y_POWERSTATE_enum;
^
In file included from .../main.cpp:2:
.../Sources/yocto_display.h:60:3: note: previous definition is here
} Y_POWERSTATE_enum;
^
Did I missed something?
I also could not find any example using yocto_dualpower.h
For Yocto-3D-V2 it would be nice to have a way to get all sensor results together in a synchronized way
To really use the IMU in an accurate and precise way you need to have some way to guarantee that all the sensor readings are synchronized across the device, for example 3 axis accel and 3 axis gyro.
Currently I don't see a way to do this. Can the firmware in the controller make sure that it keeps synchronized results and the software API provide a way to read these results.
CMAKE install directory
Why are you disallowing me to choose my installation prefix?
if(${CMAKE_SYSTEM_NAME} STREQUAL "Linux")
SET(CMAKE_INSTALL_PREFIX "/usr")
endif()
No install targets in makefile
It would be really nice if there were standard install
targets in the Makefile (or better yet, if you provided a CMakeLists) for yoctolib and yapi. Is there a reason this isn't the case?
In our use case, I'm building the yocto binaries in a Docker container and would really like to be able to run "make install" to copy:
- the headers to '/usr/local/include'
- executables to '/usr/local/bin'
- .so and .a files to '/usr/local/lib'
- other artifacts maybe to '/usr/local/share'
Obviously these targets could vary based on linux distrobution/OS, but the target directories should always be available as variables.
Having the files installed in the OS path as above would greatly simplify my CMakeLists, and be consistent with other packages manually compiled and installed in our Docker containers.
Handle Leak in Linux CPP Source
Extended testing revealed a handle leak in the 1/13/2017 version of Linux CPP source. I fixed it below...well, the handle leak is not occurring anymore anyway.
#define YOCTO_LOCK_PIPE "/tmp/.yoctolock"
// return 1 if we can reserve access to the device 0 if the device
// is already reserved
static int yReserveGlobalAccess(yContextSt *ctx, char *errmsg)
{
int fd;
int chk_val, mypid, usedpid = 0;
size_t res;
mode_t mode=0666;
mode_t oldmode = umask(0000);
char msg[YOCTO_ERRMSG_LEN];
HALLOG("old mode (%#o)\n",oldmode);
HALLOG("create fifo with (%#o)\n",mode);
if(mkfifo(YOCTO_LOCK_PIPE,mode)<0) {
HALLOG("unable to create lock fifo (%d:%s)\n",errno,strerror(errno));
}
umask(oldmode);
fd = open(YOCTO_LOCK_PIPE,O_RDWR|O_NONBLOCK);
if(fd<0){
HALLOG("unable to open lock fifo (%d)\n",errno);
if(errno==EACCES) {
return YERRMSG(YAPI_DOUBLE_ACCES, "we do not have acces to lock fifo");
}else{
// we cannot open lock file so we cannot realy
// check double instance so we asume that we are
// alone
return YAPI_SUCCESS;
}
}
chk_val = 0;
mypid = (int) getpid();
res = read(fd, &chk_val, sizeof(chk_val));
if (res == sizeof(chk_val)) {
//there is allready someone
usedpid = chk_val;
} else{
// nobody there -> store my PID
chk_val = mypid;
}
res = write(fd, &chk_val, sizeof(chk_val));
if(res != sizeof(chk_val)) {
YSPRINTF(msg, YOCTO_ERRMSG_LEN, "Write to lock fifo failed (%d)", res);
close(fd);
return YERRMSG(YAPI_DOUBLE_ACCES, msg);
}
if (usedpid != 0) {
if (usedpid == 1) {
close(fd);
// locked by api that not store the pid
return YERRMSG(YAPI_DOUBLE_ACCES, "Another process is already using yAPI");
} else {
YSPRINTF(msg, YOCTO_ERRMSG_LEN, "Another process (pid %d) is already using yAPI", (u32) usedpid);
close(fd);
return YERRMSG(YAPI_DOUBLE_ACCES, msg);
}
}
close(fd);
return YAPI_SUCCESS;
}
size_t dropwarning;
static void yReleaseGlobalAccess(yContextSt *ctx)
{
int chk_val;
int fd = open(YOCTO_LOCK_PIPE,O_RDWR|O_NONBLOCK);
if(fd>=0){
dropwarning = read(fd,&chk_val,sizeof(chk_val));
close(fd);
}
}
Types in yocto_api.h are missing a virtual destructor
Many classes in yocto_api.h have virtual
methods, but no virtual
destructor. If they are used
polymorphically then this could result in undefined behaviour. See https://github.com/isocpp/CppCoreGuidelines/blob/master/CppCoreGuidelines.md#Rc-dtor-virtual for discussion of the issue.
As an example, the YMeasure
class does not have a virtual
destructor.
yoctolib_cpp/Sources/yocto_api.h
Line 1372 in 42b0c45
I can't find a way to let the compass to read faster
I just looked in the C++ API website but I still can't find a way to let the compass to read faster, is there any way that I can adjust the speed of the compass sensor to read data faster. thanks a lot!
API Request for PWM Rx
Hello,
Would it be possible to add a feature to the PWM Rx firmware to implement a counter which increments every time the pulse count rolls overs? This rollover counter could then be read out via an API call. Of course, the counter is reset to zero on soft/hard reset of the device. Thanks in advance.
Best Regards,
Rob Krakora
Select the sensor fusion mode
I am asking if we could select the fusion mode as described in the BNO055 document section 3.3.3. I don't want absolute orientation because I am operating in an area with a lots of metal and high power electrical circuits. With the magnetometer feeding into the estimation this will basically be useless to me. Maybe you can expose a way to select among the 5 fusion methods?
I am creating this ticket so I know when this feature has been implemented. I feel this is pretty fundamental to the BNO055 and other could benefit from this.
Please add throw specifiers
The method declaration of every method has no throws(foobar)
specified.
Please add them.
ix
Yocto-MaxiThermistor capturing bogus measurements
I have a dozen of your Yocto-MaxiThermistor boards that are connected to computers that record the measurements at 1Hz continuously. After leaving these running for months and now analyzing the logs I find bad temperature measurements.
First I thought maybe this is a glitch in the software but when I look at the VirtualHub page it also shows the Max Temperature updating when then bad measurements occur, so it isn't my software.
Next I thought maybe it is the particular computer setup, so I connected one various boards to various other computers and after monitoring them for just 10 minutes I see the bad measurements.
So my next guess is that the firmware has a timing issue. The bad measurement seems to show up on any and all channels randomly. The attached image shows two channels that have already captured bogus measurements.
Deadlock with two USB PWM Rx devices during extended insertion/removal tests
unit_test-Multitech Debug [C/C++ Remote Application]
unit_test [5558] [cores: 0] (0 filtered running threads)
Thread #1 5558 [core: 0] (Suspended : Signal : SIGINT:Interrupt)
__lll_lock_wait() at lowlevellock.c:46 0xb6fc6a9c
__GI___pthread_mutex_lock() at pthread_mutex_lock.c:114 0xb6fc0ec8
Poco::MutexImpl::lockImpl() at Mutex_POSIX.h:61 0x122fc
Poco::Mutex::lock() at Mutex.h:209 0x124bc
Poco::ScopedLockPoco::Mutex::ScopedLock() at ScopedLock.h:40 0x130c4
PollingThread::Stop() at PollingThread.cpp:27 0x37448
DevicePort::Stop() at DevicePort.h:18 0x350e4
PulsePort::Stop() at PulsePort.cpp:175 0x43338
PulseDevice::Stop() at PulseDevice.cpp:100 0x39ee4
PulseTests_FunctionalTest_Test::TestBody() at PulseTests.cpp:461 0x1cd60
<...more frames...>
Thread #2 6272 [core: 0] (Suspended : Container)
__pthread_cond_wait() at pthread_cond_wait.c:187 0xb6fc383c
Poco::EventImpl::waitImpl() at Event_POSIX.cpp:99 0x6e328
wait() at Event.h:99 0x72f64
Poco::PooledThread::run() at ThreadPool.cpp:193 0x72f64
Poco::(anonymous namespace)::RunnableHolder::run at Thread.cpp:57 0x66354
Poco::ThreadImpl::runnableEntry() at Thread_POSIX.cpp:349 0x66488
start_thread() at pthread_create.c:314 0xb6fbe424
() at clone.S:92 0xb6af6878
() at clone.S:92 0xb6af6878
Thread #3 6273 [core: 0] (Suspended : Container)
__pthread_cond_wait() at pthread_cond_wait.c:187 0xb6fc383c
Poco::EventImpl::waitImpl() at Event_POSIX.cpp:99 0x6e328
wait() at Event.h:99 0x72f64
Poco::PooledThread::run() at ThreadPool.cpp:193 0x72f64
Poco::(anonymous namespace)::RunnableHolder::run at Thread.cpp:57 0x66354
Poco::ThreadImpl::runnableEntry() at Thread_POSIX.cpp:349 0x66488
start_thread() at pthread_create.c:314 0xb6fbe424
() at clone.S:92 0xb6af6878
() at clone.S:92 0xb6af6878
Thread #4 9997 [core: 0] (Suspended : Container)
poll() at syscall-template.S:81 0xb6ae85d0
handle_events() at io.c:1,888 0xb6d15e38
libusb_handle_events_timeout_completed() at io.c:2,024 0xb6d167e8
event_thread() at ypkt_lin.c:254 0xf10b8
start_thread() at pthread_create.c:314 0xb6fbe424
() at clone.S:92 0xb6af6878
() at clone.S:92 0xb6af6878
Thread #5 9998 [core: 0] (Suspended : Container)
__pthread_cond_destroy() at pthread_cond_destroy.c:75 0xb6fc343c
yCloseEvent() at ythread.c:223 0x905e8
yPktQueueFree() at ystream.c:935 0xd60a4
yyyPacketShutdown() at ypkt_lin.c:665 0xf2204
yyPacketSetup() at ystream.c:1,367 0xd719c
yPacketSetup() at ystream.c:1,425 0xd742c
yStreamSetup() at ystream.c:1,538 0xd792c
StartDevice() at ystream.c:2,091 0xd92c8
enuUpdateDStatus() at ystream.c:2,175 0xd9640
yUSBUpdateDeviceList() at ystream.c:2,320 0xda004
yapiUpdateDeviceList_internal() at yapi.c:2,597 0xcf3e8
yapiUpdateDeviceList() at yapi.c:4,385 0xd3d48
YapiWrapper::updateDeviceList() at yocto_api.cpp:3,739 0x9fc20
YDevice::requestAPI() at yocto_api.cpp:2,536 0x9c470
YFunction::isOnline() at yocto_api.cpp:2,239 0x9ab80
PulseDevice::readValue() at PulseDevice.cpp:498 0x3dc78
PulseDevice::UpdateItemValues() at PulseDevice.cpp:192 0x3b39c
PulseDevice::Poll() at PulseDevice.cpp:161 0x3a910
PulsePort::Poll() at PulsePort.cpp:232 0x43d64
PollingThread::Thread() at PollingThread.cpp:68 0x3794c
PollingThread::StaticPollingThread() at PollingThread.cpp:51 0x377e8
Poco::(anonymous namespace)::CallableHolder::run at Thread.cpp:80 0x66368
Poco::ThreadImpl::runnableEntry() at Thread_POSIX.cpp:349 0x66488
start_thread() at pthread_create.c:314 0xb6fbe424
() at clone.S:92 0xb6af6878
() at clone.S:92 0xb6af6878
Thread #6 9999 [core: 0] (Suspended : Container)
__lll_lock_wait() at lowlevellock.c:46 0xb6fc6a9c
__GI___pthread_mutex_lock() at pthread_mutex_lock.c:79 0xb6fc0d20
yEnterCriticalSection() at ythread.c:601 0x90aac
devPauseIO() at ystream.c:496 0xd5750
yUsbReadBlock() at ystream.c:2,832 0xdb358
yapiRequestWaitEndUSB() at yapi.c:3,238 0xd1524
yapiHTTPRequestSyncStartEx_internal() at yapi.c:3,326 0xd18b8
yapiHTTPRequestSyncStartOutOfBand() at yapi.c:4,549 0xd4298
YDevice::HTTPRequest() at yocto_api.cpp:2,501 0x9c140
YDevice::requestAPI() at yocto_api.cpp:2,533 0x9c450
YFunction::isOnline() at yocto_api.cpp:2,239 0x9ab80
PulseDevice::readValue() at PulseDevice.cpp:498 0x3dc78
PulseDevice::UpdateItemValues() at PulseDevice.cpp:192 0x3b39c
PulseDevice::Poll() at PulseDevice.cpp:161 0x3a910
PulsePort::Poll() at PulsePort.cpp:232 0x43d64
PollingThread::Thread() at PollingThread.cpp:68 0x3794c
PollingThread::StaticPollingThread() at PollingThread.cpp:51 0x377e8
Poco::(anonymous namespace)::CallableHolder::run at Thread.cpp:80 0x66368
Poco::ThreadImpl::runnableEntry() at Thread_POSIX.cpp:349 0x66488
start_thread() at pthread_create.c:314 0xb6fbe424
() at clone.S:92 0xb6af6878
() at clone.S:92 0xb6af6878
Remote Shell
/opt/mlinux/3.2.3/sysroots/x86_64-mlinux-linux/usr/bin/arm-mlinux-linux-gnueabi/arm-mlinux-linux-gnueabi-gdb (7.6.2)
Examples: remove the "dirty active wait loop" on Unix
On Unix you do not have to include the "dirty active wait loop" before exiting if the argument of the program is wrong. The error will just be displayed in the console and the user will get the prompt faster.
Maybe the waiting loop is needed on Windows. But on Unix it is just annoying.
Please use something like:
static void usage(void)
{
cout << "usage: demo <serial_number> " << endl;
cout << " demo <logical_name>" << endl;
cout << " demo any (use any discovered device)" << end+++l;
#ifdef WIN32
u64 now = yGetTickCount(); // dirty active wait loop
while (yGetTickCount()-now<3000);
#endif
exit(1);
}
The binary directory for the example code is NOT created by GNUmakefile
$ cd yoctolib_cpp/Examples/Doc-GettingStarted-Yocto-Thermocouple
$ make
/usr/bin/ld: cannot open output file Binary_Linux/32bits/demo: No such file or directory
collect2: error: ld returned 1 exit status
make: *** [Binary_Linux/32bits/demo] Erreur 1
This is because the directory Binary_Linux/32bits/
is never created by the GNUmakefile.
I propose to use something like:
--- /tmp/IAvi8d_GNUmakefile 2013-08-20 23:36:58.000000000 +0200
+++ Examples/Doc-GettingStarted-Yocto-Temperature/GNUmakefile 2013-08-20 23:36:01.000000000 +0200
@@ -96,9 +96,12 @@ endif
endif
-default: $(DEFAULT_BUILD)
+default: make_dir $(DEFAULT_BUILD)
-release: $(RELEASE_BUILD)
+release: make_dir $(RELEASE_BUILD)
+
+make_dir:
+ @mkdir -p $(shell dirname $(DEFAULT_BUILD))
#linux rules
$(DEMO_64) : main.cpp $(YOCTO_API_DIR_64)*
Another option is to store the binary in the current directory and name it like demo_Linux_32bits
without using a sub-directory.
Where is `ui_inventory.h`?
In yoctolib_cpp/Examples/Prog-QT/QTDemo/inventory.cpp, you're including an header called ui_inventory.h
but I can't find it... Am i missing something?
Any random identifier is valid
The following code runs without error:
int main(int argc, const char * argv[])
{
string errmsg;
string target;
YDisplay *disp;
// Setup the API to use local USB devices
if (yRegisterHub("usb", errmsg) != YAPI_SUCCESS) {
cerr << "RegisterHub error: " << errmsg << endl;
return 1;
}
target = "pouet"; // or anything else
disp = yFindDisplay(target + ".display");
if (!disp->isOnline()) {
cout << "Module is offline (check USB cable)" << endl;
return 1;
}
}
I am surprised bu the fact that the target
string can be anything.
I agree that yFindDisplay()
should not return an error. But isOnline()
should return false
when the target value is not correct.
In my case the friendly name of the device (as reported by get_friendlyName()
) is "Yocto-MiniDisplay" not "pouet".
Wrong method name in the documentation: get_displayId()
The documentation (French or English) describes a method display→get_displayId()
but the real method name looks like to be get_functionId()
instead.
Compilation ARMEL demo
There is something I havn't understood.
Every GNUmakefile use the regular g++ to compile arm version of the demos.
Since the lib GNUmakefile is ok, I don't understand what have been done.
I've edited a lot of the GNUmakefile to make the buzzer demo to compile for armel, it was a lot of pain.
YPwmInput::set_pulseCounter() does not work.
YPwmInput::set_pulseCounter(10000) does not work in version of released on 1/13/2017.
"GET /api/pwmInput2/pulseCounter?pulseCounter=100000&. \r\n\r\n"
Do not store compiled files in github
I think that storing in github binary files that are the result of a compilation is wrong:
- it is big (147 MB or 70% of the total size) and is then very slow to fetch from the server
- I always get git conflicts with the versions I rebuild locally
I fully understand that you want to provide pre-built binaries to your customers. But if I use github it is because I want to rebuild from the source code.
I can always use the official .zip
archives if I want to use pre-built binaries.
Building on Raspberry Pi fails: fatal error: gnu/stubs-soft.h: No such file or directory
I have a Raspberry Pi rev 1 model B using Raspbian
$ LANG=C ./build.sh
Build static and dynamic library for C++
========================================
compiling linux/armel/objs/yapi.o
In file included from /usr/include/features.h:398:0,
from /usr/include/stdint.h:25,
from /usr/lib/gcc/arm-linux-gnueabihf/4.9/include/stdint.h:9,
from ../Sources/yapi/ydef.h:191,
from ../Sources/yapi/yapi.h:47,
from ../Sources/yapi/yapi.c:40:
/usr/include/arm-linux-gnueabihf/gnu/stubs.h:7:29: fatal error: gnu/stubs-soft.h: No such file or directory
# include <gnu/stubs-soft.h>
^
compilation terminated.
GNUmakefile:273: recipe for target 'linux/armel/objs/yapi.o' failed
make: *** [linux/armel/objs/yapi.o] Error 1
The patch is simple: LudovicRousseau@da05623
I guess you will have to improve it to use auto detection of the hard/soft option.
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.