Master's thesis - Multi-purpose system for measuring electrical power supplied by electric sockets
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
latex-masters-thesis/problemexpres.tex

162 lines
12 KiB

\section{Embedded systems}
An embedded system is some combination of computer hardware and software, either fixed in capability or programmable, that is specifically designed for a particular function \cite{ganssle2008embedded}. Industrial machines, automobiles, medical equipment, cameras, household appliances, airplanes, vending machines and toys (as well as the more obvious cellular phone and PDA) are among the myriad possible hosts of an embedded system. Embedded systems that are programmable are provided with programming interfaces, and embedded systems programming is a specialized occupation.
\subsection{Processing units}
The term embedded system is quite broad, so there is no surprise that the spectrum of used processing units is also wide. Since the general purpose microprocessors require external components, namely memories and peripherals, they tend to consume extra power and a board space. Since the design limitations of an embedded systems are most of the time low physical size, low power consumption and/or long uptime and ruggedness (more components mean more parts could fail), microprocessors are seldom used. However, most of the commonly used architectures and word lengths are covered. Due to aforementioned reasons, microcontrollers are favored over microprocessors.
\subsection{System-on-chip}
Today's state of chip integration allows production costs of a complex system on chip devices to be relatively low, thus making very SoCs attractive choice for embedded systems. Soc could be described as an integrated circuit (IC) that integrates all components of a computer or other electronic system into a single chip. It may contain digital, analog, mixed-signal, and often radio-frequency functions - all on a single chip substrate \citep{flynn2011computer}. SoCs are very common in the mobile electronics market because of their low power consumption.
%\begin{minipage}{\textwidth}
A typical SoC consists of (specific block diagram can be seen on \ref{f:ar_block}):
\begin{itemize}
\item a microcontroller, microprocessor or digital signal processor (DSP) core(s)
\item memory blocks including a selection of ROM, RAM, EEPROM and Flash
\item timing sources including oscillators and phase-locked loops
\item peripherals including counter-timers, real-time timers and power-on reset generators
\item external interfaces, including industry standards such as USB, FireWire, Ethernet, USART, SPI
\item analog interfaces including ADCs and DACs
\item voltage regulators and power management circuits
\item a bus connecting these blocks
\end{itemize}
%\end{minipage}
SoCs can be implemented as an application-specific integrated circuit (ASIC) or using a field-programmable gate array (FPGA).
\subsection{Operating systems}
An operating system is a computer program that supports a computer's basic functions, and provides services to other programs (or applications) that run on the computer. The applications provide the functionality that the user of the computer wants or needs. The services provided by the operating system make writing the applications faster, simpler, and more maintainable.
Over time, a lot of embedded operating systems suited for embedded systems were developed. An \textit{embedded operating system} is a type of operating system that is embedded and specifically configured for a certain hardware configuration. Hardware that uses embedded operating systems is designed to be lightweight and compact, forsaking many other functions found in non-embedded (i.e. desktop) computer systems in exchange for efficiency at resource usage \cite{holt2014embedded}. This means that they are made to do specific tasks and do them efficiently.
\begin{figure}[ht!]
\centering
\includegraphics[width=.4\textwidth,angle=0]{android_scr.png}
\caption{The Android 5 (Lollipop) screenshot - the most common operating system is among embedded ones}\label{f:android_scr}
\end{figure}
%\begin{minipage}{\textwidth}
Notable embedded OSs currently in use by consumers include:
\begin{itemize}
\item \textbf{Symbian} - used in cell phones, mainly ones made by Nokia
\item \textbf{Embedded Linux} - used in many other devices like printers, routers or smart TVs; Android \ref{f:android_scr} is a subset of embedded Linux
\item \textbf{BlackBerry OS} - for BlackBerry phones
\item \textbf{iOS} - subset of Mac OS X, used in Apple’s mobile devices
Palm OS
\item \textbf{Windows Mobile}
\end{itemize}
%\end{minipage}
\subsection{Real-time operating systems}
A real time operating system is just a special purpose operating system. The \textit{real time} part of the name does not mean that the system responds quickly, it just means that there are rigid time requirements that must be met. If these time requirements are not met, the results can become inaccurate or unreliable\citep{jean2002microc}. Embedded systems frequently posses the real time requirement.
%\begin{minipage}{\textwidth}
There are two kinds of RTOS:
\begin{description}
\item[Hard Real Time]- system delays are known or at least bounded. Said to be operating correctly if the system can return results within any time constraints.
\item[Soft Real Time]- critical tasks get priority over other tasks and will retain priority until the task is completed. This is another way of saying that real time tasks cannot be kept waiting indefinitely. Soft real time makes it easier to mix the system with other systems.
\end{description}
%\end{minipage}
\subsection{Embedded Linux}
Linux itself is a kernel, but \textit{Linux} in day to day terms rarely means so. Embedded Linux generally refers to a complete Linux distribution targeted at embedded devices. There is no Linux kernel specifically targeted at embedded devices, the same Linux kernel source code can be built for a wide range of devices, workstations, embedded systems, and desktops though it allows the configuration of a variety of optional features in the kernel itself. In the embedded development context, there can be an embedded Linux system which uses the Linux kernel and other software or an embedded Linux distribution which is a prepackaged set of applications meant for embedded systems and is accompanied by development tools to build the system\citep{hallinan2010embedded}.
With the availability of consumer embedded devices, communities of users and developers were formed around theses devices: Replacement or enhancements of the Linux distribution shipped on the device has often been made possible thanks to availability of the source code and to the communities surrounding the devices. Due to the high number of devices, standardized build systems have appeared like OpenEmbedded, Buildroot, OpenWrt, and LTIB.
\subsection{Kernel}
The \textit{kernel} is the essential center of a computer operating system, the core that provides basic services for all other parts of the operating system \cite{bovet2005understanding}. It has complete control over what happens in the system. A kernel can be contrasted with a \textit{shell}, the outermost part of an operating system that interacts with user commands. Kernel and shell are terms used more frequently in Unix or Unix-like operating systems than in IBM mainframe or Microsoft Windows systems.
\begin{figure}[ht!]
\centering
\includegraphics[width=.6\textwidth,angle=0]{linux_block.jpg}
\caption{The simplified view on the Linux system structure}\label{f:linuxbl}
\end{figure}
The simplified view on the Linux system structure can be seen on \ref{f:linuxbl}. It does not include device drivers, compilers, deamon, utilities, commands, library files and such, but should be enough for a demonstration.
\subsection{OpenWRT}
OpenWrt is an operating system (in particular, an embedded operating system) based on the Linux kernel, primarily used on embedded devices to route network traffic. The main components are the Linux kernel, util-linux, uClibc and BusyBox. All components have been optimized for size, to be small enough for fitting into the limited storage and memory available in home routers.
OpenWrt is configured using a command-line interface (ash shell), or a web interface (LuCI). There are about 3500 optional software packages available for installation via the opkg package management system.
\newpage
\section{GL.inet board}
GL.inet Smart Router is a remake of a common TP-Link router TL-WR703N. The board changes include, but are not limited to, increased RAM and Flash memory, custom firmware and what is the most important - 5 usable GPIO pins exposed to the 2cm pin header for utility. Whole thesis is revolving around taking advantage of this fact. Basic information about the router are shown in Table \ref{t:charact}.
\begin{table}[h]
\caption{The basic characteristics of the GL.inet board}\label{t:charact}
\medskip
\centering
\def\arraystretch{1.5}
\setlength{\tabcolsep}{12pt}
\begin{tabular}{|l|l|}
\hline
Model & GL-iNet 6408A / 6416A \\ \hline
CPU & Atheros 9331, 400MHZ \\ \hline
RAM/ROM & DDR 64MB \\ \hline
ROM & Flash 8MB (6408A) / 16M (6416A) \\ \hline
Interface & 1 WAN, 1 LAN, 1 USB2.0, 1 Micro USB(Power), 5 GPIO \\
\hline
Wireless & IEEE802.11n/g/b, IEEE802.3, IEEE802.3u \\ \hline
\end{tabular}
\end{table}
\subsection{Atheros 9331 Wi-fi System-on-Chip}
The Atheros AR9331 is a highly integrated and cost effective IEEE 802.11n 1x1 2.4 GHz Systemon-a-Chip (SoC) for wireless local area network (WLAN) AP and router platforms. The block diagram of the chip can be seen on Figure \ref{f:ar_block}. The main processor frequency is 400 MHz and it is suited for running Linux distributions for embedded devices, preferably OpenWrt or DD-Wrt.
Features of this SoC are following:
\begin{itemize}
\item Complete IEEE 802.11n 1x1 AP or router in a single chip
\item MIPS 24K processor operating at up to 400 MHz
\item External 16-bit DDR1, DDR2, or SDRAM memory interface
\item SPI NOR Flash memory support
\item No external EEPROM needed
\item 4 LAN ports and 1 WAN port IEEE 802.3 Fast Ethernet switch with auto-crossover, auto polarity, and auto-negotiation in PHYs
\item Fully integrated RF front-end including PA and LNA
\item Optional external LNA/PA
\item Switched antenna diversity
\item High-speed UART for console support
\item I\textsuperscript{2}S/SPDIF-out audio interface
\item SLIC for VOIP/PCM
\item USB 2.0 host/device mode support
\item GPIO/LED support
\item JTAG-based processor debugging supported
\item 25 MHz or 40 MHz reference clock input
% \item Advanced power management with dynamic clock switching for ultra-low power modes
\item 148-pin, 12 mm x 12 mm dual-row LPCC package
\end{itemize}
\begin{figure}[ht!]
\centering
\includegraphics[width=.8\textwidth,angle=0]{AR9331_block.jpg}
\caption{The block diagram of the Atheros AR9331 SoC used as a main processing unit on GL.inet board}\label{f:ar_block}
\end{figure}
\subsection{From TL-WR703N to GL.inet}
TP-Link TL-WR703N router is a popular choice among hacker community because of it's cheap price tag compared to processing power and usage of a full-grown Linux distribution. People have figured out how to upgrade RAM / Flash memories or to make use of not used GPIO / UART ports for their own needs. These solutions however were mostly crude and expensive to replicate. The GL.inet team saw an opportunity to grasp this public knowledge and rolled out their own improved board clone to the marked.
Whole printed circuit board of TL-WR703N was remade by the GL.inet team to expose the unused GPIO ports on the SoC, utilize two Ethernet port instead of one and utilize the USB 2.0 port. Memory chips were replaced by their higher capacity alternatives.
\begin{figure}[ht!]
\centering
\includegraphics[width=.8\textwidth,angle=0]{gl-inet_pcb_up.jpg}
\caption{The front side of the GL.inet board exposing the main Atheros SoC, RAM and interfaces}\label{f:board_front}
\end{figure}
\begin{figure}[ht!]
\centering
\includegraphics[width=.8\textwidth,angle=0]{gl-inet_pcb_down.jpg}
\caption{The back side of the GL.inet board exposing the Flash memory and a main voltage regulator}\label{f:board_back}
\end{figure}