Categoria: Virtualizzazione

  • Segger emApps


    emApps è un pacchetto software rivoluzionario che porta nel mondo dei sistemi embedded la flessibilità tipica degli smartphone. Come alternativa al firmware statico, emApps introduce un livello applicativo che consente di aggiungere nuove funzionalità in qualsiasi momento, senza toccare il nucleo del sistema già validato.

    Per ottenere questo risultato, emApps permette di creare app: piccoli programmi che possono essere caricati dinamicamente ed eseguiti in un ambiente protetto noto come sandbox. Ogni app opera nel proprio spazio di memoria isolato dal firmware e dalle altre applicazioni.

    Queste app consentono all’utente di aggiungere nuove capacità, funzioni o miglioramenti ai dispositivi embedded mantenendo il firmware compatto e garantendo stabilità e sicurezza del sistema. Inoltre, permettono ai produttori di eseguire test sui sistemi embedded utilizzando app dedicate.

    Poiché le app vengono caricate dinamicamente, non aumentano le dimensioni del firmware. Di conseguenza, è possibile scrivere ed eseguire un numero illimitato di test, inclusi test di funzionalità e di prestazioni.

    Le capacità delle app sono definite da una tabella API nel firmware, che offre allo sviluppatore il pieno controllo sulle funzionalità esatte messe a disposizione. È persino possibile concedere diritti diversi (tabelle API differenti) a diverse app in esecuzione nel sistema.


    Caratteristiche principali

    • Dimensioni ridotte del firmware: emApps richiede solo un minuscolo esecutore e un loader all’interno del firmware, con un ingombro di circa 2,5 KB nella memoria flash e nessun dato statico richiesto.
    • Dimensioni ridotte delle app: Le app, caricate ed eseguite in RAM, sono molto piccole (a partire da meno di 100 byte). Non esiste un limite superiore alla complessità, rendendo emApps adatto anche a MCU compatte con soli 64 KB di flash.
    • Alte prestazioni: Le app girano su una CPU virtuale progettata da SEGGER. L’alta densità del codice (spesso più compatto del codice ARM Thumb-2 o RISC-V) e la pianificazione efficiente delle istruzioni garantiscono prestazioni elevate.
    • Sandboxing: Ogni app è isolata. Qualsiasi operazione illegale (come l’accesso fuori dallo spazio di memoria assegnato) viene rilevata, restituendo immediatamente il controllo al sistema host.
    • Integrazione semplice: Il codice host è scritto in C. È disponibile anche un esecutore ottimizzato in assembly per core Arm.

    Casi d’uso

    Le app possono essere utilizzate per estendere dinamicamente le capacità di un host o per consentire la personalizzazione da parte di produttori, OEM e clienti finali.

    • Sistemi di produzione e Flasher: Implementazione di routine di programmazione flash o protocolli di comunicazione personalizzati senza modificare il firmware del dispositivo.
    • Sviluppo di app di terze parti: Fornitura di kit di sviluppo a partner esterni per creare app in modo indipendente e sicuro.
    • Ambienti critici per la sicurezza: Funzioni non essenziali (come la logica della GUI) possono essere isolate come app ed escluse dall’ambito della certificazione.
    • Personalizzazione dinamica del prodotto: Espansione delle funzioni sul campo (nuove lingue, algoritmi o standard di connettività).

    Come funziona emApps

    emApps aggiunge un motore di runtime minimo — l’esecutore — nel firmware. Questo componente (~1 KB) agisce come una CPU virtuale che gestisce l’interazione con il sistema. Le app possono essere collegate staticamente o dinamicamente.

    Il firmware assegna memoria all’app solo per la durata dell’esecuzione. Qualsiasi tentativo di accesso esterno viene intercettato dall’esecutore, preservando la stabilità del sistema. A differenza delle soluzioni basate su RTOS o MPU standard, che possono essere complesse da configurare, emApps offre un modello integrato che abilita modularità e aggiornamenti dinamici in un’unica struttura pronta all’uso.


    Funzionalità aggiuntive

    Introspezione

    emApps supporta applicazioni portatili che possono sfruttare API accelerate rilevate tramite introspezione. Questo permette all’applicazione di adattarsi all’hardware su cui gira, rilevando le funzioni disponibili a runtime.

    Modello di esecuzione

    Più app possono girare sotto il controllo di un RTOS, anche in parallelo.

    Prestazioni e densità del codice

    Il set di istruzioni virtuali è estremamente efficiente. L’esecutore emApps ha un rapporto di circa 18 istruzioni host (o cicli di clock) per ogni istruzione virtuale S32 (CPI). Spesso, la densità del codice S32 è superiore a quella del sistema host, migliorando ulteriormente l’efficienza complessiva.


    Valutazione e Licenze

    • Valutazione: È disponibile una versione di prova per PC con app pre-integrate e codice sorgente. È disponibile anche un compilatore S32 online.
    • Licenze: emApps fa parte dell’ecosistema di licenze SEGGER, con opzioni per uso commerciale che includono supporto e aggiornamenti da parte degli esperti SEGGER.

    Desideri che approfondisca un aspetto tecnico specifico, come i dettagli dell’architettura della CPU virtuale S32 o le modalità di integrazione con un RTOS specifico?