You are not Logged In! |
Difference between revisions of "Public:MCUXpresso"
imported>Jonathan |
|||
Line 1: | Line 1: | ||
− | + | __NOTOC__ | |
=== About=== | === About=== | ||
Line 8: | Line 8: | ||
=== Setting Up MCUXpresso=== | === Setting Up MCUXpresso=== | ||
− | + | ''Note: This set-up guide currently covers windows only. ISC has officially only ever supported windows. We are working to make our software more cross platform but instructions for non-Windows may still be lacking. Please add them!'' | |
− | |||
− | ''Note: This set-up guide covers windows only. ISC officially | ||
<macro:mathjax><style> | <macro:mathjax><style> | ||
Line 39: | Line 37: | ||
# Download the MCUXpresso IDE from the [https://www.nxp.com/webapp/swlicensing/sso/downloadSoftware.sp?catid=MCUXPRESSO NXP Website]. | # Download the MCUXpresso IDE from the [https://www.nxp.com/webapp/swlicensing/sso/downloadSoftware.sp?catid=MCUXPRESSO NXP Website]. | ||
## Register for an NXP account | ## Register for an NXP account | ||
− | ## Download MCUXpresso '''10.1. | + | ## Download MCUXpresso '''10.1.x'''. ***<u>10.2+ have some compatibility issues with our systems.</u>*** |
### Find it on the "Previous" tab | ### Find it on the "Previous" tab | ||
− | |||
− | |||
[[File:87]] ## Agree to the MCUXpresso terms*. | [[File:87]] ## Agree to the MCUXpresso terms*. | ||
Line 48: | Line 44: | ||
# Install MCUXpresso including Debug Drivers | # Install MCUXpresso including Debug Drivers | ||
## Also Install all device drivers when prompted (depending on your device settings you may not receive these, may only receive one for them all, or will receive a bunch) | ## Also Install all device drivers when prompted (depending on your device settings you may not receive these, may only receive one for them all, or will receive a bunch) | ||
− | # At this point you will need to have ((Github | + | # At this point you will need to have ((Github|github software repos set-up)) on your computer to move forward with the set-up process. |
+ | |||
+ | {REMARKSBOX(type="errors" title="Note")}The below set-up will work, however new instructions are coming soon for recommended workspace organization{REMARKSBOX} | ||
# Now import the files into your workspace: | # Now import the files into your workspace: | ||
## Go to File > Import | ## Go to File > Import | ||
Line 61: | Line 59: | ||
~42~You may want to note the patent waiver clause in case you decide to use it for personal projects. For solar car related software this should not be a concern. | ~42~You may want to note the patent waiver clause in case you decide to use it for personal projects. For solar car related software this should not be a concern. | ||
+ | |||
+ | = Rare Problems= | ||
+ | |||
+ | If you have a Lenovo non-ThinkPad device, or maybe something else weird running Windows 10, you might run into the debuggers not working even if you've set up everything correctly. The error text when trying to debug was a popup saying Socket exception: connection reset or something similar, and the details were a whole list of things including Java code locations. This problem is probably not with the drivers. The easiest fix was to install MCUXpresso 10.1.0 instead of 10.1.1. It may work with other earlier versions as well but hasn't been tested yet. Also make sure to restart your computer after attempting any changes to MCUXpresso versions and driver installs. | ||
=== Creating a new MCUXpresso Project=== | === Creating a new MCUXpresso Project=== | ||
Line 90: | Line 92: | ||
* The LPCXpresso board is a combination of the LPC-LINK debugger (which you want to use to program your board) and a target board containing a microcontroller. To use the LPC-LINK to program your board, you need to desolder the traces between the two rows of nine pins in the middle of the LPCXpresso board. | * The LPCXpresso board is a combination of the LPC-LINK debugger (which you want to use to program your board) and a target board containing a microcontroller. To use the LPC-LINK to program your board, you need to desolder the traces between the two rows of nine pins in the middle of the LPCXpresso board. | ||
* * For extra mechanical fun, you can also dice the board into two pieces, where the cut point is the line of traces that you desoldered. | * * For extra mechanical fun, you can also dice the board into two pieces, where the cut point is the line of traces that you desoldered. | ||
− | + | * If all else fails, try restarting LPCXpresso / plugging in / unplugging the board + debugger board, etc. | |
''Run into other stuff that wasted a bunch of time or was confusing?'' Add your own notes/tips! | ''Run into other stuff that wasted a bunch of time or was confusing?'' Add your own notes/tips! |
Revision as of 14:50, 23 August 2019
About
MCUXpresso is an IDE from NXP who makes the family of chips we use on ISC (or at least they bought the company that did). We use MCUXpresso to build, flash, and debug all of the code on the solar car. You are welcome to use any IDE for writing code, however you must use MCUXpresso to compile, flash, and debug all code.
Setting Up MCUXpresso
Note: This set-up guide currently covers windows only. ISC has officially only ever supported windows. We are working to make our software more cross platform but instructions for non-Windows may still be lacking. Please add them!
<macro:mathjax><style>
.insrt_list ol {here
list-style-type: decimal;
}
.insrt_list ol ol {
list-style-type: lower-alpha;
}
.insrt_list ol ol ol {
list-style-type: lower-roman;
}
</style>
</macro:mathjax>
{DIV(class=insrt_list)}
- Download the MCUXpresso IDE from the NXP Website.
- Register for an NXP account
- Download MCUXpresso 10.1.x. ***10.2+ have some compatibility issues with our systems.***
- Find it on the "Previous" tab
File:87 ## Agree to the MCUXpresso terms*.
- Download the version for your OS.
- Install MCUXpresso including Debug Drivers
- Also Install all device drivers when prompted (depending on your device settings you may not receive these, may only receive one for them all, or will receive a bunch)
- At this point you will need to have ((Github|github software repos set-up)) on your computer to move forward with the set-up process.
{REMARKSBOX(type="errors" title="Note")}The below set-up will work, however new instructions are coming soon for recommended workspace organization{REMARKSBOX}
- Now import the files into your workspace:
- Go to File > Import
- Select General > Existing Projects into Workspace
- Click "Browse" next to "Select root directory"
- Select the base folder for the git repository you are setting up the workspace for.
- Select the checkboxes for the projects you want to import to this workspace (see below on managing workspaces)
- The absolute minimum for every workspace is -+mbed+-, -+common+-, and the skeleton for the chip your board uses (likely -+mbed1549_skeleton+- on ARGO-FW)
- At this point you are ready to work on and edit existing projects. Continue below for notes, common issues, and how to create a new project. Also see: ((Building and Debugging Code))
{DIV}
~42~You may want to note the patent waiver clause in case you decide to use it for personal projects. For solar car related software this should not be a concern.
Rare Problems
If you have a Lenovo non-ThinkPad device, or maybe something else weird running Windows 10, you might run into the debuggers not working even if you've set up everything correctly. The error text when trying to debug was a popup saying Socket exception: connection reset or something similar, and the details were a whole list of things including Java code locations. This problem is probably not with the drivers. The easiest fix was to install MCUXpresso 10.1.0 instead of 10.1.1. It may work with other earlier versions as well but hasn't been tested yet. Also make sure to restart your computer after attempting any changes to MCUXpresso versions and driver installs.
Creating a new MCUXpresso Project
Generally there is one project per board. To do so:
- You should use the appropriate skeleton project for your chip as a starting point.
- For ISC made boards that should be the -+mbed1549_skeleton+- for now (additional 15xx family chip support will be added soonish)
- For older boards from CalSol you may need the -+mbed11c14_skeleton+-
- In the project explorer right click on the appropriate skeleton and select "Copy"
- Right click in the Project Explorer and "Paste"
- At the "Copy Project" Dialog, name your project. Ensure this is unique, otherwise MCUXpresso won't let others import it (and we can't tell projects apart easily!)
- Uncheck "Use Default Location"
- Click "Browse" to chose the folder and place it appropriately within the correct repo
- Create a new folder in the repo for the project. The name does not matter but it is generally best to make it the same as the project name
- Select the new folder and press "ok"
Done! You can now work on your new project!
Appendix & Notes
- Did you get your code to upload, but now it's not letting you upload code? Make sure that you've ended any previous debugging sessions before trying to upload code again (you can either right click on an instance and terminate it or terminate all from the top menu in MCUXpresso)
- Is the Debugger crashing on upload, with red messages saying that GDB crashed and can't be relied on? Try opening the breakpoints tab and right click "delete all" to make sure there aren't random ones saved. Also setting too many breakpoints can crash the debugger too. (More details on this in ((Building and Debugging Code)).
- Is your board hard-faulting on debug? Check the .cproject file and try reverting to an earlier version if things are really ugly. Don’t sink 6 hours into attempting to fix the versioning by committing more changes like we did.
- Is the debugger not working and the red LED on it is lit up? It’s probably stuck in some weird state. Unplugging it and plugging it back in will usually fix it.
- Is the debugger really really not letting you upload code, even though it appears to be okay? You may have accidentally disabled the SWD/JTAG pins on the microcontroller, blocking communications. Try holding down PGRM and RESET on your board to force it to go into the on-chip bootloader, which is always able to talk to the debugger.
- The debugger does not provide power to your board. Make sure it’s powered on…
- If you need to change the processor (LPC1549 vs LPC11C14), you can do so by right clicking the project and selecting C++ Build > MCU Settings
- *Note that because of the way that the mbed libraries map the interrupt vector table to let you dynamically set interrupt handlers, there are 512 bytes of RAM that are dedicated to the table
- *When you change the processor, you may need to adjust the RAM region to start offset by 512 bytes (0x10000200 instead of 0x10000000) and to be 512 bytes smaller (0x1E00 instead of 0x2000) for the LPC11Cx4. Otherwise the linker may attempt to place variables in the space reserved for the interrupt table and you may see variables getting corrupted.
- The LPCXpresso board is a combination of the LPC-LINK debugger (which you want to use to program your board) and a target board containing a microcontroller. To use the LPC-LINK to program your board, you need to desolder the traces between the two rows of nine pins in the middle of the LPCXpresso board.
- * For extra mechanical fun, you can also dice the board into two pieces, where the cut point is the line of traces that you desoldered.
- If all else fails, try restarting LPCXpresso / plugging in / unplugging the board + debugger board, etc.
Run into other stuff that wasted a bunch of time or was confusing? Add your own notes/tips!
Credit:
This guide updated and edited from Devan Lai's (of CalSol) LPCXpresso set up guide which can be found here: [http:// http://goo.gl/tMMmVG]
~tc~ (alias(MCUXpresso Setup)) ~/tc~