Initialize Tizen 2.3 tizen_2.3 2.3a_release submit/tizen_2.3/20140531.111519
authorSehong Na <sehong.na@samsung.com>
Sat, 31 May 2014 04:00:16 +0000 (13:00 +0900)
committerSehong Na <sehong.na@samsung.com>
Sat, 31 May 2014 04:00:16 +0000 (13:00 +0900)
30 files changed:
AUTHORS [new file with mode: 0644]
CMakeLists.txt [new file with mode: 0644]
LICENSE.LGPLv2.1 [new file with mode: 0644]
NOTICE [new file with mode: 0644]
debian/changelog [new file with mode: 0644]
debian/compat [new file with mode: 0644]
debian/control [new file with mode: 0644]
debian/copyright [new file with mode: 0644]
debian/dirs [new file with mode: 0644]
debian/docs [new file with mode: 0644]
debian/rules [new file with mode: 0755]
debian/sf-plugin-gyro-emul-pkgs.install.in [new file with mode: 0644]
debian/sf-plugin-gyro-emul-pkgs.postinst.in [new file with mode: 0644]
mobile/CMakeLists.txt [new file with mode: 0644]
mobile/processor/CMakeLists.txt [new file with mode: 0644]
mobile/processor/include/gyro_sim_processor.h [new file with mode: 0644]
mobile/processor/src/gyro_sim_processor.cpp [new file with mode: 0644]
mobile/sensor/CMakeLists.txt [new file with mode: 0644]
mobile/sensor/include/cgyro_sim.h [new file with mode: 0644]
mobile/sensor/include/l3g4200d.h [new file with mode: 0644]
mobile/sensor/src/cgyro_sim.cpp [new file with mode: 0644]
packaging/sf-plugin-gyro-emul-pkgs.manifest [new file with mode: 0644]
packaging/sf-plugin-gyro-emul-pkgs.spec [new file with mode: 0644]
wearable/CMakeLists.txt [new file with mode: 0644]
wearable/processor/CMakeLists.txt [new file with mode: 0644]
wearable/processor/include/gyro_sim_processor.h [new file with mode: 0644]
wearable/processor/src/gyro_sim_processor.cpp [new file with mode: 0644]
wearable/sensor/CMakeLists.txt [new file with mode: 0644]
wearable/sensor/include/cgyro_sim.h [new file with mode: 0644]
wearable/sensor/src/cgyro_sim.cpp [new file with mode: 0644]

