Simulink External Mode not working on Texas Instruments C2000 Launchpad F28377S

33 ビュー (過去 30 日間)
Hi, I am trying to use Simulink r2016a "External" Simulation Mode, to run a simple Simulink program (blink LEDs at a specified rate) on a Texas Instruments C2000 Launchpad F28377S board, and monitor what is happening using scopes in Simulink.
If I can do this, then I will be able to implement and debug more complex models on the Launchpad.
I can run the "Update Diagram" check succesfully.
I can "Deploy to Hardware" succesfully - the built in LEDs on the board blink as expected.
But when I press "Run", for "External" Simulation Mode, I get the error:
" Error occurred while executing External Mode MEX-file 'ext_serial_win32_comm': Failed to connect to the target. A time-out occurred while waiting for the connection response from the target. Possible reasons for the time-out: a) The target is not switched on. b) The target is not connected to your host machine. c) The application for the model is not running on the target. You might have clicked the Stop button. If the Run button is not dimmed, click it. Otherwise, click the Build button, which downloads and runs your application on the target."
The error message is confusing, as the target is definately on, connected, and the program is running on the target.
Details of my setup:
I am using a USB cable to connect my pc to the C2000 Launchpad F28377S board.
I've attached some screenshots of relevant settings, and my code is attached.
I understand that in External Mode, the Launchpad board will send data back to Simulink on my pc over Serial communications, on the USB cable. I think there might be a setting here that I have got wrong.
Any help would be much appreciated.
  4 件のコメント
Matthias Baert
Matthias Baert 2017 年 5 月 20 日
Exactly the same problem here, shame that MATLAB does not have an answer to this problem.
SIVA KRISHNA
SIVA KRISHNA 2022 年 2 月 20 日
Please recheck the Oscillator clock frequency properly. That should solve the issue. For F2838X devices, it should be 25 MHz.

サインインしてコメントする。

採用された回答

Venkatesh Chilapur
Venkatesh Chilapur 2017 年 8 月 23 日
Hi,
With the release of R2016b, support package version 16.2.2, we are now supporting external mode on all the GPIO pins that can be configured for SCI_A via the SCI_A pane (Hardware Implementation->Target Hardware Resources-> SCI_A). However, which GPIO pin for the given board needs to be selected is dependent on the board schematic. If the user has a custom designed board, then user must configure those GPIO pins for SCI_A which are routed to serial port/FTDI chip. Bottom line is, any GPIO pin which support SCI_A functionality can be configured for external mode, but which GPIO pin is used on the given board for SCI_A is for users to investigate. Some popular board from TI and their default GPIO pin assignment for SCI_A are as below:
For F28377S Launchpad, FTDI connected to GPIO pins GPIO84(Tx) and GPIO85(Rx)
For F28379D Launchpad, FTDI connected to GPIO pins GPIO42(Tx) and GPIO43(Rx)
For F28377D Controlcards,FTDI connected to GPIO pins GIO29(Tx) and GPIO28(Rx)
Selecting internal oscillator works for F28379D Launchpad for following reason: the external oscillator on this launchpad runs at 10MHz, but our default value for Oscillator clock (OSCCLK) frequency in MHz is 20MHz. This default value is true for a F28379D control card but not for launchpad. When user generates the code keeping this default value and tries to run it on Launchpad, we get incorrect value for the PLL multiplier as we are generating it for a 20MHz oscillator but launchpad has a 10MHz oscillator as noted above. This in-turn affects the calculation of other parameters like SCI baud rate which affects the external mode. However, selecting internal oscillator for the launchpad seem to do the trick, upon selection, we no more default to 20MHz but use actual value of the internal oscillator i.e 10MHz, to derive the PLL multiplier. This keeps other calculations consistent and thus external mode works. It would be better if the user is able to change the external oscillator frequency “Oscillator clock (OSCCLK) frequency in MHz” from default value of 20MHz to 10MHz if he plans to work with F28379D Launchpad against the current solution of selecting the internal oscillator.
Regards,
Venkatesh Chilapur
  3 件のコメント
