mirror of https://github.com/FOME-Tech/openblt.git
Refs #579. Added configuration option for completely disabling memory read operations via XCP.
git-svn-id: https://svn.code.sf.net/p/openblt/code/trunk@550 5dc33758-31d5-4daf-9ae8-b24bf3d40d73
This commit is contained in:
parent
17beaf5802
commit
56cf1c696d
|
@ -452,6 +452,14 @@
|
||||||
#error "BOOT_XCP_SEED_KEY_ENABLE must be 0 or 1"
|
#error "BOOT_XCP_SEED_KEY_ENABLE must be 0 or 1"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef BOOT_XCP_UPLOAD_EN
|
||||||
|
#define BOOT_XCP_UPLOAD_EN (1)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (BOOT_XCP_UPLOAD_EN < 0) || (BOOT_XCP_UPLOAD_EN > 1)
|
||||||
|
#error "BOOT_XCP_UPLOAD_EN must be 0 or 1"
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef BOOT_XCP_PACKET_RECEIVED_HOOK
|
#ifndef BOOT_XCP_PACKET_RECEIVED_HOOK
|
||||||
#define BOOT_XCP_PACKET_RECEIVED_HOOK (0)
|
#define BOOT_XCP_PACKET_RECEIVED_HOOK (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -124,7 +124,7 @@ extern blt_int8u XcpVerifyKeyHook(blt_int8u resource, blt_int8u *key, blt_int8u
|
||||||
#if (BOOT_COM_ENABLE == 0)
|
#if (BOOT_COM_ENABLE == 0)
|
||||||
/* in case no internally supported communication interface is used, a custom
|
/* in case no internally supported communication interface is used, a custom
|
||||||
* communication module can be added. In order to use the XCP protocol in the custom
|
* communication module can be added. In order to use the XCP protocol in the custom
|
||||||
* communication module, this hook function needs to be implemented. In the XCP protocol
|
* communication module, this hook function needs to be implemented. If the XCP protocol
|
||||||
* is not needed, then simply remove the xcp.c source from the project.
|
* is not needed, then simply remove the xcp.c source from the project.
|
||||||
*/
|
*/
|
||||||
extern void XcpTransmitPacketHook(blt_int8u *data, blt_int16u len);
|
extern void XcpTransmitPacketHook(blt_int8u *data, blt_int16u len);
|
||||||
|
@ -694,13 +694,14 @@ static void XcpCmdUpload(blt_int8u *data)
|
||||||
/* set the destination pointer */
|
/* set the destination pointer */
|
||||||
destPtr = (blt_int8u *)((blt_addr)(blt_int32u)&xcpInfo.ctoData[1]);
|
destPtr = (blt_int8u *)((blt_addr)(blt_int32u)&xcpInfo.ctoData[1]);
|
||||||
|
|
||||||
|
#if (XCP_UPLOAD_EN == 1)
|
||||||
/* according to the XCP specification memory read/upload functionality is always
|
/* according to the XCP specification memory read/upload functionality is always
|
||||||
* available. This behavior is unwanted in the case of a bootloader that has the
|
* available. This behavior is unwanted in the case of a bootloader that has the
|
||||||
* seed/key security feature enabled. The default XCP behavior is deviated in this
|
* seed/key security feature enabled. The default XCP behavior is deviated in this
|
||||||
* situation. The deviation is such that all zero values are returned if the seed/key
|
* situation. The deviation is such that all zero values are returned if the seed/key
|
||||||
* security feature is enabled and the programming resource is not yet unlocked.
|
* security feature is enabled and the programming resource is not yet unlocked.
|
||||||
*/
|
*/
|
||||||
#if (XCP_SEED_KEY_PROTECTION_EN == 1)
|
#if (XCP_SEED_KEY_PROTECTION_EN == 1)
|
||||||
/* check if PGM resource is unlocked */
|
/* check if PGM resource is unlocked */
|
||||||
if ((xcpInfo.protection & XCP_RES_PGM) == XCP_RES_PGM)
|
if ((xcpInfo.protection & XCP_RES_PGM) == XCP_RES_PGM)
|
||||||
{
|
{
|
||||||
|
@ -714,10 +715,14 @@ static void XcpCmdUpload(blt_int8u *data)
|
||||||
/* copy the data from memory to the data packet */
|
/* copy the data from memory to the data packet */
|
||||||
CpuMemCopy((blt_addr)destPtr,(blt_addr)xcpInfo.mta, len);
|
CpuMemCopy((blt_addr)destPtr,(blt_addr)xcpInfo.mta, len);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
/* copy the data from memory to the data packet */
|
/* copy the data from memory to the data packet */
|
||||||
CpuMemCopy((blt_addr)destPtr,(blt_addr)xcpInfo.mta, len);
|
CpuMemCopy((blt_addr)destPtr,(blt_addr)xcpInfo.mta, len);
|
||||||
#endif
|
#endif /* XCP_SEED_KEY_PROTECTION_EN == 1 */
|
||||||
|
#else
|
||||||
|
/* uploads are disabled, so return zero values for memory read operations */
|
||||||
|
CpuMemSet((blt_addr)destPtr, 0, len);
|
||||||
|
#endif /* XCP_UPLOAD_EN == 1 */
|
||||||
|
|
||||||
/* set packet id to command response packet */
|
/* set packet id to command response packet */
|
||||||
xcpInfo.ctoData[0] = XCP_PID_RES;
|
xcpInfo.ctoData[0] = XCP_PID_RES;
|
||||||
|
@ -757,13 +762,14 @@ static void XcpCmdShortUpload(blt_int8u *data)
|
||||||
/* set the destination pointer */
|
/* set the destination pointer */
|
||||||
destPtr = (blt_int8u *)((blt_addr)(blt_int32u)&xcpInfo.ctoData[1]);
|
destPtr = (blt_int8u *)((blt_addr)(blt_int32u)&xcpInfo.ctoData[1]);
|
||||||
|
|
||||||
|
#if (XCP_UPLOAD_EN == 1)
|
||||||
/* according to the XCP specification memory read/upload functionality is always
|
/* according to the XCP specification memory read/upload functionality is always
|
||||||
* available. This behavior is unwanted in the case of a bootloader that has the
|
* available. This behavior is unwanted in the case of a bootloader that has the
|
||||||
* seed/key security feature enabled. The default XCP behavior is deviated in this
|
* seed/key security feature enabled. The default XCP behavior is deviated in this
|
||||||
* situation. The deviation is such that all zero values are returned if the seed/key
|
* situation. The deviation is such that all zero values are returned if the seed/key
|
||||||
* security feature is enabled and the programming resource is not yet unlocked.
|
* security feature is enabled and the programming resource is not yet unlocked.
|
||||||
*/
|
*/
|
||||||
#if (XCP_SEED_KEY_PROTECTION_EN == 1)
|
#if (XCP_SEED_KEY_PROTECTION_EN == 1)
|
||||||
/* check if PGM resource is unlocked */
|
/* check if PGM resource is unlocked */
|
||||||
if ((xcpInfo.protection & XCP_RES_PGM) == XCP_RES_PGM)
|
if ((xcpInfo.protection & XCP_RES_PGM) == XCP_RES_PGM)
|
||||||
{
|
{
|
||||||
|
@ -777,10 +783,14 @@ static void XcpCmdShortUpload(blt_int8u *data)
|
||||||
/* copy the data from memory to the data packet */
|
/* copy the data from memory to the data packet */
|
||||||
CpuMemCopy((blt_addr)destPtr,(blt_addr)xcpInfo.mta, len);
|
CpuMemCopy((blt_addr)destPtr,(blt_addr)xcpInfo.mta, len);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
/* copy the data from memory to the data packet */
|
/* copy the data from memory to the data packet */
|
||||||
CpuMemCopy((blt_addr)destPtr,(blt_addr)xcpInfo.mta, len);
|
CpuMemCopy((blt_addr)destPtr,(blt_addr)xcpInfo.mta, len);
|
||||||
#endif
|
#endif /* XCP_SEED_KEY_PROTECTION_EN == 1 */
|
||||||
|
#else
|
||||||
|
/* uploads are disabled, so return zero values for memory read operations */
|
||||||
|
CpuMemSet((blt_addr)destPtr, 0, len);
|
||||||
|
#endif /* XCP_UPLOAD_EN == 1 */
|
||||||
|
|
||||||
/* set packet id to command response packet */
|
/* set packet id to command response packet */
|
||||||
xcpInfo.ctoData[0] = XCP_PID_RES;
|
xcpInfo.ctoData[0] = XCP_PID_RES;
|
||||||
|
|
|
@ -99,6 +99,17 @@
|
||||||
#define XCP_SEED_KEY_PROTECTION_EN (0)
|
#define XCP_SEED_KEY_PROTECTION_EN (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/** \brief Enable (=1) or disable (=0) uploading. By default, XCP always allows memory
|
||||||
|
* read operations using the commands UPLOAD and SHORT_UPLOAD. This is not
|
||||||
|
* always desired for security reasons. If disabled, memory reads via XCP always
|
||||||
|
* return zero values.
|
||||||
|
*/
|
||||||
|
#if (BOOT_XCP_UPLOAD_EN > 0)
|
||||||
|
#define XCP_UPLOAD_EN (1)
|
||||||
|
#else
|
||||||
|
#define XCP_UPLOAD_EN (0)
|
||||||
|
#endif
|
||||||
|
|
||||||
/** \brief Enable (=1) or disable the hook function that gets called each time an XCP
|
/** \brief Enable (=1) or disable the hook function that gets called each time an XCP
|
||||||
* packet was received from the host.
|
* packet was received from the host.
|
||||||
* \details A master-slave bootloader can be realized by using this hook-function. The
|
* \details A master-slave bootloader can be realized by using this hook-function. The
|
||||||
|
@ -119,6 +130,7 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/****************************************************************************************
|
/****************************************************************************************
|
||||||
* Defines
|
* Defines
|
||||||
****************************************************************************************/
|
****************************************************************************************/
|
||||||
|
@ -319,6 +331,13 @@ void XcpPacketReceived(blt_int8u *data, blt_int8u len);
|
||||||
#error "XCP.H, XCP_SEED_KEY_PROTECTION_EN must be 0 or 1."
|
#error "XCP.H, XCP_SEED_KEY_PROTECTION_EN must be 0 or 1."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef XCP_UPLOAD_EN
|
||||||
|
#error "XCP.H, Configuration macro XCP_UPLOAD_EN is missing."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (XCP_UPLOAD_EN < 0) || (XCP_UPLOAD_EN > 1)
|
||||||
|
#error "XCP.H, XCP_UPLOAD_EN must be 0 or 1."
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef XCP_PACKET_RECEIVED_HOOK_EN
|
#ifndef XCP_PACKET_RECEIVED_HOOK_EN
|
||||||
#error "XCP.H, Configuration macro XCP_PACKET_RECEIVED_HOOK_EN is missing."
|
#error "XCP.H, Configuration macro XCP_PACKET_RECEIVED_HOOK_EN is missing."
|
||||||
|
|
Loading…
Reference in New Issue