diff --git a/AUTHORS b/AUTHORS
new file mode 100644 (file)
index 0000000..1722483
--- /dev/null
+++ b/AUTHORS
@@ -0,0 +1,12 @@
+YeongKyoon Lee <yeongkyoon.lee@samsung.com>
+DaiYoung Kim <daiyoung777.kim@samsung.com>
+SeokYeon Hwang <syeon.hwang@samsung.com>
+SangJin Kim <sangjin3.kim@samsung.com>
+KiTae Kim <kt920.kim@samsung.com>
+JinHyung Jo <jinhyung.jo@samsung.com>
+SungMin Ha <sungmin82.ha@samsung.com>
+MunKyu Im <munkyu.im@samsung.com>
+JiHye Kim <jihye1128.kim@samsung.com>
+GiWoong Kim <giwoong.kim@samsung.com>
+SooYoung Ha <yoosah.ha@samsnung.com>
+HyunGoo Kang <hyungoo1.kang@samsung.com>
diff --git a/CMakeLists.txt b/CMakeLists.txt
new file mode 100644 (file)
index 0000000..4c81390
--- /dev/null
@@ -0,0 +1,29 @@
+cmake_minimum_required(VERSION 2.6)
+project(gyro_sim_pkgs CXX)
+
+# to install pkgconfig setup file.
+SET(EXEC_PREFIX "\${prefix}")
+SET(LIBDIR "\${prefix}/lib")
+SET(INCLUDEDIR "\${prefix}/include")
+SET(VERSION 1.0)
+
+set(PROJECT_MAJOR_VERSION "0")
+set(PROJECT_MINOR_VERSION "2")
+set(PROJECT_RELEASE_VERSION "1")
+set(CMAKE_VERBOSE_MAKEFILE OFF)
+
+IF("$ENV{CFLAGS}" MATCHES "-DMOBILE")
+       OPTION(USE_D_MOBILE "Use Mobile Def" ON)
+ENDIF()
+
+IF("$ENV{CFLAGS}" MATCHES "-DWEARABLE")
+       OPTION(USE_D_WEARABLE "Use Wearable Def" ON)
+ENDIF()
+
+IF(USE_D_MOBILE)
+       add_subdirectory(mobile)
+ENDIF()
+
+IF(USE_D_WEARABLE)
+       add_subdirectory(wearable)
+ENDIF()
diff --git a/LICENSE.LGPLv2.1 b/LICENSE.LGPLv2.1
new file mode 100644 (file)
index 0000000..9c92a19
--- /dev/null
@@ -0,0 +1,505 @@
+Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd. All rights reserved.
+
+                  GNU LESSER GENERAL PUBLIC LICENSE
+                       Version 2.1, February 1999
+
+ Copyright (C) 1991, 1999 Free Software Foundation, Inc.
+ 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+[This is the first released version of the Lesser GPL.  It also counts
+ as the successor of the GNU Library Public License, version 2, hence
+ the version number 2.1.]
+
+                            Preamble
+
+  The licenses for most software are designed to take away your
+freedom to share and change it.  By contrast, the GNU General Public
+Licenses are intended to guarantee your freedom to share and change
+free software--to make sure the software is free for all its users.
+
+  This license, the Lesser General Public License, applies to some
+specially designated software packages--typically libraries--of the
+Free Software Foundation and other authors who decide to use it.  You
+can use it too, but we suggest you first think carefully about whether
+this license or the ordinary General Public License is the better
+strategy to use in any particular case, based on the explanations below.
+
+  When we speak of free software, we are referring to freedom of use,
+not price.  Our General Public Licenses are designed to make sure that
+you have the freedom to distribute copies of free software (and charge
+for this service if you wish); that you receive source code or can get
+it if you want it; that you can change the software and use pieces of
+it in new free programs; and that you are informed that you can do
+these things.
+
+  To protect your rights, we need to make restrictions that forbid
+distributors to deny you these rights or to ask you to surrender these
+rights.  These restrictions translate to certain responsibilities for
+you if you distribute copies of the library or if you modify it.
+
+  For example, if you distribute copies of the library, whether gratis
+or for a fee, you must give the recipients all the rights that we gave
+you.  You must make sure that they, too, receive or can get the source
+code.  If you link other code with the library, you must provide
+complete object files to the recipients, so that they can relink them
+with the library after making changes to the library and recompiling
+it.  And you must show them these terms so they know their rights.
+
+  We protect your rights with a two-step method: (1) we copyright the
+library, and (2) we offer you this license, which gives you legal
+permission to copy, distribute and/or modify the library.
+
+  To protect each distributor, we want to make it very clear that
+there is no warranty for the free library.  Also, if the library is
+modified by someone else and passed on, the recipients should know
+that what they have is not the original version, so that the original
+author's reputation will not be affected by problems that might be
+introduced by others.
+
+  Finally, software patents pose a constant threat to the existence of
+any free program.  We wish to make sure that a company cannot
+effectively restrict the users of a free program by obtaining a
+restrictive license from a patent holder.  Therefore, we insist that
+any patent license obtained for a version of the library must be
+consistent with the full freedom of use specified in this license.
+
+  Most GNU software, including some libraries, is covered by the
+ordinary GNU General Public License.  This license, the GNU Lesser
+General Public License, applies to certain designated libraries, and
+is quite different from the ordinary General Public License.  We use
+this license for certain libraries in order to permit linking those
+libraries into non-free programs.
+
+  When a program is linked with a library, whether statically or using
+a shared library, the combination of the two is legally speaking a
+combined work, a derivative of the original library.  The ordinary
+General Public License therefore permits such linking only if the
+entire combination fits its criteria of freedom.  The Lesser General
+Public License permits more lax criteria for linking other code with
+the library.
+
+  We call this license the "Lesser" General Public License because it
+does Less to protect the user's freedom than the ordinary General
+Public License.  It also provides other free software developers Less
+of an advantage over competing non-free programs.  These disadvantages
+are the reason we use the ordinary General Public License for many
+libraries.  However, the Lesser license provides advantages in certain
+special circumstances.
+
+  For example, on rare occasions, there may be a special need to
+encourage the widest possible use of a certain library, so that it becomes
+a de-facto standard.  To achieve this, non-free programs must be
+allowed to use the library.  A more frequent case is that a free
+library does the same job as widely used non-free libraries.  In this
+case, there is little to gain by limiting the free library to free
+software only, so we use the Lesser General Public License.
+
+  In other cases, permission to use a particular library in non-free
+programs enables a greater number of people to use a large body of
+free software.  For example, permission to use the GNU C Library in
+non-free programs enables many more people to use the whole GNU
+operating system, as well as its variant, the GNU/Linux operating
+system.
+
+  Although the Lesser General Public License is Less protective of the
+users' freedom, it does ensure that the user of a program that is
+linked with the Library has the freedom and the wherewithal to run
+that program using a modified version of the Library.
+
+  The precise terms and conditions for copying, distribution and
+modification follow.  Pay close attention to the difference between a
+"work based on the library" and a "work that uses the library".  The
+former contains code derived from the library, whereas the latter must
+be combined with the library in order to run.
+
+                  GNU LESSER GENERAL PUBLIC LICENSE
+   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+  0. This License Agreement applies to any software library or other
+program which contains a notice placed by the copyright holder or
+other authorized party saying it may be distributed under the terms of
+this Lesser General Public License (also called "this License").
+Each licensee is addressed as "you".
+
+  A "library" means a collection of software functions and/or data
+prepared so as to be conveniently linked with application programs
+(which use some of those functions and data) to form executables.
+
+  The "Library", below, refers to any such software library or work
+which has been distributed under these terms.  A "work based on the
+Library" means either the Library or any derivative work under
+copyright law: that is to say, a work containing the Library or a
+portion of it, either verbatim or with modifications and/or translated
+straightforwardly into another language.  (Hereinafter, translation is
+included without limitation in the term "modification".)
+
+  "Source code" for a work means the preferred form of the work for
+making modifications to it.  For a library, complete source code means
+all the source code for all modules it contains, plus any associated
+interface definition files, plus the scripts used to control compilation
+and installation of the library.
+
+  Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope.  The act of
+running a program using the Library is not restricted, and output from
+such a program is covered only if its contents constitute a work based
+on the Library (independent of the use of the Library in a tool for
+writing it).  Whether that is true depends on what the Library does
+and what the program that uses the Library does.
+
+  1. You may copy and distribute verbatim copies of the Library's
+complete source code as you receive it, in any medium, provided that
+you conspicuously and appropriately publish on each copy an
+appropriate copyright notice and disclaimer of warranty; keep intact
+all the notices that refer to this License and to the absence of any
+warranty; and distribute a copy of this License along with the
+Library.
+
+  You may charge a fee for the physical act of transferring a copy,
+and you may at your option offer warranty protection in exchange for a
+fee.
+
+  2. You may modify your copy or copies of the Library or any portion
+of it, thus forming a work based on the Library, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+    a) The modified work must itself be a software library.
+
+    b) You must cause the files modified to carry prominent notices
+    stating that you changed the files and the date of any change.
+
+    c) You must cause the whole of the work to be licensed at no
+    charge to all third parties under the terms of this License.
+
+    d) If a facility in the modified Library refers to a function or a
+    table of data to be supplied by an application program that uses
+    the facility, other than as an argument passed when the facility
+    is invoked, then you must make a good faith effort to ensure that,
+    in the event an application does not supply such function or
+    table, the facility still operates, and performs whatever part of
+    its purpose remains meaningful.
+
+    (For example, a function in a library to compute square roots has
+    a purpose that is entirely well-defined independent of the
+    application.  Therefore, Subsection 2d requires that any
+    application-supplied function or table used by this function must
+    be optional: if the application does not supply it, the square
+    root function must still compute square roots.)
+
+These requirements apply to the modified work as a whole.  If
+identifiable sections of that work are not derived from the Library,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works.  But when you
+distribute the same sections as part of a whole which is a work based
+on the Library, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote
+it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Library.
+
+In addition, mere aggregation of another work not based on the Library
+with the Library (or with a work based on the Library) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+  3. You may opt to apply the terms of the ordinary GNU General Public
+License instead of this License to a given copy of the Library.  To do
+this, you must alter all the notices that refer to this License, so
+that they refer to the ordinary GNU General Public License, version 2,
+instead of to this License.  (If a newer version than version 2 of the
+ordinary GNU General Public License has appeared, then you can specify
+that version instead if you wish.)  Do not make any other change in
+these notices.
+
+  Once this change is made in a given copy, it is irreversible for
+that copy, so the ordinary GNU General Public License applies to all
+subsequent copies and derivative works made from that copy.
+
+  This option is useful when you wish to copy part of the code of
+the Library into a program that is not a library.
+
+  4. You may copy and distribute the Library (or a portion or
+derivative of it, under Section 2) in object code or executable form
+under the terms of Sections 1 and 2 above provided that you accompany
+it with the complete corresponding machine-readable source code, which
+must be distributed under the terms of Sections 1 and 2 above on a
+medium customarily used for software interchange.
+
+  If distribution of object code is made by offering access to copy
+from a designated place, then offering equivalent access to copy the
+source code from the same place satisfies the requirement to
+distribute the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+  5. A program that contains no derivative of any portion of the
+Library, but is designed to work with the Library by being compiled or
+linked with it, is called a "work that uses the Library".  Such a
+work, in isolation, is not a derivative work of the Library, and
+therefore falls outside the scope of this License.
+
+  However, linking a "work that uses the Library" with the Library
+creates an executable that is a derivative of the Library (because it
+contains portions of the Library), rather than a "work that uses the
+library".  The executable is therefore covered by this License.
+Section 6 states terms for distribution of such executables.
+
+  When a "work that uses the Library" uses material from a header file
+that is part of the Library, the object code for the work may be a
+derivative work of the Library even though the source code is not.
+Whether this is true is especially significant if the work can be
+linked without the Library, or if the work is itself a library.  The
+threshold for this to be true is not precisely defined by law.
+
+  If such an object file uses only numerical parameters, data
+structure layouts and accessors, and small macros and small inline
+functions (ten lines or less in length), then the use of the object
+file is unrestricted, regardless of whether it is legally a derivative
+work.  (Executables containing this object code plus portions of the
+Library will still fall under Section 6.)
+
+  Otherwise, if the work is a derivative of the Library, you may
+distribute the object code for the work under the terms of Section 6.
+Any executables containing that work also fall under Section 6,
+whether or not they are linked directly with the Library itself.
+
+  6. As an exception to the Sections above, you may also combine or
+link a "work that uses the Library" with the Library to produce a
+work containing portions of the Library, and distribute that work
+under terms of your choice, provided that the terms permit
+modification of the work for the customer's own use and reverse
+engineering for debugging such modifications.
+
+  You must give prominent notice with each copy of the work that the
+Library is used in it and that the Library and its use are covered by
+this License.  You must supply a copy of this License.  If the work
+during execution displays copyright notices, you must include the
+copyright notice for the Library among them, as well as a reference
+directing the user to the copy of this License.  Also, you must do one
+of these things:
+
+    a) Accompany the work with the complete corresponding
+    machine-readable source code for the Library including whatever
+    changes were used in the work (which must be distributed under
+    Sections 1 and 2 above); and, if the work is an executable linked
+    with the Library, with the complete machine-readable "work that
+    uses the Library", as object code and/or source code, so that the
+    user can modify the Library and then relink to produce a modified
+    executable containing the modified Library.  (It is understood
+    that the user who changes the contents of definitions files in the
+    Library will not necessarily be able to recompile the application
+    to use the modified definitions.)
+
+    b) Use a suitable shared library mechanism for linking with the
+    Library.  A suitable mechanism is one that (1) uses at run time a
+    copy of the library already present on the user's computer system,
+    rather than copying library functions into the executable, and (2)
+    will operate properly with a modified version of the library, if
+    the user installs one, as long as the modified version is
+    interface-compatible with the version that the work was made with.
+
+    c) Accompany the work with a written offer, valid for at
+    least three years, to give the same user the materials
+    specified in Subsection 6a, above, for a charge no more
+    than the cost of performing this distribution.
+
+    d) If distribution of the work is made by offering access to copy
+    from a designated place, offer equivalent access to copy the above
+    specified materials from the same place.
+
+    e) Verify that the user has already received a copy of these
+    materials or that you have already sent this user a copy.
+
+  For an executable, the required form of the "work that uses the
+Library" must include any data and utility programs needed for
+reproducing the executable from it.  However, as a special exception,
+the materials to be distributed need not include anything that is
+normally distributed (in either source or binary form) with the major
+components (compiler, kernel, and so on) of the operating system on
+which the executable runs, unless that component itself accompanies
+the executable.
+
+  It may happen that this requirement contradicts the license
+restrictions of other proprietary libraries that do not normally
+accompany the operating system.  Such a contradiction means you cannot
+use both them and the Library together in an executable that you
+distribute.
+
+  7. You may place library facilities that are a work based on the
+Library side-by-side in a single library together with other library
+facilities not covered by this License, and distribute such a combined
+library, provided that the separate distribution of the work based on
+the Library and of the other library facilities is otherwise
+permitted, and provided that you do these two things:
+
+    a) Accompany the combined library with a copy of the same work
+    based on the Library, uncombined with any other library
+    facilities.  This must be distributed under the terms of the
+    Sections above.
+
+    b) Give prominent notice with the combined library of the fact
+    that part of it is a work based on the Library, and explaining
+    where to find the accompanying uncombined form of the same work.
+
+  8. You may not copy, modify, sublicense, link with, or distribute
+the Library except as expressly provided under this License.  Any
+attempt otherwise to copy, modify, sublicense, link with, or
+distribute the Library is void, and will automatically terminate your
+rights under this License.  However, parties who have received copies,
+or rights, from you under this License will not have their licenses
+terminated so long as such parties remain in full compliance.
+
+  9. You are not required to accept this License, since you have not
+signed it.  However, nothing else grants you permission to modify or
+distribute the Library or its derivative works.  These actions are
+prohibited by law if you do not accept this License.  Therefore, by
+modifying or distributing the Library (or any work based on the
+Library), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Library or works based on it.
+
+  10. Each time you redistribute the Library (or any work based on the
+Library), the recipient automatically receives a license from the
+original licensor to copy, distribute, link with or modify the Library
+subject to these terms and conditions.  You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties with
+this License.
+
+  11. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License.  If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Library at all.  For example, if a patent
+license would not permit royalty-free redistribution of the Library by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Library.
+
+If any portion of this section is held invalid or unenforceable under any
+particular circumstance, the balance of the section is intended to apply,
+and the section as a whole is intended to apply in other circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system which is
+implemented by public license practices.  Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+  12. If the distribution and/or use of the Library is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Library under this License may add
+an explicit geographical distribution limitation excluding those countries,
+so that distribution is permitted only in or among countries not thus
+excluded.  In such case, this License incorporates the limitation as if
+written in the body of this License.
+
+  13. The Free Software Foundation may publish revised and/or new
+versions of the Lesser General Public License from time to time.
+Such new versions will be similar in spirit to the present version,
+but may differ in detail to address new problems or concerns.
+
+Each version is given a distinguishing version number.  If the Library
+specifies a version number of this License which applies to it and
+"any later version", you have the option of following the terms and
+conditions either of that version or of any later version published by
+the Free Software Foundation.  If the Library does not specify a
+license version number, you may choose any version ever published by
+the Free Software Foundation.
+
+  14. If you wish to incorporate parts of the Library into other free
+programs whose distribution conditions are incompatible with these,
+write to the author to ask for permission.  For software which is
+copyrighted by the Free Software Foundation, write to the Free
+Software Foundation; we sometimes make exceptions for this.  Our
+decision will be guided by the two goals of preserving the free status
+of all derivatives of our free software and of promoting the sharing
+and reuse of software generally.
+
+                            NO WARRANTY
+
+  15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
+WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
+EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
+OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
+KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
+LIBRARY IS WITH YOU.  SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
+THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+  16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
+WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
+AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
+FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
+CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
+LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
+RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
+FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
+SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
+DAMAGES.
+
+                     END OF TERMS AND CONDITIONS
+
+           How to Apply These Terms to Your New Libraries
+
+  If you develop a new library, and you want it to be of the greatest
+possible use to the public, we recommend making it free software that
+everyone can redistribute and change.  You can do so by permitting
+redistribution under these terms (or, alternatively, under the terms of the
+ordinary General Public License).
+
+  To apply these terms, attach the following notices to the library.  It is
+safest to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least the
+"copyright" line and a pointer to where the full notice is found.
+
+    <one line to give the library's name and a brief idea of what it does.>
+    Copyright (C) <year>  <name of author>
+
+    This library is free software; you can redistribute it and/or
+    modify it under the terms of the GNU Lesser General Public
+    License as published by the Free Software Foundation; either
+    version 2.1 of the License, or (at your option) any later version.
+
+    This library is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+    Lesser General Public License for more details.
+
+    You should have received a copy of the GNU Lesser General Public
+    License along with this library; if not, write to the Free Software
+    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
+
+Also add information on how to contact you by electronic and paper mail.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the library, if
+necessary.  Here is a sample; alter the names:
+
+  Yoyodyne, Inc., hereby disclaims all copyright interest in the
+  library `Frob' (a library for tweaking knobs) written by James Random Hacker.
+
+  <signature of Ty Coon>, 1 April 1990
+  Ty Coon, President of Vice
+
+That's all there is to it!
+
diff --git a/NOTICE b/NOTICE
new file mode 100644 (file)
index 0000000..18b91b4
--- /dev/null
+++ b/NOTICE
@@ -0,0 +1,3 @@
+Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd. All rights reserved.
+Except as noted, this software is licensed under GNU LESSER GENERAL PUBLIC LICENSE Version 2.1.
+Please, see the LICENSE.LGPLv2.1 file for GNU LESSER GENERAL PUBLIC LICENSE Version 2.1, terms and conditions.
diff --git a/debian/changelog b/debian/changelog
new file mode 100644 (file)
index 0000000..dc9c26e
--- /dev/null
@@ -0,0 +1,45 @@
+sf-plugin-gyro-emul-pkgs (0.2.6) unstable; urgency=low
+
+  * fixed unexpectedly stop when sms injection with sensor data
+  * Git: slp/pkgs/e/emulator-plugin-gyro-pkgs
+  * Tag: sf-plugin-gyro-emul-pkgs_0.2.6
+
+ -- Sungmin Ha <sungmin82.ha@samsung.com> Wed, 08 Aug 2012 20:54:21 +0900
+
+sf-plugin-gyro-emul-pkgs (0.2.5) unstable; urgency=low
+
+  * modified for prevent from unexpectedly stop
+  * Git: slp/pkgs/e/emulator-plugin-gyro-pkgs
+  * Tag: sf-plugin-gyro-emul-pkgs_0.2.5
+
+ -- Sungmin Ha <sungmin82.ha@samsung.com> Thu, 12 Jul 2012 16:37:00 +0900
+
+sf-plugin-gyro-emul-pkgs (0.2.4) unstable; urgency=low
+
+  * modified for support updated libslp-sensor
+  * Git: slp/pkgs/e/emulator-plugin-gyro-pkgs
+  * Tag: sf-plugin-gyro-emul-pkgs_0.2.4
+
+ -- Sungmin Ha <sungmin82.ha@samsung.com> Fri, 15 Jun 2012 18:54:00 +0900
+
+sf-plugin-gyro-emul-pkgs (0.2.3) unstable; urgency=low
+
+  * modified for support updated libslp-sensor
+  * Git: slp/pkgs/e/emulator-plugin-gyro-pkgs
+  * Tag: sf-plugin-gyro-emul-pkgs_0.2.3
+
+ -- Jihye kim <jihye1128.kim@samsung.com> Fri, 6 Apr 2012 20:00:00 +0900
+
+sf-plugin-gyro-emul-pkgs (0.2.2) unstable; urgency=low
+
+  * Update changelog version.
+  * Git: slp/pkgs/e/emulator-plugin-gyro-pkgs
+  * Tag: sf-plugin-gyro-emul-pkgs_0.2.2
+
+ -- Kitae kim <kt920.kim@samsung.com>  Thu, 27 Mar 2012 20:00:00 +0900
+
+sf-plugin-gyro-emul-pkgs (0.2.1) unstable; urgency=low
+
+  * Initial release
+
+ -- Sungmin Ha <sungmin82.ha@samsung.com> Thu, 15 Mar 2012 17:00:00 +0900
diff --git a/debian/compat b/debian/compat
new file mode 100644 (file)
index 0000000..7ed6ff8
--- /dev/null
@@ -0,0 +1 @@
+5
diff --git a/debian/control b/debian/control
new file mode 100644 (file)
index 0000000..de0be58
--- /dev/null
@@ -0,0 +1,18 @@
+Source: sf-plugin-gyro-emul-pkgs
+Section: misc
+Priority: extra
+Maintainer:Sungmin ha <sungmin82.ha@samsung.com>,Jihye Kim <jihye1128.kim@samsung.com>,Yeongkyoon Lee <yeongkyoon.lee@samsung.com>
+Build-Depends: libsf-common-dev, libslp-setting-dev
+Standards-Version: 0.2.6
+
+Package: sf-plugin-gyro-emul-pkgs
+Architecture: i386
+Depends: ${shlibs:Depends}, ${misc:Depends}, libsf-common-0, libslp-setting-0
+Description: gyro-sim plugins for sensor framework (using setting)
+
+Package: sf-plugin-gyro-emul-pkgs-dbg
+Section: debug
+Architecture: i386
+Depends: ${shlibs:Depends}, ${misc:Depends}, sf-plugin-gyro-sim-pkgs(= ${Source-Version})
+Description:gyro-sim plugins for sensor framework(unstripped)
+ Easy gyro-sim plugins for SLP(not recommended)
diff --git a/debian/copyright b/debian/copyright
new file mode 100644 (file)
index 0000000..8b13789
--- /dev/null
@@ -0,0 +1 @@
+
diff --git a/debian/dirs b/debian/dirs
new file mode 100644 (file)
index 0000000..ca882bb
--- /dev/null
@@ -0,0 +1,2 @@
+usr/bin
+usr/sbin
diff --git a/debian/docs b/debian/docs
new file mode 100644 (file)
index 0000000..a0f0008
--- /dev/null
@@ -0,0 +1 @@
+CMakeLists.txt
diff --git a/debian/rules b/debian/rules
new file mode 100755 (executable)
index 0000000..025537f
--- /dev/null
@@ -0,0 +1,132 @@
+#!/usr/bin/make -f
+# -*- makefile -*-
+# Sample debian/rules that uses debhelper.
+# This file was originally written by Joey Hess and Craig Small.
+# As a special exception, when this file is copied by dh-make into a
+# dh-make output file, you may use that output file without restriction.
+# This special exception was added by Craig Small in version 0.37 of dh-make.
+
+# Uncomment this to turn on verbose mode.
+#export DH_VERBOSE=1
+
+CFLAGS ?= -Wall -g
+CXXFLAGS ?=  -Wall -g
+LDFLAGS ?=
+PREFIX ?= /usr
+DATADIR ?= /opt
+
+ifneq (,$(findstring noopt,$(DEB_BUILD_OPTIONS)))
+       CFLAGS += -O0
+       CXXFLAGS += -O0
+else
+       CFLAGS += -O2
+       CXXFLAGS += -O2
+endif
+
+LDFLAGS += -Wl,--rpath=$(PREFIX)/lib -Wl,--as-needed
+
+configure: configure-stamp
+configure-stamp:
+       dh_testdir
+       # Add here commands to configure the package.
+       CFLAGS="$(CFLAGS)" CXXFLAGS="$(CXXFLAGS)" LDFLAGS="$(LDFLAGS)" cmake . -DCMAKE_INSTALL_PREFIX=$(PREFIX)
+
+       touch configure-stamp
+
+build: build-stamp
+
+build-stamp: configure-stamp 
+       dh_testdir
+       dh_buildinfo generate cat
+
+       # Add here commands to compile the package.
+       $(MAKE)
+       #docbook-to-man debian/wavplayer.sgml > wavplayer.1
+
+       for f in `find $(CURDIR)/debian/ -name "*.in"`; do \
+               cat $$f > $${f%.in}; \
+               sed -i -e "s#@PREFIX@#$(PREFIX)#g" $${f%.in}; \
+               sed -i -e "s#@DATADIR@#$(DATADIR)#g" $${f%.in}; \
+       done
+
+
+       touch $@
+
+clean:
+       dh_testdir
+       dh_testroot
+       rm -f build-stamp configure-stamp
+
+       # Add here commands to clean up after the build process.
+       -$(MAKE) clean
+       rm -rf CMakeCache.txt
+       rm -rf CMakeFiles
+       rm -rf cmake_install.cmake
+       rm -rf Makefile
+       rm -rf install_manifest.txt
+       rm -rf *.so
+
+       rm -rf sensor/CMakeFiles
+       rm -rf sensor/cmake_install.cmake
+       rm -rf sensor/Makefile
+       rm -rf sensor/*.so
+
+       rm -rf processor/CMakeFiles
+       rm -rf processor/cmake_install.cmake
+       rm -rf processor/Makefile
+       rm -rf processor/*.so
+
+       for f in `find $(CURDIR)/debian/ -name "*.in"`; do \
+               rm -f $${f%.in}; \
+       done
+
+       dh_clean 
+
+install: build
+       dh_testdir
+       dh_testroot
+       dh_clean -k 
+       dh_installdirs
+
+       # Add here commands to install the package into debian/wavplayer.
+       $(MAKE) DESTDIR=$(CURDIR)/debian/tmp install
+
+
+# Build architecture-independent files here.
+binary-indep: build install
+# We have nothing to do by default.
+
+# Build architecture-dependent files here.
+binary-arch: build install
+       dh_testdir
+       dh_testroot
+       dh_installchangelogs 
+       dh_installdocs
+       dh_buildinfo install
+       dh_installexamples
+       dh_install --sourcedir=debian/tmp
+#      dh_installmenu
+#      dh_installdebconf       
+#      dh_installlogrotate
+#      dh_installemacsen
+#      dh_installpam
+#      dh_installmime
+#      dh_python
+#      dh_installinit
+#      dh_installcron
+#      dh_installinfo
+       dh_installman
+       dh_link
+       dh_strip --dbg-package=sf-plugin-gyro-emul-pkgs-dbg
+       dh_compress
+       dh_fixperms
+#      dh_perl
+       dh_makeshlibs
+       dh_installdeb
+       dh_shlibdeps
+       dh_gencontrol
+       dh_md5sums
+       dh_builddeb
+
+binary: binary-indep binary-arch
+.PHONY: build clean binary-indep binary-arch binary install configure
diff --git a/debian/sf-plugin-gyro-emul-pkgs.install.in b/debian/sf-plugin-gyro-emul-pkgs.install.in
new file mode 100644 (file)
index 0000000..eb08f97
--- /dev/null
@@ -0,0 +1 @@
+@PREFIX@/lib/sensor_framework/*.so*
diff --git a/debian/sf-plugin-gyro-emul-pkgs.postinst.in b/debian/sf-plugin-gyro-emul-pkgs.postinst.in
new file mode 100644 (file)
index 0000000..4731eb4
--- /dev/null
@@ -0,0 +1,10 @@
+#!/bin/sh
+#if [ ${USER} == "root" ];then
+       # change file owner
+       # 1.libraries
+       #chown root:root /usr/lib/sensor_framework/libl3g4200d_processor.so
+#fi
+# change file permissions
+# 1.libraries
+#chmod 644 /usr/lib/sensor_framework/libl3g4200d_processor.so
+       
diff --git a/mobile/CMakeLists.txt b/mobile/CMakeLists.txt
new file mode 100644 (file)
index 0000000..ea98268
--- /dev/null
@@ -0,0 +1,20 @@
+cmake_minimum_required(VERSION 2.6)
+project(gyro_sim_pkgs CXX)
+
+# to install pkgconfig setup file.
+SET(EXEC_PREFIX "\${prefix}")
+SET(LIBDIR "\${prefix}/lib")
+SET(INCLUDEDIR "\${prefix}/include")
+SET(VERSION 1.0)
+
+include(FindPkgConfig)
+pkg_check_modules(rpkgs REQUIRED vconf sf_common)
+add_definitions(${rpkgs_CFLAGS})
+
+set(PROJECT_MAJOR_VERSION "0")
+set(PROJECT_MINOR_VERSION "2")
+set(PROJECT_RELEASE_VERSION "1")
+set(CMAKE_VERBOSE_MAKEFILE OFF)
+
+add_subdirectory(sensor)
+add_subdirectory(processor)
diff --git a/mobile/processor/CMakeLists.txt b/mobile/processor/CMakeLists.txt
new file mode 100644 (file)
index 0000000..5034628
--- /dev/null
@@ -0,0 +1,19 @@
+cmake_minimum_required(VERSION 2.6)
+project(gyro_sim_processor CXX)
+
+add_definitions(-DUSE_ONLY_ONE_MODULE)
+
+ADD_DEFINITIONS("-DTARGET")
+MESSAGE("add -DTARGET")
+
+add_definitions(-Wall -O3 -omit-frame-pointer)
+#add_definitions(-Wall -g -D_DEBUG)
+add_definitions(-Iinclude)
+
+add_library(${PROJECT_NAME} SHARED
+       src/gyro_sim_processor.cpp
+)
+
+target_link_libraries(${PROJECT_NAME} ${rpkgs_LDFLAGS} ${GLES_LDFLAGS} "-lm")
+
+install(TARGETS ${PROJECT_NAME} DESTINATION lib/sensor_framework)
diff --git a/mobile/processor/include/gyro_sim_processor.h b/mobile/processor/include/gyro_sim_processor.h
new file mode 100644 (file)
index 0000000..75124fb
--- /dev/null
@@ -0,0 +1,110 @@
+/*
+ * emulator-plugin-gyro-pkgs
+ *
+ * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
+ *
+ * Contact:
+ * SooYoung Ha <yoosah.ha@samsnung.com>
+ * Sungmin Ha <sungmin82.ha@samsung.com>
+ * 
+ * This library is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by the
+ * Free Software Foundation; either version 2.1 of the License, or (at your option)
+ * any later version.
+ * 
+ * This library is distributed in the hope that it will be useful, but WITHOUT ANY
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library; if not, write to the Free Software Foundation, Inc., 51
+ * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+class gyro_sim_processor : public cprocessor_module
+{
+public:
+       enum gyro_sim_data_id {
+               GYRO_BASE_DATA_SET = (0x0020<<16) | 0x0001,
+       };
+
+       enum gyro_sim_evet_type_t {
+               GYROSCOPE_EVENT_RAW_DATA_REPORT_ON_TIME                 = (0x0020<<16) |0x0001,
+       };
+
+       enum gyro_sim_cmd_property_t {
+               PROPERTY_CMD_START = 0,
+               PROPERTY_CMD_1,
+               PROPERTY_CMD_2,
+               PROPERTY_CMD_3,
+               PROPERTY_CMD_4,
+               PROPERTY_CMD_5,
+       };
+
+       gyro_sim_processor();
+       virtual ~gyro_sim_processor();
+
+       const char *name(void);
+       int id(void);
+       int version(void);
+
+       bool update_name(char *name);
+       bool update_id(int id);
+       bool update_version(int version);
+
+       bool add_input(csensor_module *sensor);
+       bool add_input(cfilter_module *filter);
+
+       long value(char *port);
+       long value(int id);
+
+       cprocessor_module *create_new(void);
+       void destroy(cprocessor_module *module);
+
+       static void *working(void *inst);
+       static void *stopped(void *inst);
+
+       virtual bool start(void);
+       virtual bool stop(void);
+
+       bool add_callback_func(cmd_reg_t *param);
+       bool remove_callback_func(cmd_reg_t *param);
+       bool check_callback_event(cmd_reg_t *param);
+       
+       long set_cmd(int type , int property , long input_value);
+       int get_property(unsigned int property_level , void *property_data );
+       int get_struct_value(unsigned int struct_type , void *struct_values);   
+       
+       int check_hw_node(void);
+
+
+private:
+       csensor_module *m_sensor;
+       cfilter_module *m_filter;
+
+       long m_x;
+       long m_y;
+       long m_z;
+
+       long m_event;
+       long m_new_event;
+
+       long m_version;
+       long m_id;
+
+       char *m_name;
+
+       csync m_sync;
+       
+       int m_client;
+       int m_work_err_count;
+                       
+       unsigned int m_data_report_cb_client;   
+       
+};
+
+
+
+//! End of a file
diff --git a/mobile/processor/src/gyro_sim_processor.cpp b/mobile/processor/src/gyro_sim_processor.cpp
new file mode 100644 (file)
index 0000000..3e9483c
--- /dev/null
@@ -0,0 +1,570 @@
+/*
+ * emulator-plugin-gyro-pkgs
+ *
+ * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
+ *
+ * Contact: 
+ * SooYoung Ha <yoosah.ha@samsnung.com>
+ * Sungmin Ha <sungmin82.ha@samsung.com>
+ * DongKyun Yun <dk77.yun@samsung.com>
+ * 
+ * This library is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by the
+ * Free Software Foundation; either version 2.1 of the License, or (at your option)
+ * any later version.
+ * 
+ * This library is distributed in the hope that it will be useful, but WITHOUT ANY
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library; if not, write to the Free Software Foundation, Inc., 51
+ * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ * Contributors:
+ * - S-Core Co., Ltd
+ * 
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <errno.h>
+#include <dlfcn.h>
+#include <pthread.h>
+#include <string.h>
+#include <sys/un.h>
+#include <netinet/in.h>
+#include <math.h>
+#include <sys/select.h>
+#include <sys/time.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <linux/input.h>
+#include <dirent.h>
+
+#include <common.h>
+#include <cobject_type.h>
+#include <clist.h>
+#include <cmutex.h>
+#include <cmodule.h>
+#include <csync.h>
+#include <cworker.h>
+#include <cpacket.h>
+#include <csock.h>
+#include <sf_common.h>
+
+#include <csensor_module.h>
+#include <cfilter_module.h>
+#include <cprocessor_module.h>
+#include <gyro_sim_processor.h>
+
+#include <vconf.h>
+
+
+gyro_sim_processor::gyro_sim_processor()
+: m_sensor(NULL)
+, m_filter(NULL)
+, m_x(-1)
+, m_y(-1)
+, m_z(-1)
+, m_event(0)
+, m_new_event(0)
+, m_version(1)
+, m_id(0x04BE)
+, m_client(0)
+, m_work_err_count(0)
+, m_data_report_cb_client(0)
+{
+       m_name = strdup("gyro_sim_processor");
+       if ((!m_name)) {
+               free(m_name);           
+               throw ENOMEM;
+       }
+
+#ifdef HWREV_CHECK
+//     if (check_hw_node() != 1 ) {
+       //      free(m_name);
+               //throw ENXIO;
+       //}
+#endif
+
+       cprocessor_module::set_main(working, stopped, this);
+}
+
+
+
+gyro_sim_processor::~gyro_sim_processor()
+{
+       free(m_name);
+       
+}
+
+
+
+bool gyro_sim_processor::add_input(csensor_module *sensor)
+{
+       m_sensor = sensor;
+       return true;
+}
+
+
+
+bool gyro_sim_processor::add_input(cfilter_module *filter)
+{
+       m_filter = filter;
+       return true;
+}
+
+
+
+const char *gyro_sim_processor::name(void)
+{
+       return m_name;
+}
+
+
+
+int gyro_sim_processor::id(void)
+{
+       return m_id;
+}
+
+
+
+int gyro_sim_processor::version(void)
+{
+       return m_version;
+}
+
+
+
+bool gyro_sim_processor::update_name(char *name)
+{
+       char *new_name;
+       new_name = strdup(name);
+       if (!new_name) {
+               DbgPrint("No memory\n");
+               return false;
+       }
+
+       free(m_name);
+       m_name = new_name;
+       return true;
+}
+
+
+
+bool gyro_sim_processor::update_id(int id)
+{
+       m_id = id;
+       return true;
+}
+
+
+
+bool gyro_sim_processor::update_version(int version)
+{
+       m_version = version;
+       return true;
+}
+
+
+
+cprocessor_module *gyro_sim_processor::create_new(void)
+{
+#ifdef USE_ONLY_ONE_MODULE
+       return (cprocessor_module*)this;
+#else
+       gyro_sim_processor *inst = NULL;
+       bool bstate = false;
+
+       try {
+               inst = new gyro_sim_processor;
+       } catch (...) {
+               ERR("No Memory\n");
+               return NULL;
+       }
+
+       bstate = cmodule::add_to_list((cmodule *)inst);
+       if ( !bstate ) {
+               ERR("Creat and add_to_list fail");
+               return NULL;
+       }       
+
+       return (cprocessor_module*)inst;
+#endif
+}
+
+
+
+void gyro_sim_processor::destroy(cprocessor_module *module)
+{
+       bool bstate = false;
+
+       bstate = cmodule::del_from_list((cmodule *)module);
+
+       if ( !bstate ) {
+               ERR("Destory and del_from_list fail");
+               delete (gyro_sim_processor *)module;
+               return ;
+       }       
+}
+
+
+
+void *gyro_sim_processor::stopped(void *inst)
+{
+
+       gyro_sim_processor *processor = (gyro_sim_processor*)inst;
+
+       if (!processor) {
+               ERR("There is no processor module instance at gyro_sim (%s)\n", __FUNCTION__ );
+               return (void*)NULL;
+       }
+
+       processor->wakeup_all_client();
+
+       DBG(">>>>>>>>Wait signal %lx , %s\n", pthread_self(), processor->m_name);
+       processor->m_sync.wait();
+
+       DBG(">>>>>>>>>Signal received %lx, %s\n", pthread_self(), processor->m_name);
+       return (void*)NULL;
+}
+
+
+
+void *gyro_sim_processor::working(void *inst)
+{      
+       csensor_module *sensor;
+
+       gyro_sim_processor *processor = (gyro_sim_processor*)inst;
+       if (!processor) {
+               ERR("There is no processor module instance at gyro_sim (%s)\n", __FUNCTION__ );
+               return (void*)cworker::STOPPED;
+       }
+
+#ifdef TARGET
+       DBG("Gathering data\n");
+       if (!processor->m_sensor) {
+               ERR("Sensor is not added\n");
+               return (void*)cworker::STOPPED;
+       }
+
+       //! Implementation dependent
+       sensor = (csensor_module*)processor->m_sensor;
+
+       DBG("Invoke is_data_ready\n");
+       
+       if (sensor->is_data_ready(true) == false) {
+               ERR("Data ready has failed\n");
+               processor->m_work_err_count++;
+//             if ( processor->m_work_err_count > 10 ) {
+//                     ERR("Too many error counted stop processor");                   
+//                     return (void*)cworker::STOPPED;
+//             }
+               return (void*)cworker::STARTED;         
+       }
+       
+       processor->m_x = sensor->value(0);
+       processor->m_y = sensor->value(1);
+       processor->m_z = sensor->value(2);
+       
+       
+       DBG("Data is ready now\n");
+#else
+       usleep(100000);
+       
+#endif
+
+       processor->wakeup_all_client();
+
+       //! TODO: How can I get the polling interval?
+       //! TODO: When we get a polling interval, try read data in that interval :D
+       return (void*)cworker::STARTED;
+}
+
+
+
+long gyro_sim_processor::value(char *port)
+{
+       if (!strcasecmp(port, "pitch")) {
+               return m_x;
+       } else if (!strcasecmp(port, "roll")) {
+               return m_y;
+       } else if (!strcasecmp(port, "yaw")) {
+               return m_z;
+       }
+       
+       return -1;
+}
+
+
+
+long gyro_sim_processor::value(int id)
+{
+       
+       return -1;
+}
+
+
+
+bool gyro_sim_processor::start(void)
+{
+       bool ret;
+
+       m_client ++;
+       if (m_client > 1) {
+               DBG("%s processor fake starting\n",m_name);
+               return true;
+       }
+
+       DBG("%s processor real starting\n",m_name);
+
+       //! Before starting the processor module,
+       //! We have to enable sensor
+       ret = m_sensor ? m_sensor->start() : true;
+       if ( ret != true ) {
+               ERR("m_sensor start fail\n");
+               return false;
+       }
+
+       ret = m_filter ? m_filter->start() : true;
+       if ( ret != true ) {
+               ERR("m_filter start fail\n");
+               return false;
+       }
+
+#ifdef TARGET
+       ret = cprocessor_module::start();
+
+       if (ret == true) {
+               DBG("Signal send %s\n", m_name);
+               m_sync.send_event();
+               DBG("Signal sent\n");           
+       }
+#endif
+
+       return ret;
+}
+
+
+
+bool gyro_sim_processor::stop(void)
+{
+       bool ret;
+
+       m_client --;
+       if (m_client > 0) {
+               DBG("%s processor fake Stopping\n",m_name);
+               return true;
+       }
+
+       DBG("%s processor real Stopping\n",m_name);
+       
+       m_client = 0;
+
+#ifdef TARGET
+       ret = cprocessor_module::stop();
+       if ( ret != true ) {
+               ERR("cprocessor_module::stop()\n");
+               return false;
+       }
+#endif
+
+       ret = m_filter ? m_filter->stop() : true;
+       if ( ret != true ) {
+               ERR("m_filter stop fail\n");
+               return false;
+       }
+
+       ret = m_sensor ? m_sensor->stop() : true;
+       if ( ret != true ) {
+               ERR("m_sensor stop fail\n");
+               return false;
+       }
+
+       
+       return ret;
+}
+
+bool gyro_sim_processor::add_callback_func(cmd_reg_t * param)
+{
+//     char dummy_key[MAX_KEY_LEN];
+       
+       if ( param->type != REG_ADD ) {
+               ERR("invaild cmd type !!");
+               return false;
+       }
+       
+       switch ( param->event_type ) {
+               case GYROSCOPE_EVENT_RAW_DATA_REPORT_ON_TIME:
+                       m_data_report_cb_client++;
+                       break;
+               default:
+                       ERR("invaild event type !!");
+                       return false;
+       }
+
+       return true;
+}
+
+
+bool gyro_sim_processor::remove_callback_func(cmd_reg_t * param)
+{
+       if ( param->type != REG_DEL ) {
+               ERR("invaild cmd type !!");
+               return false;
+       }
+
+       switch ( param->event_type ) {
+               case GYROSCOPE_EVENT_RAW_DATA_REPORT_ON_TIME:
+                       m_data_report_cb_client--;
+                       break;
+               default:
+                       ERR("invaild event type !!");
+                       return false;
+       }       
+
+       return true;
+}
+
+bool gyro_sim_processor::check_callback_event(cmd_reg_t *param)
+{
+       if ( param->type != REG_CHK ) {
+               ERR("invaild cmd type !!");
+               return false;
+       }
+
+       switch ( param->event_type ) {
+               case GYROSCOPE_EVENT_RAW_DATA_REPORT_ON_TIME:                    
+                        DBG("event check ok\n");
+                       break;
+                       
+               default:
+                       ERR("invaild event type !!");
+                       return false;
+       }       
+
+       return true;
+}
+
+long gyro_sim_processor::set_cmd(int type , int property , long input_value)
+{
+       return -1;
+}
+
+int gyro_sim_processor::get_property(unsigned int property_level , void *property_data )
+{
+       DBG("gyro_sim_processor called get_property , with property_level : 0x%x", property_level);
+       if (m_sensor) {
+               return m_sensor->get_property(property_level , property_data);          
+       } else {
+               ERR("no m_sensor , cannot get_struct_value from sensor\n");
+               return -1;
+       }
+}
+
+int gyro_sim_processor::get_struct_value(unsigned int struct_type , void *struct_values)
+{
+       if (m_sensor) {
+               if ( struct_type == GYRO_BASE_DATA_SET  ) {
+                       return m_sensor->get_struct_value(struct_type , struct_values);
+               } else {
+                       ERR("does not support stuct_type\n");
+                       return -1;
+               }
+       } else {
+               ERR("no m_sensor , cannot get_struct_value from sensor\n");
+               return -1;
+       } 
+}
+
+int gyro_sim_processor::check_hw_node(void)
+{
+       char name_node[256];
+       char hw_name[50];
+
+       DIR *iio_main_dir = NULL;
+       struct dirent *iio_dir_entry = NULL;
+
+       FILE *fp;
+       const char* orig_name = "K3G";
+       int find_node = 0;
+
+       struct stat lstat_buf;
+
+       if (lstat("/dev/gyro_sim",&lstat_buf) != 0)
+               DBG("Cannot find old style H/W node : /dev/gyro_sim for gyro_sim\n");
+       else {
+               if (S_ISCHR(lstat_buf.st_mode))
+                       return 1;
+               else
+                       ERR("It's not char device node : /dev/gyro_sim (not real device for gyro_sim)\n");
+       }
+
+       iio_main_dir = opendir("/sys/bus/iio/devices/");
+       if (!iio_main_dir) {
+               ERR("iio-style dir open failed to collect data\n");
+               return -1;
+       }
+
+       while ( (!find_node) && (iio_dir_entry = readdir(iio_main_dir)) ) {
+               if ( (strncasecmp(iio_dir_entry->d_name ,".",1 ) != 0) && 
+                       (strncasecmp(iio_dir_entry->d_name ,"..",2 ) != 0) && 
+                       (iio_dir_entry->d_ino != 0) && (strlen(iio_dir_entry->d_name)<9) ) {
+                       snprintf(name_node,sizeof(name_node),"/sys/bus/iio/devices/%s/name",iio_dir_entry->d_name);
+                       fp = fopen(name_node, "r");
+
+                       if (!fp) {
+                               DBG("Failed to open a sys_node or there is no node: %s , so retry it\n",name_node);                     
+                               continue;
+                       }
+               
+                       if ( fscanf(fp, "%s", hw_name) < 0) {
+                               fclose(fp);
+                               DBG("Failed to collect data from %s , so retry it\n",name_node);
+                               continue;
+                       }
+                       fclose(fp);
+       
+                       if ( (!strcasecmp(hw_name, orig_name )) ) {
+                               DBG("Find new style H/W  for gyro_sim(K3G)\n");
+                               find_node = 1;  
+                               break;
+                       }
+               }
+       }
+       closedir(iio_main_dir);
+
+       return find_node;
+}
+
+
+cmodule *module_init(void *win, void *egl)
+{
+       gyro_sim_processor *inst;
+
+       try {
+               inst = new gyro_sim_processor();
+       } catch (int ErrNo) {
+               ERR("gyro_sim_processor class create fail , errno : %d , errstr : %s\n",ErrNo, strerror(ErrNo));
+               return NULL;
+       }
+
+       return (cmodule*)inst;
+}
+
+
+
+void module_exit(cmodule *inst)
+{
+       gyro_sim_processor *sample = (gyro_sim_processor*)inst;
+       delete sample;
+}
+
+
+
+//! End of a file
diff --git a/mobile/sensor/CMakeLists.txt b/mobile/sensor/CMakeLists.txt
new file mode 100644 (file)
index 0000000..e2fd84c
--- /dev/null
@@ -0,0 +1,21 @@
+cmake_minimum_required(VERSION 2.6)
+project(gyro_sim CXX)
+
+
+ADD_DEFINITIONS("-DTARGET")
+MESSAGE("add -DTARGET")
+
+
+#add_definitions(-D_ESTIMATE_PERFORMANCE)
+#add_definitions(-D_DEFAULT_FONT_NAME="Vera")
+add_definitions(-Wall -O3 -omit-frame-pointer)
+#add_definitions(-Wall -g -D_DEBUG)
+add_definitions(-Iinclude)
+
+add_library(${PROJECT_NAME} SHARED
+       src/cgyro_sim.cpp
+)
+
+target_link_libraries(${PROJECT_NAME} ${rpkgs_LDFLAGS} ${GLES_LDFLAGS})
+
+install(TARGETS ${PROJECT_NAME} DESTINATION lib/sensor_framework)
diff --git a/mobile/sensor/include/cgyro_sim.h b/mobile/sensor/include/cgyro_sim.h
new file mode 100644 (file)
index 0000000..a3af789
--- /dev/null
@@ -0,0 +1,104 @@
+/*
+ * emulator-plugin-gyro-pkgs
+ *
+ * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
+ *
+ * Contact:
+ * SooYoung Ha <yoosah.ha@samsnung.com>
+ * Sungmin Ha <sungmin82.ha@samsung.com>
+ * 
+ * This library is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by the
+ * Free Software Foundation; either version 2.1 of the License, or (at your option)
+ * any later version.
+ * 
+ * This library is distributed in the hope that it will be useful, but WITHOUT ANY
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library; if not, write to the Free Software Foundation, Inc., 51
+ * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+class cgyro_sim : public csensor_module
+{
+public:
+       enum gyro_sim_cmd_property_t {
+               PROPERTY_CMD_START = 0,
+               PROPERTY_CMD_1,
+               PROPERTY_CMD_2,
+               PROPERTY_CMD_3,
+               PROPERTY_CMD_4,
+               PROPERTY_CMD_5,
+       };
+
+       cgyro_sim();
+       virtual ~cgyro_sim();
+
+       const char *name(void);
+       int version(void);
+       int id(void);
+
+       bool is_data_ready(bool wait=false);
+
+       long value(const char *port);
+       long value(int id);
+
+       bool update_name(char *name);
+       bool update_version(int ver);
+       bool update_id(int id);
+
+       int port_count(void);
+       const char *port(int idx);
+
+       bool need_polling(void);
+       long polling_interval(void);
+       bool update_polling_interval(unsigned long val);
+       int get_sensor_type(void);
+       long set_cmd(int type , int property , long input_value);
+       int get_property(unsigned int property_level , void *property_data);
+       int get_struct_value(unsigned int struct_type , void *struct_values);   
+
+       
+       int check_hw_node(void);
+       int check_sensitivity(int update);
+       
+
+       bool start(void);
+       bool stop(void);
+
+       void reset(void);       
+       
+private:
+
+       static const char *m_port[];
+
+       char *m_name;
+       char *m_resource;
+       long m_id;
+       long m_version;
+       unsigned long m_polling_interval;
+
+       int m_x;        //pitch
+       int m_y;        //roll  
+       int m_z;        //yaw
+
+       unsigned long long m_fired_time;
+
+       bool update_value(void);
+
+       int m_client;
+       int m_sensor_type;
+
+       int m_ioctl_fd;
+       float m_sensitivity;
+       bool m_hw_type_k3g;
+
+};
+
+
+
+//! End of a file
diff --git a/mobile/sensor/include/l3g4200d.h b/mobile/sensor/include/l3g4200d.h
new file mode 100644 (file)
index 0000000..daec0fc
--- /dev/null
@@ -0,0 +1,103 @@
+/*
+ * emulator-plugin-gyro-pkgs
+ *
+ * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
+ *
+ * Contact:
+ * SooYoung Ha <yoosah.ha@samsnung.com>
+ * Sungmin Ha <sungmin82.ha@samsung.com>
+ * 
+ * This library is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by the
+ * Free Software Foundation; either version 2.1 of the License, or (at your option)
+ * any later version.
+ * 
+ * This library is distributed in the hope that it will be useful, but WITHOUT ANY
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library; if not, write to the Free Software Foundation, Inc., 51
+ * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+/******************** (C) COPYRIGHT 2010 STMicroelectronics ********************
+*
+* File Name          : l3g4200d.c
+* Authors            : MH - C&I BU - Application Team
+*                   : Carmine Iascone (carmine.iascone@st.com)
+*                   : Matteo Dameno (matteo.dameno@st.com)
+* Version            : V 0.2
+* Date               : 09/04/2010
+* Description        : L3G4200D digital output gyroscope sensor API
+*
+********************************************************************************
+*
+* This program is free software; you can redistribute it and/or modify
+* it under the terms of the GNU General Public License version 2 as
+* published by the Free Software Foundation.
+*
+* THE PRESENT SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES
+* OR CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED, FOR THE SOLE
+* PURPOSE TO SUPPORT YOUR APPLICATION DEVELOPMENT.
+* AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT,
+* INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE
+* CONTENT OF SUCH SOFTWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING
+* INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
+*
+* THIS SOFTWARE IS SPECIFICALLY DESIGNED FOR EXCLUSIVE USE WITH ST PARTS.
+*
+********************************************************************************
+* REVISON HISTORY
+*
+* VERSION | DATE       | AUTHORS            | DESCRIPTION
+*
+* 0.1    | 29/01/2010  | Carmine Iascone    | First Release
+* 
+* 0.2    | 09/04/2010  | Carmine Iascone    | Updated the struct l3g4200d_t
+*
+*******************************************************************************/
+
+#ifndef __L3G4200D_H__
+#define __L3G4200D_H__
+
+#include <sys/ioctl.h>  /* For IOCTL macros */
+
+/** This define controls compilation of the master device interface */
+/*#define L3G4200D_MASTER_DEVICE*/
+
+#define L3G4200D_IOCTL_BASE 'g'
+/* The following define the IOCTL command values via the ioctl macros */
+#define L3G4200D_SET_RANGE             _IOW(L3G4200D_IOCTL_BASE, 1, int)
+#define L3G4200D_SET_BANDWIDTH         _IOW(L3G4200D_IOCTL_BASE, 3, int)
+#define L3G4200D_READ_GYRO_VALUES      _IOW(L3G4200D_IOCTL_BASE, 4, int)
+#define L3G4200D_GET_RANGE             _IOW(L3G4200D_IOCTL_BASE, 5, int)
+#define L3G4200D_SELF_TEST_MODE                                _IOW(L3G4200D_IOCTL_BASE, 6, int)
+
+//#define L3G4200D_FS_250DPS   0x00
+#define L3G4200D_FS_500DPS     0x10
+//#define L3G4200D_FS_2000DPS  0x30
+
+//#define L3G4200D_FS_250DPS_SENSITIVITY                       (8.75)          // mdps/digit
+#define L3G4200D_FS_500DPS_SENSITIVITY                 (17.50)         // mdps/digit
+//#define L3G4200D_FS_2000DPS_SENSITIVITY              (70)                    // mdps/digit
+
+#define PM_OFF         0x00
+#define PM_NORMAL      0x08
+#define ENABLE_ALL_AXES        0x07
+
+#define ODR100_BW12_5  0x00  /* ODR = 100Hz; BW = 12.5Hz */
+#define ODR100_BW25    0x10  /* ODR = 100Hz; BW = 25Hz   */
+#define ODR200_BW12_5  0x40  /* ODR = 200Hz; BW = 12.5Hz */
+#define ODR200_BW25    0x50  /* ODR = 200Hz; BW = 25Hz   */
+#define ODR200_BW50    0x60  /* ODR = 200Hz; BW = 50Hz   */
+#define ODR400_BW25    0x90  /* ODR = 400Hz; BW = 25Hz   */
+#define ODR400_BW50    0xA0  /* ODR = 400Hz; BW = 50Hz   */
+#define ODR400_BW110   0xB0  /* ODR = 400Hz; BW = 110Hz  */
+#define ODR800_BW50    0xE0  /* ODR = 800Hz; BW = 50Hz   */
+#define ODR800_BW100   0xF0  /* ODR = 800Hz; BW = 100Hz  */
+
+
+#endif  /* __L3G4200D_H__ */
diff --git a/mobile/sensor/src/cgyro_sim.cpp b/mobile/sensor/src/cgyro_sim.cpp
new file mode 100644 (file)
index 0000000..f70bdfa
--- /dev/null
@@ -0,0 +1,616 @@
+/*
+ * emulator-plugin-gyro-pkgs
+ *
+ * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
+ *
+ * Contact: 
+ * SooYoung Ha <yoosah.ha@samsnung.com>
+ * Sungmin Ha <sungmin82.ha@samsung.com>
+ * DongKyun Yun <dk77.yun@samsung.com>
+ * 
+ * This library is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by the
+ * Free Software Foundation; either version 2.1 of the License, or (at your option)
+ * any later version.
+ * 
+ * This library is distributed in the hope that it will be useful, but WITHOUT ANY
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library; if not, write to the Free Software Foundation, Inc., 51
+ * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ * Contributors:
+ * - S-Core Co., Ltd
+ * 
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <errno.h>
+#include <dlfcn.h>
+#include <pthread.h>
+#include <string.h>
+#include <sys/un.h>
+#include <sys/time.h>
+#include <netinet/in.h>
+#include <sys/ioctl.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <dirent.h>
+
+#include <common.h>
+#include <cobject_type.h>
+#include <cmutex.h>
+#include <clist.h>
+#include <cmodule.h>
+#include <cpacket.h>
+#include <csync.h>
+#include <cworker.h>
+#include <csock.h>
+#include <sf_common.h>
+
+#include <csensor_module.h>
+
+#include <cgyro_sim.h>
+#include <l3g4200d.h>
+
+#ifdef _DEBUG
+       #ifdef LOG_TAG
+               #undef LOG_TAG
+       #endif
+       #define LOG_TAG "gyro_sim_SENSOR"
+#endif
+
+#define SENSOR_NAME    "Emul_ModelId_Gyro"
+#define SENSOR_VENDOR  "Emul_Vendor"
+
+const char *cgyro_sim::m_port[] = {"x", "y", "z"};
+
+cgyro_sim::cgyro_sim()
+: m_name(NULL)
+, m_resource(NULL)
+, m_id(0x00200002)
+, m_version(1)
+, m_polling_interval(100000)
+, m_x(-1)
+, m_y(-1)
+, m_z(-1)
+, m_fired_time(0)
+, m_client(0)
+, m_sensor_type(ID_GYROSCOPE)
+, m_ioctl_fd(-1)
+, m_sensitivity(L3G4200D_FS_500DPS_SENSITIVITY)
+, m_hw_type_k3g(false)
+{
+       m_name = strdup("gyro_sim");
+       m_resource = strdup("/sys/devices/virtual/sensor/gyro");
+       if ((!m_name) ||(!m_resource)) {
+               free(m_name);
+               free(m_resource);
+               throw ENOMEM;
+       }
+       
+}
+
+
+
+cgyro_sim::~cgyro_sim()
+{
+       free(m_name);
+       free(m_resource);
+       if ( m_ioctl_fd != -1 ) {
+               close(m_ioctl_fd);
+       }
+               
+}
+
+
+
+const char *cgyro_sim::name(void)
+{
+       return m_name;
+}
+
+
+
+int cgyro_sim::version(void)
+{
+       return m_version;
+}
+
+
+
+int cgyro_sim::id(void)
+{
+       return m_version;
+}
+
+
+
+bool cgyro_sim::update_value(void)
+{
+#ifdef TARGET
+       FILE *fp;
+       int state;
+       short gyro_raw[3];
+       char raw_data_node[256];
+
+               snprintf(raw_data_node,sizeof(raw_data_node),"%s/gyro_x_raw",m_resource);
+               fp = fopen(raw_data_node, "r");
+               if (!fp) {
+                       ERR("Failed to open a raw_data node : %s\n",raw_data_node);     
+                       return false;
+               }
+               if ( fscanf(fp, "%hd", &gyro_raw[0]) != 1 ) {
+                       ERR("Failed to collect data from : %s",raw_data_node);
+                       fclose(fp);
+                       return true;
+               }
+               fclose(fp);
+
+               snprintf(raw_data_node,sizeof(raw_data_node),"%s/gyro_y_raw",m_resource);
+               fp = fopen(raw_data_node, "r");
+               if (!fp) {
+                       ERR("Failed to open a raw_data node : %s\n",raw_data_node);     
+                       return false;
+               }
+               if ( fscanf(fp, "%hd", &gyro_raw[1]) != 1 ) {
+                       ERR("Failed to collect data from : %s",raw_data_node);
+                       fclose(fp);
+                       return true;
+               }
+               fclose(fp);
+               
+               snprintf(raw_data_node,sizeof(raw_data_node),"%s/gyro_z_raw",m_resource);
+               fp = fopen(raw_data_node, "r");
+               if (!fp) {
+                       ERR("Failed to open a raw_data node : %s\n",raw_data_node);     
+                       return false;
+               }
+               if ( fscanf(fp, "%hd", &gyro_raw[2]) != 1 ) {
+                       ERR("Failed to collect data from : %s",raw_data_node);
+                       fclose(fp);
+                       return true;
+               }
+               fclose(fp);
+
+
+       csensor_module::lock();
+       m_x = gyro_raw[0];
+       m_y = gyro_raw[1];
+       m_z = gyro_raw[2];              
+       csensor_module::unlock();       
+
+       DBG("Update done raw : %d, %d, %d , out_data : %d, %d, %d\n", gyro_raw[0],gyro_raw[1],gyro_raw[2],m_x, m_y, m_z);
+#endif
+       return true;
+}
+
+
+
+bool cgyro_sim::is_data_ready(bool wait)
+{
+       unsigned long long cur_time;
+       unsigned long elapsed_time;
+       struct timeval sv;
+       bool ret = false;
+
+       DbgPrint("Sensor, invoked\n");
+       gettimeofday(&sv, NULL);
+       cur_time = MICROSECONDS(sv);
+
+       elapsed_time = (unsigned long)(cur_time - m_fired_time);
+       if (elapsed_time < m_polling_interval) {
+               DbgPrint("Waiting\n");
+               if (wait) {
+                       /*
+                       struct timespec ts;
+                       ts.tv_sec = 0;
+                       ts.tv_nsec= (m_polling_interval - elapsed_time) * 1000llu;
+                       nanosleep(&ts, NULL);
+                       */
+                       usleep(m_polling_interval - elapsed_time);
+                       csensor_module::lock();
+                       m_fired_time = cur_time + (m_polling_interval-elapsed_time);
+                       csensor_module::unlock();
+                       ret = update_value();
+               } else {
+                       ret = true;
+               }
+       } else {
+               DbgPrint("Re-firing %llu %llu\n", cur_time, m_fired_time);
+               DbgPrint("elapsed_time %lu polling_interval %ld\n", elapsed_time, m_polling_interval);
+               csensor_module::lock();
+               m_fired_time = cur_time;
+               csensor_module::unlock();
+               ret = update_value();
+       }
+
+
+       return ret;
+}
+
+
+
+long cgyro_sim::value(const char *port)
+{
+
+#ifdef TARGET
+       if (!strcasecmp(port, "x")) {
+               return m_x;
+       } else if (!strcasecmp(port, "y")) {
+               return m_y;
+       } else if (!strcasecmp(port, "z")) {
+               return m_z;
+       }
+#endif
+
+       return -1;
+}
+
+
+
+long cgyro_sim::value(int id)
+{
+
+#ifdef TARGET
+       if (id == 0) {
+               return m_x;
+       } else if (id == 1) {
+               return m_y;
+       } else if (id == 2) {
+               return m_z;
+       }
+#endif
+
+       return -1;
+}
+
+
+void cgyro_sim::reset(void)
+{
+       return;
+}
+
+
+
+bool cgyro_sim::update_name(char *name)
+{
+       char *new_name;
+       new_name = strdup(name);
+       if (!new_name) {
+               DbgPrint("No memory\n");
+               return false;
+       }
+
+       free(m_name);
+       m_name = new_name;
+       return true;
+}
+
+
+
+bool cgyro_sim::update_version(int version)
+{
+       m_version = version;
+       return true;
+}
+
+
+
+bool cgyro_sim::update_id(int id)
+{
+       m_id = id;
+       return true;
+}
+
+
+
+int cgyro_sim::port_count(void)
+{
+       return 3;
+}
+
+
+
+const char *cgyro_sim::port(int idx)
+{
+       if (idx >= (int)(sizeof(m_port)/sizeof(const char*))) {
+               return NULL;
+       }
+
+       return m_port[idx];
+}
+
+
+
+bool cgyro_sim::need_polling(void)
+{
+       return m_polling_interval != 0;
+}
+
+
+
+long cgyro_sim::polling_interval(void)
+{
+       return (unsigned long long)m_polling_interval /1000llu ;
+}
+
+
+
+bool cgyro_sim::update_polling_interval(unsigned long val)
+{
+       DbgPrint("Update polling interval %lu\n", val);
+       csensor_module::lock();
+       m_polling_interval = (unsigned long long)val * 1000llu;
+       csensor_module::unlock();
+       return true;
+}
+
+
+
+bool cgyro_sim::start(void)
+{
+
+       m_client ++;
+
+       if (m_client > 1) {
+               return true;
+       }
+/*
+       if ( !m_hw_type_k3g ) {
+       //gyro_sim does not need init-state
+               m_ioctl_fd = open(m_resource , O_RDWR);
+               if ( m_ioctl_fd < 0 ) {
+                       ERR("Cannot open ioctl node : %s for ST_gyro\n",m_resource);
+                       return false;
+               }
+       }
+*/
+       return true;
+}
+
+
+
+bool cgyro_sim::stop(void)
+{
+
+       m_client --;
+       if (m_client > 0) {
+               DbgPrint("%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% Stopping\n");
+               return true;
+       }
+/*
+       if ( !m_hw_type_k3g ) {
+       //gyro_sim does not need final-state
+               if (m_ioctl_fd < 0 ) {
+                       ERR("m_ioctl_fd value check fail : %d\n", m_ioctl_fd);
+                       return false;
+               }
+
+               close(m_ioctl_fd);
+               m_ioctl_fd = -1;
+       }
+*/
+       return true;
+}
+
+int cgyro_sim::get_sensor_type(void)
+{
+       return m_sensor_type;
+}
+
+long cgyro_sim::set_cmd(int type , int property , long input_value)
+{
+       long value = -1;
+
+#if 0
+       if ( type == m_sensor_type) {
+               switch (property) {
+                       case PROPERTY_CMD_1 :                           
+                               if ( calibration( (int)input_value ) ) {
+                                       DBG("acc_sensor_calibration OK\n");
+                                       value = 0;
+                               } else {
+                                       ERR("acc_sensor_calibration FAIL\n");
+                               }
+                               break;
+
+                       case PROPERTY_CMD_2 :
+                               return (long)m_calibration_flag;
+
+                               
+                       default :
+                               ERR("Invalid property_cmd\n");
+                               break;                          
+               }
+       }
+       else {
+               ERR("Invalid sensor_type\n");           
+       }
+#else
+       ERR("Cannot support any cmd\n");                
+#endif
+
+       return value;
+       
+}
+
+int cgyro_sim::get_property(unsigned int property_level , void *property_data)
+{
+       DBG("gyro_sim_sensor called get_property , with property_level : 0x%x", property_level);
+       if ( (property_level & 0xFFFF) == 1 ) {
+               base_property_struct *return_property;
+               return_property = (base_property_struct *)property_data;
+               return_property->sensor_unit_idx = IDX_UNIT_DEGREE_PER_SECOND;
+               return_property->sensor_min_range = -(m_sensitivity*32768/1000);
+               return_property->sensor_max_range = (m_sensitivity*32767/1000);
+                return_property->sensor_resolution = (m_sensitivity/1000);
+               snprintf(return_property->sensor_name,   sizeof(return_property->sensor_name),   SENSOR_NAME  );
+               snprintf(return_property->sensor_vendor, sizeof(return_property->sensor_vendor), SENSOR_VENDOR);
+
+               return 0;
+       } else {
+               ERR("Doesnot support property_level : %d\n",property_level);
+               return -1;
+       }
+}
+
+int cgyro_sim::get_struct_value(unsigned int struct_type , void *struct_values)
+{
+#ifdef TARGET
+       if ( (struct_type & 0xFFFF) == 0x0001) {
+               base_data_struct *return_struct_value = NULL;
+               return_struct_value = (base_data_struct *)struct_values;
+               if ( return_struct_value ) {
+                       return_struct_value->data_accuracy = ACCURACY_NORMAL;
+                       return_struct_value->data_unit_idx = IDX_UNIT_DEGREE_PER_SECOND;
+                       return_struct_value->time_stamp = m_fired_time ;
+                       return_struct_value->values_num = 3;
+                       return_struct_value->values[0] = (m_x * m_sensitivity / 1000 );
+                       return_struct_value->values[1] = (m_y * m_sensitivity / 1000 );
+                       return_struct_value->values[2] = (m_z * m_sensitivity / 1000 );
+
+                       return 0;
+               } else {
+                       ERR("return struct_value point error\n");
+               }
+               
+       } else {
+               ERR("Does not support type , struct_type : %d \n",struct_type);         
+       } 
+#endif
+       return -1;
+}
+
+int cgyro_sim::check_hw_node(void)
+{
+       char name_node[256];
+       char hw_name[50];
+
+       DIR *iio_main_dir = NULL;
+       struct dirent *iio_dir_entry = NULL;
+
+       FILE *fp;
+       const char* orig_name = "K3G";
+       int find_node = 0;
+
+       struct stat lstat_buf;
+
+       if (lstat("/dev/gyro_sim",&lstat_buf) != 0)
+               DBG("Cannot find old style H/W node : /dev/gyro_sim for gyro_sim\n");
+       else {
+               if (S_ISCHR(lstat_buf.st_mode))
+                       return 1;
+               else
+                       ERR("It's not char device node : /dev/gyro_sim (not real device for gyro_sim)\n");
+       }
+
+       iio_main_dir = opendir("/sys/bus/iio/devices/");
+       if (!iio_main_dir) {
+               ERR("iio-style dir open failed to collect data\n");
+               return -1;
+       }
+
+       while ( (!find_node) && (iio_dir_entry = readdir(iio_main_dir)) ) {
+               if ( (strncasecmp(iio_dir_entry->d_name ,".",1 ) != 0) && 
+                       (strncasecmp(iio_dir_entry->d_name ,"..",2 ) != 0) && 
+                       (iio_dir_entry->d_ino != 0) && (strlen(iio_dir_entry->d_name)<9) ) {
+                       snprintf(name_node,sizeof(name_node),"/sys/bus/iio/devices/%s/name",iio_dir_entry->d_name);
+                       fp = fopen(name_node, "r");
+
+                       if (!fp) {
+                               DBG("Failed to open a sys_node or there is no node: %s , so retry it\n",name_node);                     
+                               continue;
+                       }
+               
+                       if ( fscanf(fp, "%s", hw_name) < 0) {
+                               fclose(fp);
+                               DBG("Failed to collect data from %s , so retry it\n",name_node);
+                               continue;
+                       }
+                       fclose(fp);
+       
+                       if ( (!strcasecmp(hw_name, orig_name )) ) {
+                               DBG("Find new style H/W  for gyro_sim(K3G)\n");
+                               find_node = 1;  
+                               break;
+                       }
+               }
+       }
+       closedir(iio_main_dir);
+
+       return find_node;
+}
+
+int cgyro_sim::check_sensitivity(int update)
+{
+       int fd;
+       int state;
+       unsigned char fs_range = 0x10;  // L3G4200D_FS_500DPS
+       
+       fd = open(m_resource , O_RDWR);
+       if ( fd < 0 )
+               return -1;
+
+       
+       if (update) {
+               m_sensitivity = L3G4200D_FS_500DPS_SENSITIVITY;
+       /*      switch (fs_range ) {
+                       case L3G4200D_FS_250DPS:
+                               m_sensitivity = L3G4200D_FS_250DPS_SENSITIVITY;
+                               break;
+
+                       case L3G4200D_FS_500DPS:
+                               m_sensitivity = L3G4200D_FS_500DPS_SENSITIVITY;
+                               break;
+
+                       case L3G4200D_FS_2000DPS:
+                               m_sensitivity = L3G4200D_FS_2000DPS_SENSITIVITY;
+                               break;
+
+                       default:
+                               close(fd);
+                               return -1;
+               }
+       */
+       }
+
+       DBG("Check sensitivity : 0x%x\n",fs_range);
+
+       close(fd);
+       return fs_range;        
+}
+
+
+
+cmodule *module_init(void *win, void *egl)
+{
+       cgyro_sim *sample;
+
+       try {
+               sample = new cgyro_sim();
+       } catch (int ErrNo) {
+               ERR("cgyro_sim class create fail , errno : %d , errstr : %s\n",ErrNo, strerror(ErrNo));
+               return NULL;
+       }
+
+       return (cmodule*)sample;
+}
+
+
+
+void module_exit(cmodule *inst)
+{
+       cgyro_sim *sample = (cgyro_sim*)inst;
+       delete sample;
+}
+
+
+
+//! End of a file
diff --git a/packaging/sf-plugin-gyro-emul-pkgs.manifest b/packaging/sf-plugin-gyro-emul-pkgs.manifest
new file mode 100644 (file)
index 0000000..017d22d
--- /dev/null
@@ -0,0 +1,5 @@
+<manifest>
+ <request>
+    <domain name="_"/>
+ </request>
+</manifest>
diff --git a/packaging/sf-plugin-gyro-emul-pkgs.spec b/packaging/sf-plugin-gyro-emul-pkgs.spec
new file mode 100644 (file)
index 0000000..7ae1313
--- /dev/null
@@ -0,0 +1,80 @@
+Name: sf-plugin-gyro-emul-pkgs
+Version: 0.3.4
+Release: 1
+Summary: Gyro plugin for sensor framework
+Group: System/Sensor Framework
+License: GNUv2
+Source0: %{name}-%{version}.tar.gz
+Source1001: packaging/sf-plugin-gyro-emul-pkgs.manifest
+BuildArch: i386
+ExclusiveArch: %{ix86}
+
+BuildRequires: cmake
+BuildRequires: pkgconfig(sf_common)
+BuildRequires: pkgconfig(vconf)
+
+%description
+
+%prep
+%setup -q
+
+%if ("%{_repository}" == "wearable")
+       export CFLAGS+=" -DWEARABLE"
+%endif
+
+%if ("%{_repository}" == "mobile")
+       export CFLAGS+=" -DMOBILE"
+%endif
+
+cmake . -DCMAKE_INSTALL_PREFIX=%{_prefix}
+
+%build
+
+make
+
+%install
+rm -rf %{buildroot}
+%make_install
+
+%clean
+make clean
+rm -rf CMakeCache.txt
+rm -rf CMakeFiles
+rm -rf cmake_install.cmake
+rm -rf Makefile
+rm -rf install_manifes.txt
+rm -rf *.so
+
+%if ("%{_repository}" == "wearable")
+       rm -rf wearable/sensor/CMakeFiles
+       rm -rf wearable/sensor/cmake_install.cmake
+       rm -rf wearable/sensor/Makefile
+       rm -rf wearable/sensor/*.so
+
+       rm -rf wearable/processor/CMakeFiles
+       rm -rf wearable/processor/cmake_install.cmake
+       rm -rf wearable/processor/Makefile
+       rm -rf wearable/processor/*.so
+%endif
+
+%if ("%{_repository}" == "mobile")
+       rm -rf mobile/sensor/CMakeFiles
+       rm -rf mobile/sensor/cmake_install.cmake
+       rm -rf mobile/sensor/Makefile
+       rm -rf mobile/sensor/*.so
+
+       rm -rf mobile/processor/CMakeFiles
+       rm -rf mobile/processor/cmake_install.cmake
+       rm -rf mobile/processor/Makefile
+       rm -rf mobile/processor/*.so
+%endif
+
+%post
+
+%postun
+
+%files
+%defattr(-,root,root,-)
+%{_prefix}/lib/sensor_framework/*.so*
+
+%changelog
diff --git a/wearable/CMakeLists.txt b/wearable/CMakeLists.txt
new file mode 100644 (file)
index 0000000..ea98268
--- /dev/null
@@ -0,0 +1,20 @@
+cmake_minimum_required(VERSION 2.6)
+project(gyro_sim_pkgs CXX)
+
+# to install pkgconfig setup file.
+SET(EXEC_PREFIX "\${prefix}")
+SET(LIBDIR "\${prefix}/lib")
+SET(INCLUDEDIR "\${prefix}/include")
+SET(VERSION 1.0)
+
+include(FindPkgConfig)
+pkg_check_modules(rpkgs REQUIRED vconf sf_common)
+add_definitions(${rpkgs_CFLAGS})
+
+set(PROJECT_MAJOR_VERSION "0")
+set(PROJECT_MINOR_VERSION "2")
+set(PROJECT_RELEASE_VERSION "1")
+set(CMAKE_VERBOSE_MAKEFILE OFF)
+
+add_subdirectory(sensor)
+add_subdirectory(processor)
diff --git a/wearable/processor/CMakeLists.txt b/wearable/processor/CMakeLists.txt
new file mode 100644 (file)
index 0000000..17acd0f
--- /dev/null
@@ -0,0 +1,16 @@
+cmake_minimum_required(VERSION 2.6)
+project(gyro_sim_processor CXX)
+
+add_definitions(-DUSE_ONLY_ONE_MODULE)
+
+add_definitions(-Wall -std=gnu++0x -O3 -omit-frame-pointer)
+#add_definitions(-Wall -g -D_DEBUG)
+add_definitions(-Iinclude)
+
+add_library(${PROJECT_NAME} SHARED
+       src/gyro_sim_processor.cpp
+)
+
+target_link_libraries(${PROJECT_NAME} ${rpkgs_LDFLAGS} ${GLES_LDFLAGS} "-lm")
+
+install(TARGETS ${PROJECT_NAME} DESTINATION lib/sensor_framework)
diff --git a/wearable/processor/include/gyro_sim_processor.h b/wearable/processor/include/gyro_sim_processor.h
new file mode 100644 (file)
index 0000000..f9070dc
--- /dev/null
@@ -0,0 +1,105 @@
+/*
+ * emulator-plugin-gyro-pkgs
+ *
+ * Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd. All rights reserved.
+ *
+ * Contact:
+ * Jinhyung Choi <jinhyung2.choi@samsung.com>
+ * SooYoung Ha <yoosah.ha@samsung.com>
+ * Sungmin Ha <sungmin82.ha@samsung.com>
+ * 
+ * This library is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by the
+ * Free Software Foundation; either version 2.1 of the License, or (at your option)
+ * any later version.
+ * 
+ * This library is distributed in the hope that it will be useful, but WITHOUT ANY
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library; if not, write to the Free Software Foundation, Inc., 51
+ * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+#if !defined(_GYRO_SIM_PROCESSOR_CLASS_H_)
+#define _GYRO_SIM_PROCESSOR_CLASS_H_
+
+class gyro_sim_processor : public cprocessor_module
+{
+public:
+    enum gyro_sim_data_id {
+        GYRO_BASE_DATA_SET = (0x0020<<16) | 0x0001,
+    };
+
+    enum gyro_sim_evet_type_t {
+        GYROSCOPE_EVENT_RAW_DATA_REPORT_ON_TIME = (0x0020 << 16) | 0x0001,
+    };
+
+    enum gyro_sim_cmd_property_t {
+        PROPERTY_CMD_START = 0,
+        PROPERTY_CMD_1,
+        PROPERTY_CMD_2,
+        PROPERTY_CMD_3,
+        PROPERTY_CMD_4,
+        PROPERTY_CMD_5,
+    };
+
+    gyro_sim_processor();
+    virtual ~gyro_sim_processor();
+
+    const char *name(void);
+    int id(void);
+    int version(void);
+    int get_processor_type(void);
+
+    bool update_name(char *name);
+    bool update_id(int id);
+    bool update_version(int version);
+
+    bool add_input(csensor_module *sensor);
+    bool add_input(cprocessor_module *processor);
+#if 0
+    long value(char *port);
+    long value(int id);
+#endif
+    cprocessor_module *create_new(void);
+    void destroy(cprocessor_module *module);
+
+    static void *working(void *inst);
+    static void *stopped(void *inst);
+
+    virtual bool start(void);
+    virtual bool stop(void);
+
+    long set_cmd(int type , int property , long input_value);
+    int get_property(unsigned int property_level , void *property_data );
+    int get_struct_value(unsigned int struct_type , void *struct_values);   
+
+protected:
+    bool update_polling_interval(unsigned long interval);
+
+private:
+    csensor_module *m_sensor;
+
+    long m_x;
+    long m_y;
+    long m_z;
+
+    long m_event;
+    long m_new_event;
+
+    long m_version;
+    long m_id;
+
+    char *m_name;
+
+    int m_client;
+
+    cmutex m_mutex;
+    cmutex m_value_mutex;
+};
+
+#endif
diff --git a/wearable/processor/src/gyro_sim_processor.cpp b/wearable/processor/src/gyro_sim_processor.cpp
new file mode 100644 (file)
index 0000000..7667e5a
--- /dev/null
@@ -0,0 +1,340 @@
+/*
+ * emulator-plugin-gyro-pkgs
+ *
+ * Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd. All rights reserved.
+ *
+ * Contact: 
+ * Jinhyung Choi <jinhyung2.choi@samsung.com>
+ * SooYoung Ha <yoosah.ha@samsung.com>
+ * Sungmin Ha <sungmin82.ha@samsung.com>
+ * DongKyun Yun <dk77.yun@samsung.com>
+ * 
+ * This library is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by the
+ * Free Software Foundation; either version 2.1 of the License, or (at your option)
+ * any later version.
+ * 
+ * This library is distributed in the hope that it will be useful, but WITHOUT ANY
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library; if not, write to the Free Software Foundation, Inc., 51
+ * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ * Contributors:
+ * - S-Core Co., Ltd
+ * 
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <errno.h>
+#include <dlfcn.h>
+#include <pthread.h>
+#include <string.h>
+#include <sys/un.h>
+#include <netinet/in.h>
+#include <math.h>
+#include <sys/select.h>
+#include <sys/time.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <linux/input.h>
+#include <dirent.h>
+
+#include <common.h>
+#include <cobject_type.h>
+#include <clist.h>
+#include <cmutex.h>
+#include <cmodule.h>
+//#include <csync.h>
+#include <cworker.h>
+#include <cpacket.h>
+#include <csock.h>
+#include <sf_common.h>
+
+#include <csensor_module.h>
+#include <cfilter_module.h>
+#include <cprocessor_module.h>
+#include <gyro_sim_processor.h>
+
+#include <vconf.h>
+
+gyro_sim_processor::gyro_sim_processor()
+: m_sensor(NULL)
+, m_x(-1)
+, m_y(-1)
+, m_z(-1)
+, m_event(0)
+, m_new_event(0)
+, m_version(1)
+, m_id(0x04BE)
+, m_client(0)
+{
+    m_name = strdup("gyro_sim_processor");
+    if ((!m_name)) {
+        throw ENOMEM;
+    }
+
+    register_supported_event(GYROSCOPE_EVENT_RAW_DATA_REPORT_ON_TIME);
+
+    cprocessor_module::set_main(working, stopped, this);
+}
+
+gyro_sim_processor::~gyro_sim_processor()
+{
+    free(m_name);
+}
+
+bool gyro_sim_processor::add_input(csensor_module *sensor)
+{
+    m_sensor = sensor;
+    return true;
+}
+
+bool gyro_sim_processor::add_input(cprocessor_module *processor)
+{
+    return true;
+}
+
+const char *gyro_sim_processor::name(void)
+{
+    return m_name;
+}
+
+int gyro_sim_processor::id(void)
+{
+    return m_id;
+}
+
+int gyro_sim_processor::version(void)
+{
+    return m_version;
+}
+
+bool gyro_sim_processor::update_name(char *name)
+{
+    char *new_name;
+    new_name = strdup(name);
+    if (!new_name) {
+        DbgPrint("No memory\n");
+        return false;
+    }
+
+    free(m_name);
+    m_name = new_name;
+    return true;
+}
+
+bool gyro_sim_processor::update_id(int id)
+{
+    m_id = id;
+    return true;
+}
+
+bool gyro_sim_processor::update_version(int version)
+{
+    m_version = version;
+    return true;
+}
+
+cprocessor_module *gyro_sim_processor::create_new(void)
+{
+    return (cprocessor_module*)this;
+}
+
+void gyro_sim_processor::destroy(cprocessor_module *module)
+{
+    bool bstate = false;
+
+    bstate = cmodule::del_from_list((cmodule *)module);
+
+    if ( !bstate ) {
+        ERR("Destory and del_from_list fail");
+        delete (gyro_sim_processor *)module;
+        return;
+    }
+}
+
+void *gyro_sim_processor::stopped(void *inst)
+{
+    return (void*)NULL;
+}
+
+void *gyro_sim_processor::working(void *inst)
+{   
+    csensor_module *sensor;
+       base_data_struct raw_data;
+
+    gyro_sim_processor *processor = (gyro_sim_processor*)inst;
+    if (!processor) {
+        ERR("There is no processor module instance at gyro_sim (%s)\n", __FUNCTION__ );
+        return (void*)cworker::STOPPED;
+    }
+
+    DBG("Gathering data\n");
+    if (!processor->m_sensor) {
+        ERR("Sensor is not added\n");
+        return (void*)cworker::STOPPED;
+    }
+
+    sensor = (csensor_module*)processor->m_sensor;
+
+    DBG("Invoke is_data_ready\n");
+
+    if (sensor->is_data_ready(true) == false) {
+        ERR("Data ready has failed\n");
+        return (void*)cworker::STARTED;     
+    }
+
+       sensor->get_struct_value(GYRO_BASE_DATA_SET, &raw_data);
+
+       processor->m_x = raw_data.values[0];
+       processor->m_y = raw_data.values[1];
+       processor->m_z = raw_data.values[2];
+
+    DBG("Data is ready now\n");
+
+    return (void*)cworker::STARTED;
+}
+#if 0
+long gyro_sim_processor::value(char *port)
+{
+    AUTOLOCK(m_value_mutex);
+    if (!strcasecmp(port, "pitch")) {
+        return m_x;
+    } else if (!strcasecmp(port, "roll")) {
+        return m_y;
+    } else if (!strcasecmp(port, "yaw")) {
+        return m_z;
+    }
+
+    return -1;
+}
+
+long gyro_sim_processor::value(int id)
+{
+    return -1;
+}
+#endif
+bool gyro_sim_processor::start(void)
+{
+    bool ret;
+    AUTOLOCK(m_mutex);
+
+    if (m_client > 0) {
+        m_client ++;
+        INFO("%s processor fake starting\n",m_name);
+        return true;
+    }
+
+    INFO("%s processor real starting\n",m_name);
+
+    ret = m_sensor ? m_sensor->start() : true;
+    if ( ret != true ) {
+        ERR("m_sensor start fail\n");
+        return false;
+    }
+
+    cprocessor_module::start();
+    m_client = 1;
+    return ret;
+}
+
+bool gyro_sim_processor::stop(void)
+{
+    bool ret;
+    AUTOLOCK(m_mutex);
+
+    if (m_client > 1) {
+        m_client --;
+        DBG("%s processor fake Stopping\n",m_name);
+        return true;
+    }
+
+    DBG("%s processor real Stopping\n",m_name);
+
+    ret = cprocessor_module::stop();
+    if ( ret != true ) {
+        ERR("cprocessor_module::stop()\n");
+        return false;
+    }
+
+    ret = m_sensor ? m_sensor->stop() : true;
+    if ( ret != true ) {
+        ERR("m_sensor stop fail\n");
+        return false;
+    }
+
+    m_client = 0;   
+    return ret;
+}
+
+long gyro_sim_processor::set_cmd(int type , int property , long input_value)
+{
+    return -1;
+}
+
+int gyro_sim_processor::get_property(unsigned int property_level , void *property_data )
+{
+    DBG("gyro_sim_processor called get_property , with property_level : 0x%x", property_level);
+    if (m_sensor) {
+        return m_sensor->get_property(property_level , property_data);      
+    } else {
+        ERR("no m_sensor , cannot get_struct_value from sensor\n");
+        return -1;
+    }
+}
+
+int gyro_sim_processor::get_struct_value(unsigned int struct_type , void *struct_values)
+{
+    if (m_sensor) {
+        if (struct_type == GYRO_BASE_DATA_SET) {
+            return m_sensor->get_struct_value(struct_type , struct_values);
+        } else {
+            ERR("does not support stuct_type\n");
+            return -1;
+        }
+    } else {
+        ERR("no m_sensor , cannot get_struct_value from sensor\n");
+        return -1;
+    }
+}
+
+bool gyro_sim_processor::update_polling_interval(unsigned long interval)
+{
+    return m_sensor->update_polling_interval(interval);
+}
+
+int gyro_sim_processor::get_processor_type(void)
+{
+    if (m_sensor)
+        return m_sensor->get_sensor_type();
+    else
+        return ID_GYROSCOPE;
+}
+
+cmodule *module_init(void *win, void *egl)
+{
+    gyro_sim_processor *inst;
+
+    try {
+        inst = new gyro_sim_processor();
+    } catch (int ErrNo) {
+        ERR("gyro_sim_processor class create fail , errno : %d , errstr : %s\n",ErrNo, strerror(ErrNo));
+        return NULL;
+    }
+
+    return (cmodule*)inst;
+}
+
+void module_exit(cmodule *inst)
+{
+    gyro_sim_processor *sample = (gyro_sim_processor*)inst;
+    delete sample;
+}
+
diff --git a/wearable/sensor/CMakeLists.txt b/wearable/sensor/CMakeLists.txt
new file mode 100644 (file)
index 0000000..bd28538
--- /dev/null
@@ -0,0 +1,16 @@
+cmake_minimum_required(VERSION 2.6)
+project(gyro_sim CXX)
+
+#add_definitions(-D_ESTIMATE_PERFORMANCE)
+#add_definitions(-D_DEFAULT_FONT_NAME="Vera")
+add_definitions(-Wall -O3 -omit-frame-pointer)
+#add_definitions(-Wall -g -D_DEBUG)
+add_definitions(-Iinclude)
+
+add_library(${PROJECT_NAME} SHARED
+       src/cgyro_sim.cpp
+)
+
+target_link_libraries(${PROJECT_NAME} ${rpkgs_LDFLAGS} ${GLES_LDFLAGS})
+
+install(TARGETS ${PROJECT_NAME} DESTINATION lib/sensor_framework)
diff --git a/wearable/sensor/include/cgyro_sim.h b/wearable/sensor/include/cgyro_sim.h
new file mode 100644 (file)
index 0000000..eff1a0c
--- /dev/null
@@ -0,0 +1,115 @@
+/*
+ * emulator-plugin-gyro-pkgs
+ *
+ * Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd. All rights reserved.
+ *
+ * Contact:
+ * Jinhyung Choi <jinhyung2.choi@samsnung.com>
+ * SooYoung Ha <yoosah.ha@samsnung.com>
+ * Sungmin Ha <sungmin82.ha@samsung.com>
+ * 
+ * This library is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by the
+ * Free Software Foundation; either version 2.1 of the License, or (at your option)
+ * any later version.
+ * 
+ * This library is distributed in the hope that it will be useful, but WITHOUT ANY
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library; if not, write to the Free Software Foundation, Inc., 51
+ * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+#if !defined(_GYRO_SIM_CLASS_H_)
+#define _GYRO_SIM_CLASS_H_
+
+class cgyro_sim : public csensor_module
+{
+public:
+    enum gyro_data_id {
+        GYRO_BASE_DATA_SET = (0x0020 << 16) | 0x0001,
+    };
+
+    enum gyro_sim_cmd_property_t {
+        PROPERTY_CMD_START = 0,
+        PROPERTY_CMD_1,
+        PROPERTY_CMD_2,
+        PROPERTY_CMD_3,
+        PROPERTY_CMD_4,
+        PROPERTY_CMD_5,
+    };
+
+    enum gyro_get_value_id_t {
+        VALUE_ID_X = 0,
+        VALUE_ID_Y = 1,
+        VALUE_ID_Z = 2,
+    };
+
+    cgyro_sim();
+    virtual ~cgyro_sim();
+
+    const char *name(void);
+    int version(void);
+    int id(void);
+
+    bool is_data_ready(bool wait=false);
+#if 0
+    long value(const char *port);
+    long value(int id);
+#endif
+    bool update_name(char *name);
+    bool update_version(int ver);
+    bool update_id(int id);
+
+    int port_count(void);
+    const char *port(int idx);
+
+    bool need_polling(void);
+    long polling_interval(void);
+    bool update_polling_interval(unsigned long val);
+    int get_sensor_type(void);
+    long set_cmd(int type , int property , long input_value);
+    int get_property(unsigned int property_level , void *property_data);
+    int get_struct_value(unsigned int struct_type , void *struct_values);   
+
+    bool check_hw_node(void);
+
+    bool start(void);
+    bool stop(void);
+
+    void reset(void);   
+    
+private:
+
+    static const char *m_port[];
+
+    char *m_name;
+    char *m_resource;
+    long m_id;
+    long m_version;
+    unsigned long m_polling_interval;
+
+    int m_x;    //pitch
+    int m_y;    //roll  
+    int m_z;    //yaw
+
+    unsigned long long m_fired_time;
+
+    bool update_value(void);
+
+    int m_client;
+    int m_sensor_type;
+
+    cmutex m_value_mutex;
+
+    int m_ioctl_fd;
+    float m_sensitivity;
+    bool m_hw_type_k3g;
+
+};
+
+#endif
diff --git a/wearable/sensor/src/cgyro_sim.cpp b/wearable/sensor/src/cgyro_sim.cpp
new file mode 100644 (file)
index 0000000..9ee23e1
--- /dev/null
@@ -0,0 +1,436 @@
+/*
+ * emulator-plugin-gyro-pkgs
+ *
+ * Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd. All rights reserved.
+ *
+ * Contact: 
+ * Jinhyung Choi <jinhyung2.choi@samsung.com>
+ * SooYoung Ha <yoosah.ha@samsung.com>
+ * Sungmin Ha <sungmin82.ha@samsung.com>
+ * DongKyun Yun <dk77.yun@samsung.com>
+ * 
+ * This library is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU Lesser General Public License as published by the
+ * Free Software Foundation; either version 2.1 of the License, or (at your option)
+ * any later version.
+ * 
+ * This library is distributed in the hope that it will be useful, but WITHOUT ANY
+ * WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
+ * License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this library; if not, write to the Free Software Foundation, Inc., 51
+ * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ * Contributors:
+ * - S-Core Co., Ltd
+ * 
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <errno.h>
+#include <dlfcn.h>
+#include <pthread.h>
+#include <string.h>
+#include <sys/un.h>
+#include <sys/time.h>
+#include <netinet/in.h>
+#include <sys/ioctl.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <dirent.h>
+
+#include <common.h>
+#include <cobject_type.h>
+#include <cmutex.h>
+#include <clist.h>
+#include <cmodule.h>
+#include <cpacket.h>
+//#include <csync.h>
+#include <cworker.h>
+#include <csock.h>
+#include <sf_common.h>
+
+#include <csensor_module.h>
+
+#include <cgyro_sim.h>
+
+#define PORT_COUNT 3
+
+#define SENSOR_NAME "Emul_ModelId_Gyro"
+#define SENSOR_VENDOR   "Emul_Vendor"
+
+#define SENSOR_NODE "/sys/devices/virtual/sensor/gyro"
+
+const char *cgyro_sim::m_port[] = {"x", "y", "z"};
+
+cgyro_sim::cgyro_sim()
+: m_name(NULL)
+, m_resource(NULL)
+, m_id(0x00200002)
+, m_version(1)
+, m_polling_interval(POLL_1HZ_MS)
+, m_x(-1)
+, m_y(-1)
+, m_z(-1)
+, m_fired_time(0)
+, m_client(0)
+, m_sensor_type(ID_GYROSCOPE)
+, m_sensitivity(17.50)
+{
+    m_name = strdup("gyro_sim");
+    m_resource = strdup(SENSOR_NODE);
+    if ((!m_name) ||(!m_resource)) {
+        throw ENOMEM;
+    }
+}
+
+cgyro_sim::~cgyro_sim()
+{
+    free(m_name);
+    free(m_resource);
+}
+
+const char *cgyro_sim::name(void)
+{
+    return m_name;
+}
+
+int cgyro_sim::version(void)
+{
+    return m_version;
+}
+
+int cgyro_sim::id(void)
+{
+    return m_version;
+}
+
+bool cgyro_sim::update_value(void)
+{
+    FILE *fp;
+    short gyro_raw[3];
+    char raw_data_node[256];
+
+    snprintf(raw_data_node,sizeof(raw_data_node),"%s/gyro_x_raw",m_resource);
+    fp = fopen(raw_data_node, "r");
+    if (!fp) {
+        ERR("Failed to open a raw_data node : %s\n",raw_data_node);
+        return false;
+    }
+    if ( fscanf(fp, "%hd", &gyro_raw[0]) != 1 ) {
+        ERR("Failed to collect data from : %s",raw_data_node);
+        fclose(fp);
+        return true;
+    }
+    fclose(fp);
+
+    snprintf(raw_data_node,sizeof(raw_data_node),"%s/gyro_y_raw",m_resource);
+    fp = fopen(raw_data_node, "r");
+    if (!fp) {
+        ERR("Failed to open a raw_data node : %s\n",raw_data_node);
+        return false;
+    }
+    if ( fscanf(fp, "%hd", &gyro_raw[1]) != 1 ) {
+        ERR("Failed to collect data from : %s",raw_data_node);
+        fclose(fp);
+        return true;
+    }
+    fclose(fp);
+    
+    snprintf(raw_data_node,sizeof(raw_data_node),"%s/gyro_z_raw",m_resource);
+    fp = fopen(raw_data_node, "r");
+    if (!fp) {
+        ERR("Failed to open a raw_data node : %s\n",raw_data_node);
+        return false;
+    }
+    if ( fscanf(fp, "%hd", &gyro_raw[2]) != 1 ) {
+        ERR("Failed to collect data from : %s",raw_data_node);
+        fclose(fp);
+        return true;
+    }
+    fclose(fp);
+
+    AUTOLOCK(m_value_mutex);
+    m_x = gyro_raw[0];
+    m_y = gyro_raw[1];
+    m_z = gyro_raw[2];      
+
+    DBG("Update done raw : %d, %d, %d , out_data : %d, %d, %d\n", gyro_raw[0],gyro_raw[1],gyro_raw[2],m_x, m_y, m_z);
+
+    return true;
+}
+
+bool cgyro_sim::is_data_ready(bool wait)
+{
+    unsigned long long cur_time;
+    unsigned long elapsed_time;
+    struct timeval sv;
+    bool ret = false;
+
+    DbgPrint("Sensor, invoked\n");
+    gettimeofday(&sv, NULL);
+    cur_time = MICROSECONDS(sv);
+
+    elapsed_time = (unsigned long)(cur_time - m_fired_time);
+    if (elapsed_time < m_polling_interval) {
+        DbgPrint("Waiting\n");
+        if (wait) {
+            usleep(m_polling_interval - elapsed_time);
+            m_fired_time = cur_time + (m_polling_interval-elapsed_time);
+            ret = update_value();
+        } else {
+            ret = true;
+        }
+    } else {
+        DbgPrint("Re-firing %llu %llu\n", cur_time, m_fired_time);
+        DbgPrint("elapsed_time %lu polling_interval %ld\n", elapsed_time, m_polling_interval);
+        m_fired_time = cur_time;
+        ret = update_value();
+    }
+
+    return ret;
+}
+#if 0
+long cgyro_sim::value(const char *port)
+{
+    AUTOLOCK(m_value_mutex);
+
+    if (!strcasecmp(port, "x")) {
+        return m_x;
+    } else if (!strcasecmp(port, "y")) {
+        return m_y;
+    } else if (!strcasecmp(port, "z")) {
+        return m_z;
+    }
+
+    return -1;
+}
+
+long cgyro_sim::value(int id)
+{
+    AUTOLOCK(m_value_mutex);
+
+    if (id == VALUE_ID_X) {
+        return m_x;
+    } else if (id == VALUE_ID_Y) {
+        return m_y;
+    } else if (id == VALUE_ID_Z) {
+        return m_z;
+    }
+
+    return -1;
+}
+#endif
+void cgyro_sim::reset(void)
+{
+    return;
+}
+
+bool cgyro_sim::update_name(char *name)
+{
+    char *new_name;
+    new_name = strdup(name);
+    if (!new_name) {
+        DbgPrint("No memory\n");
+        return false;
+    }
+
+    free(m_name);
+    m_name = new_name;
+    return true;
+}
+
+bool cgyro_sim::update_version(int version)
+{
+    m_version = version;
+    return true;
+}
+
+bool cgyro_sim::update_id(int id)
+{
+    m_id = id;
+    return true;
+}
+
+int cgyro_sim::port_count(void)
+{
+    return PORT_COUNT;
+}
+
+const char *cgyro_sim::port(int idx)
+{
+    if (idx >= (int)(sizeof(m_port)/sizeof(const char*))) {
+        return NULL;
+    }
+
+    return m_port[idx];
+}
+
+bool cgyro_sim::need_polling(void)
+{
+    return m_polling_interval != 0;
+}
+
+long cgyro_sim::polling_interval(void)
+{
+    return (long)m_polling_interval;
+}
+
+bool cgyro_sim::update_polling_interval(unsigned long val)
+{
+    AUTOLOCK(m_mutex);
+    DbgPrint("Update polling interval %lu\n", val);
+    m_polling_interval = val;
+    return true;
+}
+
+bool cgyro_sim::start(void)
+{
+
+    AUTOLOCK(m_mutex);
+
+    if (m_client > 0) {
+        m_client++;
+        INFO("Gyro sensor fake starting, client cnt = %d\n", m_client);
+        return true;
+    }
+
+    m_client = 1;
+    m_fired_time = 0;
+    INFO("Gyro sensor real starting, client cnt = %d\n", m_client);
+    return true;
+}
+
+bool cgyro_sim::stop(void)
+{
+
+    AUTOLOCK(m_mutex);
+
+    INFO("gyro_sensor client cnt = %d\n", m_client);
+
+    if (m_client > 1) {
+        m_client--;
+        INFO("Gyro sensor fake stopping, client cnt = %d\n", m_client);
+        return true;
+    }
+
+    m_client = 0;
+    INFO("Gyro sensor real stopping, client cnt = %d\n", m_client);
+    return true;
+}
+
+int cgyro_sim::get_sensor_type(void)
+{
+    return m_sensor_type;
+}
+
+long cgyro_sim::set_cmd(int type , int property , long input_value)
+{
+    ERR("Cannot support any cmd\n");        
+
+    return -1;
+}
+
+int cgyro_sim::get_property(unsigned int property_level , void *property_data)
+{
+    DBG("gyro_sensor called get_property , with property_level : 0x%x", property_level);
+
+    if (property_level == GYRO_BASE_DATA_SET) {
+        base_property_struct *return_property;
+        return_property = (base_property_struct *)property_data;
+        return_property->sensor_unit_idx = IDX_UNIT_DEGREE_PER_SECOND;
+        return_property->sensor_min_range = -(m_sensitivity * 32768 / 1000);
+        return_property->sensor_max_range = (m_sensitivity * 32767 / 1000);
+        snprintf(return_property->sensor_name,   sizeof(return_property->sensor_name),   SENSOR_NAME  );
+        snprintf(return_property->sensor_vendor, sizeof(return_property->sensor_vendor), SENSOR_VENDOR);
+        return_property->sensor_resolution = (m_sensitivity/1000);
+        return 0;
+    } else {
+        ERR("Does not support property_level : %d\n",property_level);
+    }
+    return -1;
+}
+
+int cgyro_sim::get_struct_value(unsigned int struct_type , void *struct_values)
+{
+    const int chance = 3;
+    int retry = 0;
+
+    if (struct_type == GYRO_BASE_DATA_SET) {
+        while ((m_fired_time == 0) && (retry++ < chance)) {
+            INFO("Try usleep for getting a valid BASE DATA value");
+            usleep(m_polling_interval * 1000llu);
+        }
+        if (m_fired_time == 0) {
+            ERR("get_struct_value failed");
+            return -1;
+        }
+
+        base_data_struct *return_struct_value = NULL;
+        return_struct_value = (base_data_struct *)struct_values;
+        if ( return_struct_value ) {
+            AUTOLOCK(m_value_mutex);
+            return_struct_value->data_accuracy = ACCURACY_NORMAL;
+            return_struct_value->data_unit_idx = IDX_UNIT_DEGREE_PER_SECOND;
+            return_struct_value->time_stamp = m_fired_time ;
+            return_struct_value->values_num = 3;
+            return_struct_value->values[0] = (m_x * m_sensitivity / 1000 );
+            return_struct_value->values[1] = (m_y * m_sensitivity / 1000 );
+            return_struct_value->values[2] = (m_z * m_sensitivity / 1000 );
+            return 0;
+        } else {
+            ERR("return struct_value point error\n");
+        }
+    } else {
+        ERR("Does not support type , struct_type : %d \n",struct_type);
+    }
+    return -1;
+}
+
+bool cgyro_sim::check_hw_node(void)
+{
+    char name_node[256];
+    char hw_name[50];
+
+    FILE *fp;
+    const char* orig_name = "K3G";
+    int find_node = 0;
+
+
+    snprintf(name_node,sizeof(name_node),"%s/name", SENSOR_NODE);
+    fp = fopen(name_node, "r");
+
+    if (!fp) {
+        DBG("Failed to open a sys_node or there is no node: %s , so retry it\n",name_node);
+        return false;
+    }
+
+    fclose(fp);
+    return true;
+}
+
+cmodule *module_init(void *win, void *egl)
+{
+    cgyro_sim *sample;
+
+    try {
+        sample = new cgyro_sim();
+    } catch (int ErrNo) {
+        ERR("cgyro_sim class create fail , errno : %d , errstr : %s\n",ErrNo, strerror(ErrNo));
+        return NULL;
+    }
+
+    return (cmodule*)sample;
+}
+
+void module_exit(cmodule *inst)
+{
+    cgyro_sim *sample = (cgyro_sim*)inst;
+    delete sample;
+}
+