Wednesday, November 16, 2011

Magic Safari Disappearing Trick

Maybe its an old developer bug/Easter egg, or a iPhone 2G jailbreak shadow hanging on, but since I can remember (iPhone 3G iOS3, iPhone 3GS iOS4, iPhone 4S iOS5) triple tapping my Safari icon will make it disappear and the only way to bring it back is to move the icons around which makes it pop back, but it still won't work anymore.  I have to restart the phone to make it work, otherwise I need to use the taskbar or search in Spotlight to open the app.  None of my co-workers or family have the phenomenon.  Anyone else?

Tuesday, November 15, 2011

Shortcuts to WiFi and Other Settings on iPhone Homescreen

Finally! One click access to the WiFi switch without having to jailbreak.

http://iphoneza.co.za/IconSettings/

Thx u for the WiFiz.

Friday, November 11, 2011

Broken Visual Studio 2008/2010 Wizards?

On multiple computers at various times I have run into this INSANELY frustrating issue where creating a new project in Microsoft Visual Studio 2008 or 2010 will fail when the created project type brings up one of those Application Wizard screens.  The symptom is that instead of the Wizard showing its content a File Download window pops up asking if you want to save, open, or cancel the download of Default.htm.  Microsoft is surprisingly quiet on the issue, but its gone on a for a long time, since the IE7 days and VS2005, judging from the forums. I searched for "Visual Studio Wizard Navigation to this webpage cancelled" and every variant I could think of and tried multiple solutions until I found this: Microsoft Forum that at the very bottom linked to this: Registry Keys to Fix the Problem in which you can find the ".htm" fixer.  The registry keys that it defines are extensive, and I haven't gone through all of the file to see what exactly it does, but it does work.  Disclaimer is that I've only used this on Windows 7 32-bit.

