Adding SIMD support to improve performance of Eclipse OpenJ9 on the AArch64 platform

dc.contributor.advisorKent, Kenneth
dc.contributor.authorNoor, Md Alvee
dc.date.accessioned2023-03-01T16:37:51Z
dc.date.available2023-03-01T16:37:51Z
dc.date.issued2021
dc.date.updated2023-03-01T15:02:53Z
dc.description.abstractJust-in-time (JIT) compilers achieve application portability and improved management of large code-bases by abstracting the architecture specific details from the programmers. A large number of compiler optimization techniques make this a subject undergoing intense study, over the last few decades. Eclipse OMR is a robust language runtime builder, and Eclipse OpenJ9 is a managed language runtime that consumes OMR. The targeted domains of OMR and OpenJ9 include AArch64, a 64-bit extended version of the ARM architecture. AArch64 features compatibility to the user-space, along with the pre-existing 32-bit AArch32 architecture. AArch64 is a popular member of the embedded computing market, where computing infrastructure resources (i.e., CPU, memory) are constrained. This thesis discusses the steps taken to add Single Instruction Multiple Data (SIMD) support to OMR for AArch64, and relevant OMR tril tests to confirm the appropriate functioning of the implemented mechanisms. The implementation of advanced SIMD and floating-point instructions are also discussed, which cover vectorized mathematical operations, including addition, subtraction, multiplication, and division for supported data-types. We present two microbenchmarks VectorizationMicrobenchmark and Sepia Tone Filter and a set of standard benchmarks, which leverage the OpenJ9 autovectorization process in AArch64. The AArch64 vectorized operations are evaluated against non-vectorized, but similar operations using Eclipse OpenJ9. Our microbenchmarks show improvements of up to four times in execution speed of certain vector arithmetic operations.
dc.description.copyright© Md Alvee Noor, 2021
dc.formattext/xml
dc.format.extentxiv, 93 pages
dc.format.mediumelectronic
dc.identifier.oclc(OCoLC)1418896744en
dc.identifier.otherThesis 10971en
dc.identifier.urihttps://unbscholar.lib.unb.ca/handle/1882/14236
dc.language.isoen_CA
dc.publisherUniversity of New Brunswick
dc.rightshttp://purl.org/coar/access_right/c_abf2
dc.subject.disciplineComputer Science
dc.subject.lcshVirtual computer systems.en
dc.subject.lcshJust-in-time systems.en
dc.subject.lcshProgramming languages (Electronic computers)en
dc.titleAdding SIMD support to improve performance of Eclipse OpenJ9 on the AArch64 platform
dc.typemaster thesis
thesis.degree.disciplineComputer Science
thesis.degree.fullnameMaster of Computer Science
thesis.degree.grantorUniversity of New Brunswick
thesis.degree.levelmasters
thesis.degree.nameM.C.S.

Files

Original bundle
Now showing 1 - 1 of 1
Loading...
Thumbnail Image
Name:
item.pdf
Size:
1.99 MB
Format:
Adobe Portable Document Format