Since the beginning of the multicore era, parallel processing has become prevalent across the board. On a traditional multicore system, a single operating system manages all cores and schedules threads and processes among them, inherently supported by hardware-implemented cache coherence protocols. However, a further growth of the number of cores per system implies an increasing chip complexity, especially with respect to the cache coherence protocols. Therefore, a very attractive alternative for future many-core systems is to waive the hardware-based cache coherency and to introduce a software-oriented message-passing based architecture instead: a so-called Cluster-on-Chip architecture. Intel's Single-chip Cloud Computer (SCC), a many-core research processor with 48 non-coherent memory-coupled cores, is a very recent example for such a Cluster-on-Chip architecture. The SCC can be configured to run one operating system instance per core by partitioning the shared main memory in a strict manner. However, it is also possible to access the shared main memory in an unsplit and concurrent manner, provided that the cache coherency is then ensured by software. In this paper, we detail our first experiences gained while developing low-level software for message-passing and shared-memory programming on the SCC. In doing so, we evaluate the potential of both programming models and we show how these models can be improved especially with respect to the SCC's many-core architecture.
[1]
Nick Knupffer.
Intel Corporation
,
2018,
The Grants Register 2019.
[2]
Thomas Bemmerl,et al.
A Shared Memory Programming Interface for SCI Clusters
,
1999,
Scalable Coherent Interface.
[3]
Anthony Skjellum,et al.
A High-Performance, Portable Implementation of the MPI Message Passing Interface Standard
,
1996,
Parallel Comput..
[4]
J. Donnelly.
Periodic chaotic relaxation
,
1971
.
[5]
Saurabh Dighe,et al.
The 48-core SCC Processor: the Programmer's View
,
2010,
2010 ACM/IEEE International Conference for High Performance Computing, Networking, Storage and Analysis.