Open main menu

CDOT Wiki β

Changes

SPO600

2,791 bytes added, 5 April
no edit summary
k{{Chris Tyler Draft}}<!-- {| style="float: right; margin: 0 0 3em 2em; border: 1px solid black;"
!style="background: #cccccc"| Quick Links
|-|<div style="background:#ffff00">[[Fall 2013 SBR600 Current SPO600 Weekly Schedule|Weekly Schedule]]</div>[[Fall 2013 SBR600 Current SPO600 Participants|Participants and Project Table]]<br />[[SBR600 Potential Projects|Potential Project List]]<br https://>[[Fall 2013 SBR600 Presentation Schedule|Release Presentation Schedule]telescope.cdot.systems Telescope]<br />[https://scs.senecacict.onsenecacollege.ca/course/sbr600 spo600 Course Outline]<br />[[Fedora ARM Secondary Architecturemedia:SPO600 Winter 2022 addendum.pdf|Winter 2022 Addendum]]<br />[http://pidora.ca Pidora[SPO600 Course Policies|Course Policies]]<br />|}[http[Category://fedoraproject.org Fedora ProjectSPO600]<br />[http://docs.fedoraproject.org/ Fedora documentation]<br !-- {{Admon/>tip|Thinking of taking this course?|[http://zenit.senecac.on.ca/~chris.tyler/planet/ Planet CDOT]<br />[http://kojiSPO600 - Information for Prospective Students|Here is some information for prospective students.fedoraproject.org Fedora Koji]<br />[http://koji.pidora.ca Pidora Koji]|}}-->[[Category:SPO600]]= Software Portability and Optimization =
= Software Porting is sometimes written to work on a specific computer architecture (type of computer), such as on Intel-compatible x86_64 PCs, or IBM Z-series mainframes. This course deals with the challenge of making software compatible with a new architecture in one of two ways:# Adding additional architecture-specific code so that the software can run on the new architecture ('porting' the software), or# Removing the architecture-specific code and Optimization =replacing it with architectural-neutral code, so that it can run on a variety of system architectures (making the software 'portable').
This course In either case, software can be altered or it can be built in such a way that performance is a professional option in the [http://ict.senecac.onoptimized - so that runs faster, or it uses less memory or other resources.ca/ Seneca School of Information In order to test optimizations, we'll be performing benchmark testing before and Communication Technology] [https://ict.senecacollege.ca/academic-programs/cty/overview CTY] and [https://ict.senecacollege.ca/academic-programs/cpa/overview CPA] program. First offering: Winter 2014after modification.
== SPO600 is a professional option in Fall 2013 ==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.
In == SPO600, you'll be working directly with open source communities to port software. This semester, we'll be working with a number of communities as well as Linaro to port software to the ARM 64-bit (Aarch64) platform.in 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, and specifically on building infrastructure to make it easier to use indirect functions (similar to the glibc "ifunc" capability) for runtime implementation selection. This technique is widely used in a few places -- such as in glibc, the GNU standard C library -- but it would be great if we could easily use it in other places. This would allow (for example) two versions of a particular function to be automatically compiled, with and without support for particular hardware features (such as Scalable Vector Extensions (SVE/SVE2)), and for the best version to be 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 projectssoftware, 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 [[OPS600 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.
=== Course Materials / System Requirements === * Course information and labs are online - no textbook is required. '''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.
<!-- '''Recommended:'''* Course information 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 labs are onlinea video output (HDMI). If your video output is of a different type (VGA/DVI/DP/Miracast/MyDP/MiniDP/MiniHDMI/other) you will need an appropriate adapter.* You will require For productivity, you '''should''' have access to a personal Fedora 18 or Fedora 19 Linux installationon a 64-bit (x86_64) computer (see [[SPO600 Host Setup]]). This * Students in the SPO600 course may be on your own laptop, on want to purchase a virtual machine on your laptop64-bit ARM computer, on an SSH-accessible system (such as a home desktop computer), Rasbperry Pi 4 or on Raspberry Pi 400 -- but you will need to run a SATA disk pack or USB drive for use with the Seneca computers64-bit operating system, such as [https://fedoraproject.org/wiki/Architectures/ARM/Raspberry_Pi Fedora AArch64].-->
=== Professor ===
There are three keys to success in this course:
1. '''Blog.''' Tell your professor, your colleagues, the community, and everyone else what you're doing. <u>Write a lot</u> and write well, include good technical content, and incorporate links to all relevant resources and the product of your work, and write often. Almost all of your work in this course is submitted by blogging. 2. '''Be ambitious.''' In this course, you will need to be the driving force behind your project. The community will help you, but it's up to you to supply the energy. 3. '''Work ''in'' the open source community.''' The projects we will be doing are too large and too unfamiliar for you to succeed entirely on your own. You will need to use the community's knowledge, connections, and resources to succeed well. Respect the community's standards, tell the community what you're doing, ask when you have a question, and pull your own weight within the community.
2. '''Blog.''' Tell your professor, your colleagues, the community, and everyone else what you're doing. Write a lot and write well, include good technical content, and incorporate links to all relevant resources and the product of your work, and write often. Almost all of your work in this course is submitted by blogging.
3. '''Be ambitious.''' In this course, you will need to be the driving force behind your project. The community will help you, but it's up to you to supply the energy. '''It's best to plan to make a bit of progress each day.'''
== Weekly Outline ==
See the [[Winter 2013 Current SPO600 Weekly Schedule]] for specific dates and topics.
== 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.