Change in osmo-ccid-firmware[master]: obtain chip-unique serial number and print it during startup.

This is merely a historical archive of years 2008-2021, before the migration to mailman3.

A maintained and still updated list archive can be found at https://lists.osmocom.org/hyperkitty/list/gerrit-log@lists.osmocom.org/.

Harald Welte gerrit-no-reply at lists.osmocom.org
Fri May 17 09:03:26 UTC 2019


Harald Welte has submitted this change and it was merged. ( https://gerrit.osmocom.org/13710 )

Change subject: obtain chip-unique serial number and print it during startup.
......................................................................

obtain chip-unique serial number and print it during startup.

Change-Id: I298942e12f9ffd6f571555253fda160baece5c6c
---
M sysmoOCTSIM/main.c
1 file changed, 36 insertions(+), 0 deletions(-)



diff --git a/sysmoOCTSIM/main.c b/sysmoOCTSIM/main.c
index 4bda38a..3c189eb 100644
--- a/sysmoOCTSIM/main.c
+++ b/sysmoOCTSIM/main.c
@@ -20,6 +20,7 @@
 #include <stdio.h>
 #include <math.h>
 #include <parts.h>
+#include <errno.h>
 #include <hal_cache.h>
 #include <hri_port_e54.h>
 
@@ -738,9 +739,43 @@
 	return 0;
 }
 
+/* Section 9.6 of SAMD5x/E5x Family Data Sheet */
+static int get_chip_unique_serial(uint8_t *out, size_t len)
+{
+	uint32_t *out32 = (uint32_t *)out;
+	if (len < 16)
+		return -EINVAL;
+
+	out32[0] = *(uint32_t *)0x008061fc;
+	out32[1] = *(uint32_t *)0x00806010;
+	out32[2] = *(uint32_t *)0x00806014;
+	out32[3] = *(uint32_t *)0x00806018;
+
+	return 0;
+}
+
+/* same as get_chip_unique_serial but in hex-string format */
+static int get_chip_unique_serial_str(char *out, size_t len)
+{
+	uint8_t buf[16];
+	int rc;
+
+	if (len < 16*2 + 1)
+		return -EINVAL;
+
+	rc = get_chip_unique_serial(buf, sizeof(buf));
+	if (rc < 0)
+		return rc;
+	osmo_hexdump_buf(out, len, buf, sizeof(buf), NULL, false);
+	return 0;
+}
+
 int main(void)
 {
+	char sernr_buf[16*2+1];
+
 	atmel_start_init();
+	get_chip_unique_serial_str(sernr_buf, sizeof(sernr_buf));
 
 	usb_start();
 
@@ -760,6 +795,7 @@
 	command_register(&cmd_talloc_free);
 
 	printf("\r\n\r\nsysmocom sysmoOCTSIM\r\n");
+	printf("Chip-Id %s\r\n", sernr_buf);
 
 	talloc_enable_null_tracking();
 	g_tall_ctx = talloc_named_const(NULL, 0, "global");

-- 
To view, visit https://gerrit.osmocom.org/13710
To unsubscribe, or for help writing mail filters, visit https://gerrit.osmocom.org/settings

Gerrit-Project: osmo-ccid-firmware
Gerrit-Branch: master
Gerrit-MessageType: merged
Gerrit-Change-Id: I298942e12f9ffd6f571555253fda160baece5c6c
Gerrit-Change-Number: 13710
Gerrit-PatchSet: 3
Gerrit-Owner: Harald Welte <laforge at gnumonks.org>
Gerrit-Reviewer: Jenkins Builder (1000002)
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.osmocom.org/pipermail/gerrit-log/attachments/20190517/333c4823/attachment.htm>


More information about the gerrit-log mailing list