Here is a listing of the registry keys from the second link, for posterity:
Windows Registry Editor Version 5.00
[-HKEY_CLASSES_ROOT\.htm]
[HKEY_CLASSES_ROOT\.htm]"PerceivedType"="text"@="htmlfile""Content Type"="text/html"
[HKEY_CLASSES_ROOT\.htm\OpenWithList]
[HKEY_CLASSES_ROOT\.htm\OpenWithList\notepad.exe]@=""
[HKEY_CLASSES_ROOT\.htm\PersistentHandler]@="{eec97550-47a9-11cf-b952-00aa0051fe20}"
[HKEY_CLASSES_ROOT\htmlfile]"AppUserModelID"="Microsoft.InternetExplorer.Default"@="HTML Document""FriendlyTypeName"="@C:\\Windows\\System32\\ieframe.dll,-912"
[HKEY_CLASSES_ROOT\htmlfile\CLSID]@="{25336920-03F9-11cf-8FD0-00AA00686F13}"
[HKEY_CLASSES_ROOT\htmlfile\DefaultIcon]@=hex(2):25,00,50,00,72,00,6f,00,67,00,72,00,61,00,6d,00,46,00,69,00,6c,00,65,\  00,73,00,25,00,5c,00,49,00,6e,00,74,00,65,00,72,00,6e,00,65,00,74,00,20,00,\  45,00,78,00,70,00,6c,00,6f,00,72,00,65,00,72,00,5c,00,69,00,65,00,78,00,70,\  00,6c,00,6f,00,72,00,65,00,2e,00,65,00,78,00,65,00,2c,00,2d,00,31,00,37,00,\  00,00
[HKEY_CLASSES_ROOT\htmlfile\ScriptHostEncode]@="{0CF774D0-F077-11D1-B1BC-00C04F86C324}"
[HKEY_CLASSES_ROOT\htmlfile\shell]@="opennew"
[HKEY_CLASSES_ROOT\htmlfile\shell\open]@="Open in S&ame Window""MUIVerb"="@C:\\Windows\\System32\\ieframe.dll,-5732"
[HKEY_CLASSES_ROOT\htmlfile\shell\open\command]@="\"C:\\Program Files (x86)\\Internet Explorer\\iexplore.exe\" -nohome"
[HKEY_CLASSES_ROOT\htmlfile\shell\open\ddeexec]@="\"file://%1\",,-1,,,,,""NoActivateHandler"=""
[HKEY_CLASSES_ROOT\htmlfile\shell\open\ddeexec\Application]@="IExplore"
[HKEY_CLASSES_ROOT\htmlfile\shell\open\ddeexec\Topic]@="WWW_OpenURL"
[HKEY_CLASSES_ROOT\htmlfile\shell\opennew]@="&Open""MUIVerb"="@C:\\Windows\\System32\\ieframe.dll,-5731"
[HKEY_CLASSES_ROOT\htmlfile\shell\opennew\command]@="\"C:\\Program Files (x86)\\Internet Explorer\\iexplore.exe\" %1"
[HKEY_CLASSES_ROOT\htmlfile\shell\opennew\ddeexec]@="\"%1\",,-1,0,,,,""NoActivateHandler"=""
[HKEY_CLASSES_ROOT\htmlfile\shell\opennew\ddeexec\Application]@="IExplore"
[HKEY_CLASSES_ROOT\htmlfile\shell\opennew\ddeexec\IfExec]@="*"
[HKEY_CLASSES_ROOT\htmlfile\shell\opennew\ddeexec\Topic]@="WWW_OpenURLNewWindow"
[HKEY_CLASSES_ROOT\htmlfile\shell\print]
[HKEY_CLASSES_ROOT\htmlfile\shell\print\command]@=hex(2):72,00,75,00,6e,00,64,00,6c,00,6c,00,33,00,32,00,2e,00,65,00,78,00,65,\  00,20,00,25,00,77,00,69,00,6e,00,64,00,69,00,72,00,25,00,5c,00,73,00,79,00,\  73,00,74,00,65,00,6d,00,33,00,32,00,5c,00,6d,00,73,00,68,00,74,00,6d,00,6c,\  00,2e,00,64,00,6c,00,6c,00,2c,00,50,00,72,00,69,00,6e,00,74,00,48,00,54,00,\  4d,00,4c,00,20,00,22,00,25,00,31,00,22,00,00,00
[HKEY_CLASSES_ROOT\htmlfile\shell\printto]
[HKEY_CLASSES_ROOT\htmlfile\shell\printto\command]@=hex(2):72,00,75,00,6e,00,64,00,6c,00,6c,00,33,00,32,00,2e,00,65,00,78,00,65,\  00,20,00,25,00,77,00,69,00,6e,00,64,00,69,00,72,00,25,00,5c,00,73,00,79,00,\  73,00,74,00,65,00,6d,00,33,00,32,00,5c,00,6d,00,73,00,68,00,74,00,6d,00,6c,\  00,2e,00,64,00,6c,00,6c,00,2c,00,50,00,72,00,69,00,6e,00,74,00,48,00,54,00,\  4d,00,4c,00,20,00,22,00,25,00,31,00,22,00,20,00,22,00,25,00,32,00,22,00,20,\  00,22,00,25,00,33,00,22,00,20,00,22,00,25,00,34,00,22,00,00,00
[-HKEY_CLASSES_ROOT\htmlfile_FullWindowEmbed]
[HKEY_CLASSES_ROOT\htmlfile_FullWindowEmbed]@="HTML Plugin Document""AppUserModelID"="Microsoft.InternetExplorer.Default"
[HKEY_CLASSES_ROOT\htmlfile_FullWindowEmbed\CLSID]@="{25336921-03F9-11CF-8FD0-00AA00686F13}"
[-HKEY_CLASSES_ROOT\SystemFileAssociations\.htm]
[HKEY_CLASSES_ROOT\SystemFileAssociations\.htm]"PerceivedType"="document"
[HKEY_CLASSES_ROOT\SystemFileAssociations\.htm\ShellEx]
[HKEY_CLASSES_ROOT\SystemFileAssociations\.htm\ShellEx\{8895b1c6-b41f-4c1c-a562-0d564250836f}]@="{f8b8412b-dea3-4130-b36c-5e8be73106ac}"
[-HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\FileExts\.htm]
[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\FileExts\.htm]
[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\FileExts\.htm\OpenWithProgids]"htmlfile"=hex(0):

Wednesday, September 21, 2011

Play Spotify Over Airplay from Mac

How on Earth are we going to do this (for free)?!  Without this feature Spotify is little more than background noise for me.

Potentially useful tools available to us:
MacPorts
DarkIce
IceCast
Jack
Soundflower

I will be noodling this one, feel free to join in!

Wednesday, September 14, 2011

Apple USB-Ethernet Adapter Drivers for Windows 7 64-bit [UPDATED x2]

Through a series of incredibly unbelievable events I ended up needing to use an Apple USB-Ethernet adapter on this fully loaded Alienware M17X laptop running Windows 7 64-bit. The rest of you will probably be approaching this from the much more believable but equally incredible event of installing Boot Camp on your new MacBook Air. Congratulations.

