saleae-iec-analyser/docs/Analyzer SDK Setup.md

330 lines
16 KiB
Markdown
Raw Normal View History

# Setting up an Analyzer SDK Project
This document details setting up your analyzer project for development on Windows, Mac, and Linux.
Documentation for the Analyzer SDK code is still in the older Saleae Analyzer SDK.pdf.
## Initial Setup (All Platforms)
Before continuing this setup guide, please follow the instructions in the readme file to download, fork or clone this repository, and then run the rename_analyzer.py script.
## Visual Studio
To build on Windows, open the visual studio project in the Visual Studio folder, and build. The Visual Studio solution has configurations for 32 bit and 64 bit builds. You will likely need to switch the configuration to 64 bit and build that in order to get the analyzer to load in the Windows software.
To test your analyzer, you will need to tell the Saleae Logic software where to load find your compiled analyzer dll.
The four build combinations produce analyzer dll files in the following locations:
```
.\Visual Studio\Win32\Debug\<Your Analyzer's Name>Analyzer.dll
.\Visual Studio\Win32\Release\<Your Analyzer's Name>Analyzer.dll
.\Visual Studio\x64\Debug\<Your Analyzer's Name>Analyzer.dll
.\Visual Studio\x64\Release\<Your Analyzer's Name>Analyzer.dll
```
Instructions to tell the Saleae Logic software where to find your new analyzer dll can be found here:
[How to set the developer directory in the Saleae software to use third party or user created analyzers.](http://support.saleae.com/hc/en-us/articles/208667506)
Once you have set that directory and restarted the software, your new custom analyzer should appear in the list of analyzers you can add.
## Debugging an Analyzer with Visual Studio
Newer versions of the Saleae software cannot be used to debug custom analyzers on Windows. This means that older versions of the software and SDK must be used if you wish to attach a debugger and step through your code. This complicates debugging on Windows, unfortunately, but it can be done.
*Note: it is impossible to attach a debugger to any version of the software that supports the new products. We are working on a solution to this problem, but for now that means you must rely on the simulation data generator for your analyzer to produce captures you can then debug in the older software.*
To debug your custom analyzer, you will need to download the 32-bit standalone copy of our older, 1.1.18 software.
http://downloads.saleae.com/betas/1.1.18/Logic1.1.18BetaWin32Standalone.zip
This is a sandalone download and does not need to be installed. Just extract the zip file and run the contained Logic.exe.
Please note - switching between Saleae Logic software versions has a tendency to reset the software's settings. This could cause the analyzer developer directory to get reset. If you no longer see your analyzer in the list, please verify that the analyzer developer directory is still set properly.
To build and and debug your custom analyzer using the 1.1.14 software, follow these steps:
- Using Visual Studio, open the solution file in the Visual Studio Folder.
- Select the solution configuration "Debug-Legacy-1.1.14"
- Select the platform "Win32"
- Build the solution
- Launch the 1.1.18 32-bit Logic software. If the analyzer directory is not already configured, set that to the `Visual Studio\Win32\Debug-Legacy-1.1.14` directory, and restart the software.
- The analyzer should now be visible in the list of analyzers you can add.
- In visual studio, open the Debug Menu, and select "Attach to process..."
- Locate Logic.exe in the list, select it, and click the Attach button.
- Add a break point on any line near the top of the WorkerThread() function, such as line 27, mSampleRateHz = GetSampleRate();
- In the Logic software, add your custom analyzer if you haven't already, and start a simulation.
- The breakpoint should hit
Optionally you can change the debugger command in visual studio to point to the older Logic.exe binary. Then you will be able to start debugging simply by pressing run in Visual Studio.
**Common issues on Windows**
- The software says "Unable to 'LoadLibrary' on dll ... is not a valid Win32 application"
This is most likely because the analyzer was not built for the same platform architecture as the software running it. In almost all cases, this means the analyzer was compiled for 32 bit instead of 64 bit. Details to switch from 32 bit to 64 bit are included in the Analyzer SDK documentation on page 9. First, [add a x64 target to your project](https://msdn.microsoft.com/en-us/library/ms185328(v=vs.120).aspx). Then, edit the linker settings for the 64 bit configuration. Change the additional dependencies item from Analyzer.dll to Analyzer64.dll.
Note: Only the software versions 1.1.16 and later were built for 64 bit. Previous releases, including 1.1.15, were 32 bit only, which is why no 64 bit analyzer dll was provided.
- The Saleae software crashes on launch when the debugger is attached.
Versions after about 1.1.18 no longer allow debuggers to attach. In these cases, we recommend building with the 32 bit version of the 1.1.18 beta and the 1.1.14 SDK, and debug there. This restriction only applies to Windows.
## Linux
*Note: When using git clone, please remember to use --recursive to automatically also clone the AnalyzerSDK submodule*
After you have cloned, forked, or downloaded the repository, and ran the rename_analyzer.py script, there are two additional steps required to run the analyzer.
First, if you are using Linux 64 bit, you need to delete the 32 bit libAnalyzer.so file, and rename the libAnalyzer64.so file to just libAnalyzer.so.
```
mv AnalyzerSDK/lib/libAnalyzer64.so AnalyzerSDK/lib/libAnalyzer.so
```
Then run build_analyzer.py
```
python build_analyzer.py
```
That's it! To debug the analyzer, you need to first tell the Saleae Logic software where to find your newly compiled *.so file.
[How to set the developer directory in the Saleae software to use third party or user created analyzers.](http://support.saleae.com/hc/en-us/articles/208667506)
The two variants of the newly compiled analyzer can be found here:
```
debug/lib<Your Analyzer's Name>Analyzer.so
release/lib<Your Analyzer's Name>Analyzer.so
```
### Debugging with GDB on Linux
To debug your analyzer, you will need to attach gdb to the Logic application, something like this:
```
gdb /Home/YourUserName/Desktop/Logic 1.2.14 (64-bit)/Logic
```
And then test setting a breakpoint like this:
```
break MyAnalyzer::WorkerThread
```
Because your analyzer hasn't been loaded yet, GDB will notify you that it can't find this function, and ask if you want to automatically set this breakpoint if a library with a matching function is loaded in the future. Type y <enter>
Then type run to start the application. Add your custom analyzer and start a simulation. This will trigger the breakpoint.
## MacOS
### Build Script Based Project
*Note: When using git clone, please remember to use --recursive to automatically also clone the AnalyzerSDK submodule*
After you have cloned, forked, or downloaded the repository, and ran the rename_analyzer.py script, there is one additional step required to run the analyzer.
run build_analyzer.py
```
python build_analyzer.py
```
That's it! To debug the analyzer, you need to first tell the Saleae Logic software where to find your newly compiled *.dylib file.
[How to set the developer directory in the Saleae software to use third party or user created analyzers.](http://support.saleae.com/hc/en-us/articles/208667506)
```
debug/lib<Your Analyzer's Name>Analyzer.dylib
release/lib<Your Analyzer's Name>Analyzer.dylib
```
### Debugging with GDB on MacOS
To debug your analyzer, you will need to attach gdb to the Logic application, something like this:
```
gdb /Applications/Logic.app/Contents/MacOS/Logic
```
And then test setting a breakpoint like this:
```
break MyAnalyzer::WorkerThread
```
Because your analyzer hasn't been loaded yet, GDB will notify you that it can't find this function, and ask if you want to automatically set this breakpoint if a library with a matching function is loaded in the future. Type y <enter>
Then type run to start the application. Add your custom analyzer and start a simulation. This will trigger the breakpoint.
### XCode Based Project
**Note: This section hasn't yet been updated to describe the proper setup using a fork or clone of the new Github repository for the Sample Analyzer. The instructions will still work, but need improvement to work well with the git repository.**
This section was written using the 1.1.32 Analyzer SDK, Xcode version 7.2.1, and OSX 10.10.5. however it is likely to work with other versions as well.
- Start Xcode
- Click "Create a new Xcode project"
![1](./images/1_-_new_project.png)
- select "Other" from the left column, and "Empty" from the templates list.
- Click next.
![2](./images/2_-_empty_project.png)
- Enter a name for your Xcode Project.
![2.5](./images/2_5_analyzer_name.png)
- The location should be set to the analyzer SDK folder recently downloaded, "SaleaeAnalyzerSdk-1.1.32". Do not create a new folder, this will be done for you by Xcode.
- Click "Create"
![2.75](./images/2_75_-_project_location.png)
- Back in Finder, copy the file "rename_analyzer.py" and "source" from the downloaded SDK directory into the freshly created folder, which will have the same name as your new analyzer. Shown here the name is "XcodeAnalyzer"
![3](./images/3_-_copy_files.png)
- Open a terminal, and browse to the new project folder in the downloaded SDK folder.
- Run the python script with:
python rename_analyzer.py
- first, it will prompt you for the class prefix for all of the source files. All classes and files will be re-named with this prefix. If you type "I2C" the classes and files will be named with "I2CAnalyzer". Please avoid using analyzer in this name, as it will get repeated like this: "I2CAnalyzerAnalyzer"
- Second, it will ask you for the name to display to the user in the "Add Analyzers" menu. This should be the user facing name, and can include spaces.
![4](./images/4_-_rename_analyzer_script.png)
- Next, we need to add a target to the Xcode project. Be sure that the project is selected in the Project Navigator on the left, and then click the menu highlighted below to add a target.
![5](./images/5_-_add_target_button.png)
- This is the target menu.
![6](./images/6_-_add_target_menu.png)
- Select "Framework & Library" under "OS X" in the left column, and select "Library" in the main area.
- Click Next.
![7](./images/7_-_library_target.png)
- Enter a product name, we recommend the the same name as the project, since there will only be one product.
- Under framework, select "None (Plain C/C++ Library)
- For Type, select "Dynamic"
![8](./images/8_-_library_settings.png)
- Next, we need to add the source files. Click File -> Add Files to "<project name>"...
- Note: if this is disabled, it is because you do not have the project selected in the Project Navigator.
![8.5](./images/8_5_-_add_files_menu.png)
- Browse to the source folder in the Xcode project folder, and select it. Don't select the contents, be sure to select the folder itself.
- select "Create groups" in the "added folders" section.
- Click Add.
![9](./images/9_-_add_files.png)
- Verify that the files were automatically added to the build phases "Compile Sources" and "Headers".
- Select the project from the Project Navigator if not already selected.
- Click "Build Phases".
- Expand "Compile Sources" and "Headers"
- Under "Headers", also expand "Project".
- Verify that each has 4 files.
![9.5](./images/9_5_-_verify_sources_added.png)
- Click "Build Settings"
- If "Levels" is selected, switch it to "Combined"
![10](./images/10_-_build_settings_page.png)
- Expand the section "Search Paths"
- Locate "Header Search Paths" and edit the value.
- Click the "+" button and enter "../include" in the new entry.
![11](./images/11_-_header_includes_search_path.png)
- Locate "Library Search Paths" in the same section, and edit its value.
- Click the "+" button and enter "../lib" in the new entry.
![11.5](./images/11_5_-_add_library_path.png)
- Return to "Build Phases" and expand the section "Link Binary with Libraries"
- Click the "+" button
![12](./images/12_-_add_library_part_1.png)
- Click "Add Other..."
![13](./images/13_-_add_library_part_2.png)
- Browse to the original SDK folder which contains our Xcode folder.
- Open the "lib" folder
- Select "libAnalyzer.dylib"
- Click Open.
![14](./images/14_-_add_library_part_3.png)
- At this point, you should build the project, so that the resulting library will be created.
- It's worth mentioning that new Xcode versions do not save build outputs in the project directory. Instead, the default output directory looks like this:
~/Library/Developer/Xcode/DerivedData
- You may want to change it. **The following steps are optional**
**Optional: change build output folder**
- Optional step 1: From the file menu, select "Project Settings..."
![optional 1](./images/optional_-_project_settings_-_edit_products_folder_menu.png)
- Optional step 2: in the "Derived Data" dropdown, select "Project-relative Location"
- Click "Done"
![optional 2](./images/optional_-_Project_Settings.png)
- That's it for the optional steps.
### Running and Debugging your Analyzer
- Next we will setup debugging for the project. Be sure to have the latest Saleae Logic Software installed.
- On the Product menu at the top of the screen, select "Scheme" -> "Edit Scheme..."
![15](./images/15_-_edit_scheme.png)
- Make sure "Run" is selected on the left.
- Under "Executable" select "Other..."
![16](./images/16_-_debug_launch_app_menu.png)
- Browse to the "Applications" folder (or wherever Logic is installed) and select "Logic.app"
- Click Choose.
![17](./images/17_-_select_debug_program.png)
- Set a breakpoint in the software so that we can test debugging.
- Open "XcodeAnalyzer.cpp" on the left. The name will reflect what you selected as the class prefix in a previous step. In this example, the class prefix was "Xcode".
- In the source file, add a break point to the first line of code in the WorkerThread method. This code runs when the analyzer starts processing data.
![18](./images/18_-_breakpoint_set.png)
- Before proceeding, see this article with instructions to configure the software to load your new analyzer: https://trello.com/c/LEFlqhlL
- Be sure to select the folder where the debug version of the custom analyzer is is saved.
- Once the Saleae logic software has been configured, and has been closed, click run from Xcode.
- The Saleae software should launch a few seconds later. Click the "+" button on the analyzers panel, and then select your analyzer. In this case, the user facing name of the analyzer was set by the Python script to "Xcode Analyzer". Yours may be different.
- If your analyzer is missing, it could indicate that the dylib was not created, or that the developer path was not set properly. Please review the previous steps for any possible errors.
- The settings dialog for your custom analyzer will appear. Click "Save".
![19](./images/19_-_logic_software_add_analyzer_menu.png)
- Here is your fresh new analyzer, now added to the software. Note that our breakpoint hasn't fired yet. If you had captured data previously, it might fire now, since analyzers will automatically start processing if they are added to an existing analyzer.
![20](./images/20_-_analyzer_in_Logic.png)
- Press start to start a simulation.
- Since your analyzer has already been added, the simulator will call your simulation data generator code. The analyzer also starts processing the moment data has been captured, so your breakpoint should fire immediately.
![21](./images/21_-_logic_software_start_button.png)
- Here you can see that the debugger was attached and your break point has been hit. You can examine variables, set new break points, or press continue from the debug menu at the bottom.
![22](./images/22_-_breakpoint_hit.png)
- Congratulations! You now have an Xcode project for which you can use to develop a custom analyzer for the Saleae software.
If you have any questions, please contact support.