pouya abbasi
pouya abbasi 2018 年 3 月 29 日
me too :(
SIVA KRISHNA
SIVA KRISHNA 2022 年 2 月 20 日
Please recheck the Oscillator clock frequency properly. That should solve the issue. For F2838X devices, it should be 25 MHz.

サインインしてコメントする。

その他の回答 (6 件)

Matthias Baert
Matthias Baert 2017 年 5 月 23 日
I have found the solution to this problem. MATLAB initialises the SCI_A port badly. If one has a look in the documentation of the Launchpad one can see that the SCI_A port needs to be configured to use GPIO 42 and 43 in order to be able to communicate over USB. For me this solved the problem completely.
  4 件のコメント
han wang
han wang 2021 年 1 月 28 日
Many thanks! It works with F28379D.
Hassan Khalid
Hassan Khalid 2021 年 4 月 11 日
@Matthias Baert im using arduino UNO. I am facing the same issue. Can you please guide me in similar way in this regard.

サインインしてコメントする。


Matko  Pecanic
Matko Pecanic 2018 年 1 月 4 日
My solution: Hi, as you can see above I had the same problem despite doing all the stuff mentioned above.
So after no more smart options I started doing random shi*. I changed from CPU1 to CPU2 in Hardware Implementation > Build options and ofcourse it did not work. So I changed it back to CPU1 and hit RUN just to make sure it still does everything as same as before, bit this time it worked :D
  1 件のコメント
Yunjie Gu
Yunjie Gu 2021 年 3 月 30 日
Thanks Matko, this trick works for me. I guess it might be that the code running on CPU2 are disrupting the sci communication interrput handler.

サインインしてコメントする。


Brian McKay
Brian McKay 2016 年 10 月 10 日
Just a guess... but sometimes, CCS locks the USB port to the board because it maintains the connection. Try using the MathWorks tools to build and download, before connecting with CCS. Or if you do connect with CCS, make sure it is disconnected and releases the USB port - as both programs cant access USB port at the same time.
-Brian
  5 件のコメント
ismet tin
ismet tin 2017 年 3 月 25 日
編集済み: ismet tin 2017 年 5 月 12 日
Hi everybody, I have been using f28379D series. I had same problem. After checking internal clock (Hardware configuration > Clock Settings) the problem were solved . now I can work external mode. But building and downloading time is so much ( about 3 minutes) I couldnt reduce that time. ? Anyone have this problem?
Lukasz Huchel
Lukasz Huchel 2017 年 8 月 10 日
Why the internal clock solves the problem?

サインインしてコメントする。


Matko  Pecanic
Matko Pecanic 2018 年 1 月 3 日
編集済み: Matko Pecanic 2018 年 1 月 3 日
I'm using an F28379D Launchpad and did all the things mentioned above:
- set SCI_A PINS to 42 & 43
- checked "internal clock" box (it becomes 10MHz automatically)
also matched baud rate
Still getting this error:
Error occurred while executing External Mode MEX-file 'ext_comm': Failed to connect to the target. A time-out occurred while waiting for the connection response from the target. Possible reasons for the time-out:
a) The target is not switched on.
b) The target is not connected to your host machine.
c) The application for the model is not running on the target. You might have clicked the Stop button. If the Run button is not dimmed, click it. Otherwise, click the Build button, which downloads and runs your application on the target. Component:Simulink | Category:Block diagram error Unable to connect to the 'TI Delfino F2837xD' target for 'Launchpad_test3'. Component:Simulink | Category:Model error
  1 件のコメント
SIVA KRISHNA
SIVA KRISHNA 2022 年 2 月 20 日
Please recheck the Oscillator clock frequency properly. That should solve the issue. For F2838X devices, it should be 25 MHz.

サインインしてコメントする。


giray uzun
giray uzun 2018 年 2 月 24 日
編集済み: giray uzun 2018 年 2 月 24 日
I had the same problem. Then I have tried something and fixed. First, you need to specify GPIO_42 and GPIO_43 as Tx and Rx as in SCI_A tab. Then go `clocking` and write `Oscillator frequency in MHz` 10 instead of 20 which is the default. If it does not work, try to use internal oscillator. By the way, I am using F28379D.
All options are at ` Hardware Implementation`.
Have a nice programming.
  1 件のコメント
telhaoui
telhaoui 2024 年 5 月 2 日
編集済み: telhaoui 2024 年 5 月 2 日
Thank you..this solution works well.. just use internal oscillator

サインインしてコメントする。


Dynamo
Dynamo 2025 年 8 月 29 日
For anyone looking for an answer to this question in 2025 here is how I solved this problem on TI Delfino F28379D:
  1. If you are using any other board than TI Delfino F28379D then make sure you check the GPIO pins it uses for Tx and Rx (basically input output pins of the board) you will find this information in the manual of the board you are using so search carefully. It is GPIO 42 Tx and GPIO43 for Rx for TI Delfino F28379D.
  2. Once you have your board and GPIO pin numbers. Check the oscillator clock frequency it should be 10 MHz for TI Delfino F28379D. It may differ from board to board.
  3. Open device manager in your PC and look for Ports and COM and double click on XDS 100 Class USB serial port (COMX) where X is some integer number. Note down the COMX as we will use it later in MATLAB. Now in port settings Set baud rate to 115200, parity to nonne, leave everything as default.
  4. Go to MATLAB and Simulink. Open hardware settings. Click on HArdware Implementation.
  5. Click on target hardware resources.
  6. Go to Clocking and set Oscillator OSCCLK to 10 MHz
  7. Go to SCI_A and set Tx and Rx as GPIO42 and GPIO43. Check baud rate and other settings same as Device manager port settings.
  8. Go to External mode and check the COM port is right same as device manager.
  9. Go to connected IO and again check right COM port.
Now run the simulation on the board through build,deloy and run. It should work.

タグ

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by