1,885
edits
Changes
SPO600
,no edit summary
{| style="float: right; margin: 0 0 3em 2em; border: 1px solid black;"
!style="background: #cccccc"| Quick Links
|-|<div style="background:#ffff00">[[Current SPO600 Weekly Schedule|Weekly Schedule]]</div>[[Winter 2017 Current SPO600 Participants|Participants and Project Table]]<br />[httphttps://wwwtelescope.cdot.systems Telescope]<br />[https://ict.senecacollege.ca/ssos/findWithoutSemestercourse/spo600/sict Course Outline]<br />[[media:SPO600 Course PoliciesWinter 2022 addendum.pdf|Course PoliciesWinter 2022 Addendum]]<br />[http://linaro.org Linaro]<br /><!--[http://performance.linaro.org Linaro Performance ChallengeSPO600 Course Policies|Course Policies]<br /> -->[http://zenit.senecac.on.ca/~chris.tyler/planet/ Planet CDOT]<br />
|}[[Category:SPO600]]
<!-- {{Admon/tip|Thinking of taking this course?|[[SPO600 - Information for Prospective Students|Here is some information for prospective students.]]}}-->
= Software Portability and Optimization =
SPO600 is a professional option in the [http://ict.senecac.on.ca/ Seneca School of Information and Communication Technology] [https://ict.senecacollege.ca/academic-programs/cty/overview CTY] and [https://ict.senecacollege.ca/academic-programs/cpa/overview CPA] programs. First offered: Winter 2014.
== SPO600 in Winter 2017 Fall 2023 ==
A new computer architecture has appeared: 64-bit ARM systems (also known as "ARM64" or "AArch64"). While AArch64 is showing up in cell phones and tablets, it is also poised to pounce on the datacentre. Most of the work of porting core software to AArch64 has been completed, and at this point, just about everything that runs on x86_64 Linux systems will run an AArch64 systems. However, the x86_64 architecture has been around for many years, and software has been well-optimized to work on that architecture; but AArch64 is relatively new, and it may be possible to get better performance with additional tuning and optimization.
In this semester, the SPO600 course will be focused on optimizing software on AArch64 systems, using and specifically on building infrastructure to make it easier to use indirect functions (similar to the [http://leapprojectglibc "ifunc" capability) for runtime implementation selection.ca LEAP]This technique is widely used in a few places -- such as in glibc, [http://fedoraprojectthe GNU standard C library -- but it would be great if we could easily use it in other places.org Fedora]This would allow (for example) two versions of a particular function to be automatically compiled, with and [http:without support for particular hardware features (such as Scalable Vector Extensions (SVE//centos.org CentOS] projects as a starting point. We will be benchmarking SVE2)), and for the performance of open source software stacks on AArch64 relative best version to the raw performance of the hardware and searching for optimization opportunitiesbe automatically used at runtime.
Note that, unlike some other project-based courses, the results of the projects done in SPO600 will eventually be incorporated into the actual "upstream" open source software, and have a real impact on other people. For this reason, projects must be completed in collaboration with the relevant open source communities, using relevant [[SPO600 Communication Tools|communication tools]]. Work performed in this course will be licensed using the relevant open source licenses used by the associated community.
Working in an open source community provides the opportunity to build solid real-world experience, your technical skills and reputation, and a network of contacts, all of which are useful in developing your career.
'''Required:'''
* You '''must''' be able to [[SSH]] to [[SPO600 Servers|computer systems]] at Seneca (CDOT). You can do this using an SSH client program, included with or available for almost all platforms.
* You '''must''' be able to participate in synchronous (live) streaming classes and be able to view/stream video content.
<!-- '''Strongly Recommended:'''* Classes are held in an [[Active Learning Classroom]]. You '''should''' have a mobile device of some type (laptop, smartphone, tablet) with a wireless network connection (WiFi or mobile) and a video output (VGA or HDMI). If your video output is of a different type (VGA/DVI/DP/Miracast/MyDP/MiniDP/MiniHDMI/other) you will need an appropriate adapter.
* For productivity, you '''should''' have access to a personal Linux installation on a 64-bit (x86_64) computer (see [[SPO600 Host Setup]]).
* '''If available''', students Students in the SPO600 course may want to purchase a 64-bit [https://www.96boards.org/ 96Boards] ARM computer (, such as a Rasbperry Pi 4 or Raspberry Pi 400 -- but you will need to run a 64-bit operating system, such as [https://www.96boardsfedoraproject.org/productswiki/hikeyArchitectures/ HiKey] or [https:ARM//www.96boards.org/products/dragonboard410c/ DragonBoard 410cRaspberry_Pi Fedora AArch64]).-->
=== Professor ===
There are three keys to success in this course:
1. '''Work ''in'' the open source communityBlog.''' The projects we will be doing are too large and too unfamiliar for you to succeed entirely on Tell your own. You will need to use the community's knowledgeprofessor, connectionsyour colleagues, and resources to succeed well. Respect the community's standards, tell the community and everyone else what you're doing. <u>Write a lot</u> and write well, ask when you have a questioninclude good technical content, and incorporate links to all relevant resources and the product of your work, and pull write often. Almost all of your own weight within the communitywork in this course is submitted by blogging.
2. '''BlogBe ambitious.''' Tell your professorIn this course, you will need to be the driving force behind your colleagues, the project. The communitywill help you, and everyone else what but it's up to you're doing. <u>Write a lot</u> and write well, include good technical content, and incorporate links to all relevant resources and supply the product of your work, and write often. Almost all of your work in this course is submitted by bloggingenergy.
3. '''Be ambitiousWork ''in'' the open source community.''' In this course, The projects we will be doing are too large and too unfamiliar for you to succeed entirely on your own. You will need to be use the driving force behind your projectcommunity's knowledge, connections, and resources to succeed well. The Respect the community's standards, tell the community will help what you're doing, but it's up to ask when you to supply have a question, and pull your own weight within the energycommunity.
== Course Outline ==
See the online [https://ict.senecacollege.ca/course/spo600 course outline] for course details, and the [[media:SPO600 Winter 2022 addendum.pdf|Winter 2022 Addendum]] for additional course details.