[UPDATE 1/9/2013]
The driver link below has been updated now that MobileMe is dead!

[UPDATE 9/14/2011]
The proper driver is now included in Boot Camp 4.0 from Apple.  At the time of this writing the only way to get 4.0 is to download it from your Mac by running Boot Camp assistant and asking it to download Windows support files.
[/UPDATE]

Originally posted 8/10/2011...
Anyway, why these drivers are so hard to find is beyond me. Here’s the link to them on my iDisk. When iDisk becomes iCloud I will have to update this link, remind me if necessary. Apple USB-Ethernet Win7 64-bit Drivers

The .ini files were modified as taught by: YouGottaBeKiddingYou

Wednesday, September 7, 2011

Enable VNC Server in Mac OS X

This is so easy I can't believe it's taken me this long to find it.  This works for Snow Leopard and Lion as far as I know, though I've only tested it on Lion.

Go this route:
  • System Preferences
  • Sharing
  • Choose "Screen Sharing" and check the box to turn it on
  • Click "Computer Settings..."
  • Enable the "VNC views may control screen with password:" option and give it a password.  Password length is limited to 8 characters.
Now you can connect to and control your Mac from your favorite VNC application, including free versions like Mocha VNC (Lite) for iPhone or Chicken of the VNC for Mac.  I personally use Mocha VNC and it is a very good VNC app for my casual use.  It is surprisingly fast over my home network Wireless-G iPhone 3GS to Gigabit-connected early-2007 iMac, and it works perfect with my iMac's dual monitor setup.  It's the best Spotify "remote" I've found yet.


Tuesday, September 6, 2011

Part 4: Mac OS + Eclipse + OpenOCD + STM32 (ARM Cortex M3)

Intro
I really wanted to program and debug ARM processors from my Mac. This series of entries is a work in progress as I fine tune my setup for regular use.  Be sure to read the full story:
Part 1: Getting Started, what we are going to do and what parts we are going to use.
Part 2: Laying the Foundation, getting all the parts installed.
Part 3: Connecting the Plumbing, hook up all the pieces and run it.
Part 4
: Finishing Touches, troubleshooting and final thoughts.

Finishing Touches
I know that established, commercial software can often have more start-up issues than we care to deal with, especially when dealing with external development hardware.  My experience is that open-source, home-grown, multiple-author, work-on-it-in-my-spare-time, no-warranty-expressed-or-implied solutions are even more difficult.  I hope to someday build an Eclipse plug-in automate all of the things so my company can use a low maintenance open toolchain, but it's not going to happen right now!  Instead, I will show you the troubles that I've seen and the solutions that worked for me.  Deal?  Deal.

OpenOCD External Tool Troubleshooting
Installing OpenOCD
I don't have any comments on installing OpenOCD since the MacPorts installation works so well.

External Tool Configuration Reminders
This setup is pretty easy from the Eclipse perspective since only one tab in the External Tools Configuration screen needs to be populated.  Just be sure that your Location path is absolute and correct for your machine.  Same goes for the paths used in Arguments fields.  If you aren't using an Olimex ARM-USB-TINY-H JTAG or STM32 then be warned that you may need different flags on Arguments command, and that you will need to find the necessary .cfg files for your setup.

Target Connection Errors
A common thing that I ran into initially was not having my target connected and/or powered so OpenOCD couldn't connect.  When running the OpenOCD External Tool from Eclipse I would get error messages in the Eclipse Console that looked like this:

