Code Monkey home page Code Monkey logo

yoctolib_cpp's Introduction

Yoctopuce library for C++ v2.0

License information

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.

Content of this package

  • 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)
    

Installation

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 !

Linux Notes

Libusb 1.0

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".

Configure udev access rights

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"

License Notice for Mbed TLS Library

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

Contributors

franck-madelin avatar ludovicrousseau avatar sblanchet avatar stuart8c avatar yoctopuce avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar

yoctolib_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

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.

YMeasure(double start, double end, double minVal, double avgVal, double maxVal);

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.

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.

localhost_4445_webapp.pdf

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.hbut 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".

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.

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 photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo 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.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.