2017-05-20 06:56 AM
Hi,
After generation of code with STM32CubeMx (release 4.21.0), Error_Handler() interface present in main.h is not specified to be used in C-style linkage as it's done in the rest of the code.
This performing a linkage error with IAR C++ compiler.
Please, fix it in the next release.
Thx and Regards
#main.h #c-style-linkage #stm32cubemx-4.21.0 #error_handler()Solved! Go to Solution.
2017-11-01 04:54 PM
Hi,
I just test the new release 4.23.0 and I confirm the issue has been fixed.
My C++ project is compiled now without any error.
Thanks for this,
Br
Nig
PS: the other issue 'PLLM = 1' has been fixed too !
2017-05-22 08:14 AM
Hi
Oros.Nig
,Using IAR version 8.11, I'm not encountering any issue.
Could you please precise the IAR version you're using and share your ioc file.
Best regards,
Khouloud.
2017-05-22 02:48 PM
Hi, Here my ioc file. I use IAR version 7.10 with C++ compiler (mandatory to obtain the error). I’ve got this error message: Error[Pe337]: linkage specification is incompatible with previous '_Error_Handler' (declared at line 82 of 'C:\ Test_bug\EWARM/../Inc\main.h') C: \Test_bug\Inc\i2c.h 60 Br Nig Provenance: Courrier pour Windows 10 De: Khouloud G Envoyé le:lundi 22 mai 2017 17:15 À: Oros Nig Objet:You have been mentioned by Khouloud G in Re: STM32CubeMx forSTM32L476RG bug report in STMicroelectronics Community STMicroelectronics Community
You have been mentioned by Khouloud G in Re: STM32CubeMx for STM32L476RG bug report in STMicroelectronics Community - View Khouloud G's reference to you Hi Oros Nig, Using IAR version 8.11, I'm not encountering any issue. Could you please precise the IAR version you're using and share your ioc file. Best regards, Khouloud. Participate in the conversation by replying to this email
This email was sent by STMicroelectronics Community because you are a registered user.
You may unsubscribe instantly from STMicroelectronics Community, or adjust email frequency in your email preferences
________________ Attachments : TestNig.ioc.zip : https://st--c.eu10.content.force.com/sfc/dist/version/download/?oid=00Db0000000YtG6&ids=0680X000006HyeV&d=%2Fa%2F0X0000000bAX%2FL.nYmXCXHpMzDTnJUp5WJhFf1GzNj0T4Z90arQ6Bjwo&asPdf=false22D18B1210434C438756D53B5577C131.png : https://st--c.eu10.content.force.com/sfc/dist/version/download/?oid=00Db0000000YtG6&ids=0680X000006HyeQ&d=%2Fa%2F0X0000000bAY%2F0iEjPqLAoL9VDe.5FK2DD4_0ktjnkRZi3ykDtFm2Ke4&asPdf=false2017-05-23 01:51 AM
Hi
Oros.Nig
,Thanks for sharing those details.
Your issue is reported internally to our CubeMX team and we will keep you posted about any further update.
Khouloud.
2017-08-19 04:54 AM
2017-09-12 06:45 AM
Hello
Oros.Nig
,I am using IAR 4.2.13606, and cannot reproduce this issue.
I cannot go back to a previous version as it is not available on the original website.
Taking into account the fact that new SoC are supported by latest IAR release, I recommend to use latest one.
It should not mixup your build.
Could you please try to upgrade your tool ?
Thanks in advance.
Kind regards
Sirma
2017-09-12 12:19 PM
Hi Sirma
I use IAR Embedded Workbench for ARM 7.8 to compile my Project. My target is a Nucleo SMT32L476RG.
Version 7.8 is not a very old one.
It seems your IAR version is regarding a Texas Instrument target ?!
Thanks and regards
Nig
Use the ioc file I give to see the issue ...
2017-09-13 09:21 AM
Hello
,I used cubeMX4.1, from which I open your ioc.
I migrate it to that version;
Then I generate the code and open the IAR Embedded Workbench (mine is version 8.2, and not 4.2 as I wrote before).
I built it and get following trace:
Building configuration: Sh4047_4.1_L476_ErrorHandlerWithIAR - Sh4047_4.1_L476_ErrorHandlerWithIAR
Updating build tree... 28 file(s) deleted. Updating build tree... startup_stm32l476xx.s i2c.c gpio.c main.c stm32l4xx_hal.c stm32l4xx_hal_cortex.c stm32l4xx_hal_dma.c stm32l4xx_hal_dma_ex.c stm32l4xx_hal_flash.c stm32l4xx_hal_flash_ex.c stm32l4xx_hal_flash_ramfunc.c stm32l4xx_hal_gpio.c stm32l4xx_hal_i2c_ex.c stm32l4xx_hal_msp.c stm32l4xx_hal_i2c.c stm32l4xx_hal_pwr.c stm32l4xx_hal_pwr_ex.c stm32l4xx_hal_rcc.c stm32l4xx_hal_rcc_ex.c stm32l4xx_hal_tim_ex.c stm32l4xx_hal_tim.c stm32l4xx_hal_uart_ex.c stm32l4xx_hal_uart.c stm32l4xx_it.c system_stm32l4xx.c tim.c usart.c Linking Total number of errors: 0 Total number of warnings: 0At my end everything went well.
I know IAR is regularly updated, and rules might have changes since your version.
Could you upgrade and test with version 8.2 ?
I attached a picture showing you my env.
Kind regards
Sirma
________________ Attachments : Capture.PNG : https://st--c.eu10.content.force.com/sfc/dist/version/download/?oid=00Db0000000YtG6&ids=0680X000006HyRv&d=%2Fa%2F0X0000000b7o%2FQp0egt.2A6jh9kQlc0qyqsFVZzf4yinO3L5DmeD0Tys&asPdf=false2017-09-13 02:14 PM
Hi Sirma,
This issue occured only with the C++ compiler. I suppose you've compiled your project with C compiler.
The '' ♯ defined __cplusplus integer'' is defined only in C++ compilers. Its value activate or not the directive '' ♯ extern C'' which have an effect on linkage and name-mangling of wrapped declarations.
As it's done in i2c.h (and may be in other peripherical interfaces), the declaration of extern void __Error_Handler(char *, int);
must be declared as ♯ extern ''C'' also in main.h.
I attached a picture showing my compiler options.
Thx and Regards
Nig
2017-09-15 06:45 AM
Hello
Oros.Nig
,A great thanks for your guidance and patience 🙂
I understand your point, and I confirm it.
The correction will be part of the Cube version 4.
Kind regards
Sirma