Open On-Chip Debugger 0.4.0 (2011-07-22-14:08)
Licensed under GNU GPL v2
For bug reports, read
http://openocd.berlios.de/doc/doxygen/bugs.html
1000 kHz
jtag_nsrst_delay: 100
jtag_ntrst_delay: 100
Info : max TCK change to: 30000 kHz
Info : clock speed 1000 kHz
Error: JTAG scan chain interrogation failed: all zeroes
Error: Check JTAG interface, timings, target power, etc.
Error: JTAG scan chain interrogation failed: all zeroes
Error: Check JTAG interface, timings, target power, etc.
Command handler execution failed
Warn : jtag initialization failed; try 'jtag init' again.
Error: JTAG scan chain interrogation failed: all zeroes
Error: Check JTAG interface, timings, target power, etc.
error: -100
Command handler execution failed
With a properly connected target you should see something less scary like:
Open On-Chip Debugger 0.4.0 (2011-07-22-14:08)
Licensed under GNU GPL v2
For bug reports, read
http://openocd.berlios.de/doc/doxygen/bugs.html
1000 kHz
jtag_nsrst_delay: 100
jtag_ntrst_delay: 100
Info : max TCK change to: 30000 kHz
Info : clock speed 1000 kHz
Info : JTAG tap: stm32.cpu tap/device found: 0x3ba00477 (mfg: 0x23b, part: 0xba00, ver: 0x3)
Info : JTAG tap: stm32.bs tap/device found: 0x16410041 (mfg: 0x020, part: 0x6410, ver: 0x1)
Info : stm32.cpu: hardware has 6 breakpoints, 4 watchpoints
Info : JTAG tap: stm32.cpu tap/device found: 0x3ba00477 (mfg: 0x23b, part: 0xba00, ver: 0x3)
Info : JTAG tap: stm32.bs tap/device found: 0x16410041 (mfg: 0x020, part: 0x6410, ver: 0x1) 
You might also see this displayed when starting OpenOCD:
Error: JTAG-DP_STICKY_ERROR
This doesn't happen all the time, or very often at all, for me, but I have seen it, and it makes it impossible to start debugging when it does happen.  I found a page at TinCanTools that said it is related to an OpenOCD 0.4.0 bug and it can be fixed by simply relaunching OpenOCD (the method I stumbled on) or by changing the OpenOCD launch arguments from:
-f /opt/local/share/openocd/scripts/interface/olimex-arm-usb-tiny-h.cfg -f /opt/local/share/openocd/scripts/target/stm32.cfg -c "init" -c "reset"
to:
-f /opt/local/share/openocd/scripts/interface/olimex-arm-usb-tiny-h.cfg -f /opt/local/share/openocd/scripts/target/stm32.cfg -c "init" -c "reset init" 
I did that and it worked, but then I switched back to the original to test the theory and it still worked.  YMMV.

Debugger Troubleshooting
No source available for ""
This being displayed in the source file area of the Debug Perspective happens for any number of reasons, but its always when something prevented the program download or run from happening properly.  Go through your Console output and look for "Error:" messages.

Error: couldn't open test_rom.hex
This is thrown when the debugger can find your binary file (obviously).  One reason is because you haven't build your program yet, or you did but then you cleaned the project before running the debugger.  Another reason is that in your debugger configuration has the wrong path to your binary file in the "'Run' commands" section of the "Commands" tab.  Your run command should look like the block below, but you need to edit it to reflect the correct relative path to your binary output file.  The location is dependent on your project directory structure and the name of your output files which are dependent on what you called them and if your are compiling for Flash or RAM.  Notice that the "symbol-file" path doesn't require the same path information.  Why? I don't know right now. The two paths I'm talking about are in bold:

monitor soft_reset_halt
monitor wait_halt
monitor poll
monitor flash probe 0
monitor stm32x mass_erase 0
monitor flash write_bank 0 STM32Test2/test_rom.hex 0
monitor soft_reset_halt
symbol-file test_rom.elf
thbreak main
continue
Conclusion
This was fun and I hope you were able to use it for your own work.  Looking back it took quite a long time to figure out and a surprising amount of time to write about...there's a lot to do!  All of this stuff certainly helps you appreciate the simplicity of IAR Embedded Workbench for ARM.

In the future I want to show you how to use IAR sample projects in our new toolchain, and I want to develop a quick-install method or plug-in of some kind to automate all of this work, as well as make it easy to change JTAG and target processor types.  Should be fun!  Please feel free to put questions/corrections/etc in the comments and I'll try to reply quickly.

Thursday, September 1, 2011

Part 3: Mac OS + Eclipse + OpenOCD + STM32 (ARM Cortex M3)

Intro
I really wanted to program and debug ARM processors from my Mac. This series of entries is a work in progress as I fine tune my setup for regular use.  Be sure to read the full story:
Part 1: Getting Started, what we are going to do and what parts we are going to use.
Part 2: Laying the Foundation, getting all the parts installed.
Part 3: Connecting the Plumbing, hook up all the pieces and run it.
Part 4
: Finishing Touches, troubleshooting and final thoughts.

Connecting the Plumbing
So at this point you have all the software and tools installed and it is time to hook everything together. I considered an infographic/flowchart to describe it all, but maybe later. For now, consider this
  • Eclipse uses OpenOCD to make the bridge to the hardware
  • Eclipse then uses a makefile in your project to invoke YAGARTO to compile your source into binary and debugger files
  • Eclipse then uses YAGARTO's GDB via Zylin to send the binary file over the OpenOCD bridge to the hardware using a simple (JTAG and chip dependent) OpenOCD script that I'll share with you
  • Now that your microcontroller is programmed Eclipse uses its built in debugger features to control YAGARTO's GDB via Zylin to control and debug your device over the OpenOCD bridge
