2021-05-31 14:59:23 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2010-2014 Wind River Systems, Inc.
|
|
|
|
* Copyright (c) 2021 Nordic Semiconductor ASA
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Linkers may treat weak functions differently if they are located within
|
|
|
|
* the same object that calls the symbol or not.
|
|
|
|
*
|
|
|
|
* For example, when using armlink, then if the weak symbol is inside the object
|
|
|
|
* referring to it the weak symbol will be used. This will result in the symbol
|
|
|
|
* being multiply defined because both the weak and strong symbols are used.
|
|
|
|
*
|
|
|
|
* To GNU ld, it doesn't matter if the weak symbol is placed in the same object
|
|
|
|
* which uses the weak symbol. GNU ld will always link to the strong version.
|
|
|
|
*
|
|
|
|
* Having the weak main symbol in an independent file ensures that it will be
|
|
|
|
* correctly treated by multiple linkers.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <kernel_internal.h>
|
|
|
|
|
2022-11-04 16:22:25 +01:00
|
|
|
int __weak main(void)
|
2021-05-31 14:59:23 +02:00
|
|
|
{
|
|
|
|
/* NOP default main() if the application does not provide one. */
|
|
|
|
arch_nop();
|
2022-11-04 16:22:25 +01:00
|
|
|
|
|
|
|
return 0;
|
2021-05-31 14:59:23 +02:00
|
|
|
}
|