As you can see, there is a lot of interaction between the parts, but after initial setup the complexity will be reduced to a three step process: 
  1. Build Project.
  2. Start OpenOCD. Even better: you only have to do this once per session.
  3. Start Debugging. Automatically downloads the latest binaries to your target each time.
Create a Test Project
  1. YAGARTO's example page has a nice starter project. It is their STM32Test project for the STM32-P103 board, but really its so simple it will work for anything. I modified the makefile to suit my setup and preferences, and I'll show you how to do it, too. Download it and extract it, doesn't matter where you put it.
  2. Time to import the project into Eclipse. Go File->New->C Project. Name it STM32Test for consistency, Project Type is "Makefile project"->Empty Project, Toolchain setting is "-- Other Toolchain --". Hit Finish.  My project is called STM32Test2 since I'm redoing this for you.
  3. In Project Explorer, right-click on your new project name and click "Import...". Set the Import source to be "General"->File System, then hit Next.  The From Directory is where you extracted the STM32Test project to. You want to import everything except for the root folder, see the image below (click to expand). To do this, expand the root folder, choose the three sub-folders, then click on the root folder to view its files and select the makefile.  The Into Folder path is set to your new project path because that was the one you right-clicked on to start the import. Press Finish to complete the import.
  4. Now that the files are in your project expand the project folder in the Project Explorer of Eclipse so you can see the contents.  Open the makefile by double-clicking on it. 
  5. Find the makefile line near the top that begins with TRGT.  Since Eclipse doesn't like to respect PATH variables I changed this line to reflect the absolute path to the YAGARTO compiler tools: TRGT = /Developer/YAGARTO/yagarto-4.6.0/bin/arm-none-eabi-
  6. My STM32 toolchain configuration wants binary files instead of hex files, so I went down a five lines and changed the BIN entry to be: BIN  = $(CP) -O binary
  7. I also wanted to run the program from the Flash memory of my micro so I scrolled down further and changed this setting: RUN_FROM_FLASH = 1
  8. Note that later when you add more source files to you project you will need to add them to the source files list in the makefile.  Header files are found automatically as long as they are in the project folder.
  9. Ok, that's it, save the makefile, then build your project from the Project menu or just by right-clicking on your project in Project Explorer. The Console window should show all the of the compiler commands rushing by then three new files should appear in your project: test_rom.elf (debugger data file), test_rom.hex (the image for your micro, its actually binary), and test_rom.map (like any map file, showing what is will be in the various memory areas of your micro).

Configure OpenOCD as an External Tool for Eclipse
  1. Look for External Tools icon on the toolbar and hit the drop-down arrow, or go to the Run menu -> External Tools, and choose "External Tools Configuration".
  2. On the left side of theExternal Tools Configuration dialog box click on "Program", if it's not already selected, and the right-side pane will show you what you can do with this dialog box.
  3. Choose the New option and the right-side pane will show you details of your new tool configuration.
  4. First thing to note is that the Helios release of Eclipse does not remember your global or project prefs settings for environment PATH variables.  So, where ever I use file paths I put in the absolute path rather than using relative paths and relying on the environment setting. You can either use the latest version of Eclipse or modify your Mac's PATH variable if you don't like this.  I understand the lack of portability, but I blame it on Eclipse and my laziness of not upgrading.
  5. Location is the path to the executable of the tool, and that tool is OpenOCD
  6. Arguments setup OpenOCD for your particular toolchain, my case is the Olimex ARM-USB-TINY-H and the ST Micro STM32.  The OpenOCD scripts folder contains quite a few different options here, but be aware that changing these options may result in necessary changes elsewhere in our IDE setup.
  7. The "Main" tab is all you need to worry about here. Fill in your new tool configuration as shown in the image below (click to enlarge), then press Apply then Close. You can run this external tool from the toolbar by clicking on the drop-down arrow of External Tools and finding the tool name (ARM-USB-TINY-H Start), you may have to Run the tool from inside its configuration window the first time to get it to appear in the drop-down menu. So, make sure that your JTAG is plugged into USB and plugged into your target, and make sure your target is powered, then run it!
  8. The console should show lots of red text (red doesn't mean error), and it should look something like this:
    Open On-Chip Debugger 0.4.0 (2011-07-22-14:08)Licensed under GNU GPL v2For bug reports, readhttp://openocd.berlios.de/doc/doxygen/bugs.html1000 kHzjtag_nsrst_delay: 100jtag_ntrst_delay: 100Info : max TCK change to: 30000 kHzInfo : clock speed 1000 kHzInfo : JTAG tap: stm32.cpu tap/device found: 0x3ba00477 (mfg: 0x23b, part: 0xba00, ver: 0x3)Info : JTAG tap: stm32.bs tap/device found: 0x16410041 (mfg: 0x020, part: 0x6410, ver: 0x1)Info : stm32.cpu: hardware has 6 breakpoints, 4 watchpointsInfo : JTAG tap: stm32.cpu tap/device found: 0x3ba00477 (mfg: 0x23b, part: 0xba00, ver: 0x3)Info : JTAG tap: stm32.bs tap/device found: 0x16410041 (mfg: 0x020, part: 0x6410, ver: 0x1)

Set the Debugger Configuration for Eclipse
  1. Find the Debugger icon on the toolbar and hit the drop-down arrow, or go to the Run menu, and choose "Debug Configurations".
  2. Since you've already installed the Zylin CDT Plugin you will have "Zylin Embedded Debug (Native)" in the list on the left side.  Select this and press the "New launch configuration" button at the top of the list.
  3. For this setup there are three tabs that we are interested in: Main, Debugger, and Commands.
  4. Main Tab: Thus far in my usage I've needed a separate debugger config for each project because there are pathnames hard coded into the debugger commands, I'm sure this can be improved on, but not yet. So, at the very top of the dialog box we are going to call this setup "STM32TestROM".  Then put in the optional project name, either browse for your new project or type in the name STM32Test (STM32Test2 in my case). The C/C++ Application is the .elf file created by the project build, which you can search or browse for, or just type in "test_rom.elf".  Note that since we pointed it at the "_rom" file this config is specific for running our program in Flash and not RAM, since our makefile uses "_ram" output filenames for non-Flash compiled programs.  Feel free to customize.
  5. Debugger Tab: Debugger is "Embedded GDB", Selected "Stop on startup at: " and put "main" in the text box. GDB debugger absolute path (for me) is: "/Developer/YAGARTO/yagarto-4.6.0/bin/arm-none-eabi-gdb". Clear out the GDB command file field.  GDB command set: standard. Protocol: mi.
  6. Commands Tab, 'Initialize' commands: 

  7. target remote localhost:3333
    monitor soft_reset_halt



  8. Commands Tab, 'Run' commands:


  9. monitor soft_reset_halt
    monitor wait_halt
    monitor poll
    monitor flash probe 0
    monitor stm32x mass_erase 0
    monitor flash write_bank 0 STM32Test2/test_rom.hex 0
    monitor soft_reset_halt
    symbol-file test_rom.elf
    thbreak main
    continue



  10. That's it.  Apply. Close.
  11. The OpenOCD JTAG interface is already running from before, so now we just need to run the debugger.  The Debug toolbar icon offers the drop-down arrow where you can find your debug configuration name.  Again, the first time you run it you may have to go click "Debug" from inside the debug configuration setup window to get it to appear on the toolbar menu. When you do this Eclipse will automatically switch the IDE to the Debug Perspective so you can see your typical debugger view and tools like Disassembly and Step controls. Eclipse has a powerful debugger that even allows you to hover the mouse over variables in your source code and read the realtime values when the program is halted.
Next Step
Ok, that was a long post, I went further than I expected, but ideally you are up and running now.  I'm going to leave it here for today, but next time I'll get into some troubleshooting and configuration tweaking items. Part 4: Finishing Touches.

Wednesday, August 31, 2011

Part 2: Mac OS + Eclipse + OpenOCD + STM32 (ARM Cortex M3)

Intro
I really wanted to program and debug ARM processors from my Mac. This series of entries is a work in progress as I fine tune my setup for regular use.  Be sure to read the full story:
Part 1: Getting Started, what we are going to do and what parts we are going to use.
Part 2: Laying the Foundation, getting all the parts installed.
Part 3: Connecting the Plumbing, hook up all the pieces and run it.
Part 4
: Finishing Touches, troubleshooting and final thoughts.

Laying the Foundation
We are going to work (more or less) from the bottom to the top of the list of pieces shown in Part 1.

OpenOCD Installation
First thing to do is get the hardware interface installed, that is OpenOCD, for which you will need to install MacPorts, if you want to do it my way.
  1. Install MacPorts. The MacPorts site has very good instructions on how to do that. I am running XCode 3.2.5 on OS X Lion with no problems, although the MacPorts page says to use 4.x. For those of you unfamiliar with MacPorts it is a very powerful tool similar to apt-get on Linux. MacPorts removes you from the task of compiling source code and finding all of the required dependencies for your open source software of choice. Don't be scared, embrace Terminal and realize how much more your Mac can do. Use the search feature on MacPorts' site and see how much stuff is available. I don't want to sound like a command-line freak, I'm not, I'd much rather download a sweet DMG image containing an installer and prebuilt binaries, but alas.
  2. Use MacPorts to install OpenOCD. The Terminal command is "sudo port install openocd" where sudo gives admin rights to the port command (MacPorts), and install tells MacPorts to install openocd, as opposed to uninstalling. The openocd name comes from the MacPorts description for OpenOCD. If you pay attention to the dependencies you'll see that libftdi gets installed, this is the driver for the FTDI USB-UART chip inside the Olimex JTAG (and many other budget JTAGs). You might end up waiting a while for this step to complete, depending on what is already installed on your machine, internet speed, etc. I'm talking like 5's or 10's of minutes. When it's done there won't be any new icon in your Applications folder or anything, but there will be bunch of stuff in your /opt/local/ directory. /opt/local/bin/openocd is the executable and /opt/local/share/openocd/ contains a number of different scripts to configure OpenOCD for various JTAGs and various targets (processors).
YAGARTO Installation

Next, we install YAGARTO which is a plug-in to the GDB debugger which allows the GDB to work with ARM processors.

  1. Go get the goods, and make sure you download from the Mac OS X section and not the Windows section. I used the 29 Apr 2011 version with GCC-4.6.0 and GDB-7.2. YAGARTO means Yet Another GNU ARM Toolchain. Eclipse uses this piece to cross-compile your code for the ARM on your Mac, generate the binary file used program your chip, and generate debugger data. It also uses this piece, via the Zylin add-in, to run the debugger.
  2. Install as per the ReadMe file included in the DMG: To install the toolchain copy the YAGARTO installer (yagarto-4.6.0, the blue box icon) to the folder where you want to install it. Start the installer by double clicking on it. I chose to place the installer at /Developer/YAGARTO/ so you can copy if you want to use my examples directly.
  3. The installer will simply create a directory structure under the path where you put the installer. Again, no fancy icons in your Applications folder, just some crazy sounding filenames waiting patiently for Eclipse to exercise them. The business end is at /Developer/YAGARTO/yagarto-4.6.0/bin and this is a path that will be useful to know in the near future.
Eclipse Installation

If you haven't heard of Eclipse then I'm surprised you made it this far. Eclipse is the ultimate GUI/IDE for just about every purpose. Personally I've used it for Java, Actionscript, Python, and now C for the ARM. Anyway,

  1. Download the Eclipse IDE and the C/C++ Developer Tooling (CDT). These are separate downloads and you need them both, unless you want to install Eclipse then add in the CDT via the "Help->Install New Software..." feature. I am using Helios SR2 with CDT 7.0.2. I haven't upgraded to Indigo yet, but I'm sure this process is very similar for both versions.
Zylin Installation

Zylin fills the gap between Eclipse and OpenOCD for the debugging side of things.

  1. The Zylin CDT is open source and there website is here, although there is nothing you need to download from there.
  2. What you need to do is fire up Eclipse, and use the Help->Install New Software... feature.
  3. To the right of the "Work with:" text box click the "Add..." button to bring up the "Add Repository" window. Name it something like "Zylin CDT" and put in "http://opensource.zylin.com/zylincdt" for the location. This location information came from the Zylin website.
  4. After some thinking "Zylin Embedded CDT" should show up in the big window. Check the box next to it then hit "Next" a couple times, accept the license terms, and hit "Finish." It might take a few minutes to do its thing, but wait for it, approve any unsigned software installation, then restart Eclipse when prompted.
Next Step

We have the foundation laid, so now its on to Part 3: Connect the Plumbing.

Tuesday, August 30, 2011

Part 1: Mac OS + Eclipse + OpenOCD + STM32 (ARM Cortex M3)

Intro
I really wanted to program and debug ARM processors from my Mac. This series of entries is a work in progress as I fine tune my setup for regular use.  Be sure to read the full story:
Part 1: Getting Started, what we are going to do and what parts we are going to use.
Part 2: Laying the Foundation, getting all the parts installed.
Part 3: Connecting the Plumbing, hook up all the pieces and run it.
Part 4
: Finishing Touches, troubleshooting and final thoughts.

My motivation: I am an electrical engineer that uses a Mac. It's a long story, but now that I'm here I'd rather not switch operating systems via Boot Camp multiple times per day. I admit that it's not THAT hard to reboot in Windows, nor does it take THAT long, and I'm sure I've spent more time on this research project than I'll ever save. However, I wanted to know more about open source embedded dev tools and this was a great way to find out if its worth it. Is it worth it? I don't know yet. I'll try to get comfortable debugging the STM32 in Eclipse and report back. If it works out well then I'll try the STM8 with its SWIM interface and get all of my development under one IDE umbrella.

Where I came from: IAR Embedded Workbench for ARM + IAR J-Link. This is great software and hardware, no doubt. Very easy to use, supports every processor I've ever heard of, and my chip vendor of choice (ST Micro) supplies great sample projects in IAR format. But it doesn't run on Mac, and its not cheap (even if you use the free 16K version of EWARM the J-Link will cost you a lot). For some the cost is irrelevant, but if you switch chips a lot, if you're a student, or if you have multiple developers who just want to experiment then maybe this article is for you.

Bill of Materials
I am going to show you how to establish an embedded processor programming and debugging ecosystem using as much free and open source stuff as I reasonably can, and do it all on a Mac. Here are the pieces:
  1. STM32 development board with JTAG interface. I am using an STM32F103 on my own PCB design, you can use your own platform or buy any of the many development kits out there.
  2. Olimex ARM-USB-TINY-H JTAG device (buy it from Mouser.com for about $50).
  3. Mac OS X Lion 10.7.1
  4. Eclipse IDE with C/C++ Developer Tooling (CDT). These are separate downloads and you need them both. I am using Helios SR2 with CDT 7.0.2. I haven't upgraded to Indigo yet, but I'm sure the process is very similar. You will need a few helper pieces as well, described below.
  5. YAGARTO means Yet Another GNU ARM Toolchain. I used the 29 Apr 2011 version with GCC-4.6.0 and GDB-7.2. Eclipse uses this piece to cross-compile your code for the ARM on your Mac, generate the binary file used program your chip, and generate debugger data.
  6. Zylin Embedded CDT is an open source plug-in for GDB that magically fills the gap between Eclipse and OpenOCD. It gets installed into Eclipse.
  7. OpenOCD the Open On-Chip Debugger v0.4.0. This lets GDB talk to the JTAG hardware over USB. Hadn't been updated in over a year until I start using it then they release v0.5.0 : ) No hard feelings, but you should be aware that many of the OpenOCD server commands changed with the new version, so to use what I've done you should get the old one, or wait (potentially for eternity) for me to update to the latest.
  8. I used the MacPorts method to install OpenOCD, and I suggest you do the same if you are fairly new to the command line of Mac OS X or Linux. Heck, even if you're not new to the nitty gritty you should use it, I think MacPorts is great, and it's the method I'll show.
If it wasn't for the great open source community out there I never would have accomplished my goal. It took the aggregation of multiple how-to guides and forums for me to put together my specific solution, so I will reference those resources but also publish sufficient relavent information here.

First Things First
First thing to do is get the hardware interface installed, so go on to Part 2: Lay the Foundation.

Saturday, August 6, 2011

Get Mac OS X Lion to Work with NTFS [UPDATED]

From a comment in a neighboring blog I successfully got my NTFS drives to mount again after upgrading to Lion. There are paid solutions to NTFS on Lion, but I use Windows-formatted drives so rarely that I can't justify $39.

[UPDATE Aug 31, 2011]
MacFUSE 2.2 has been released with Lion compatibility: There is a 2.2.1 out in the wild, but many have reported that it makes your CPU run like crazy. 2.2.x is expected to be the last MacFUSE release with the new Fuse4X project taking over, but not yet useful for NTFS, as far as I can tell.



Its working great for me and not throwing that weird 15.00000 second timeout error that MacFUSE 2.0.3 was doing. and is simpler than the original method I posted.
[/UPDATE]

Old way...
How to do it:
1. Install the latest version of MacFUSE: http://macfuse.googlecode.com/files/MacFUSE-2.0.3%2C2.dmg


2. Install the lastest MacFUSE core of Tuxera (aka NTFS-3G): Install http://www.tuxera.com/mac/macfuse-core-10.5-2.1.9.dmg


Restart as necessary to make it all happy and stuff.