Context Switch..An initial investigtion on ARM processor

Modern operating system offer multitasking and multiprocessing. Even we have multiprocessor based systems. All of these require a Scheduler to manage and ever wondered how fast and smoothly all these are managed by Scheduler so that we don't even notice even a glitch. 
The answer lies in the core of Scheduler - Context Switch
Let's take a small example of scheduler code from SLOS;

task t=0,t';

scheduler()
{
    t' = t+1;
    if t' = MAX_NUM_OF_TASK then
        t' = 0;
    end;

    contextSwitch(t,t');
}

See what is scheduler without a little function at the end of it.  Now lets see this code in little more detail. The current task PCB t, is set to 0 during initialization. When periodic tick occurs, next task t' is calculated from the task list. If the task reaches the MAX then t' is reset to Zero. It's a simple round robin scheduling. Once the task is selected, it need to be run. That where our context switching happens.
ContextSwitch() mainly does two tasks:-
    1. Saving the current context, t
    2. Loading the next context, t'
Ahh, we know this basic but lets go in little more detail now.

Save the current context, t

All the task execute in user mode so the user mode registers need to be saved.
1. save r0 - r3 & r14 from the stack which belong to the current task.
2. r13 points to the PCB of current task t. 
3. store all the registers from r0- r14 and this occur in a single instruction.
4. store spsr and return lr.
Here is what happens,

Offset15Regs   EQU   15*4

LDMFD  r13!,{r0-r3,r12,r14}
LDR        r13,=PCB_t
LDR        r13,[r13]
SUB        r13,r13,#Offset15Regs
STMIA   r13,{r0-r14}^
MRS       r0, spsr
STMDB r13,{r0-r14}

Load the next context, t'

1. load r13 at offset -60 from start of new PCB.
2. load spsr and lr first and then load rest r0-r14
3. IRQ stack is restored from PCB_IRQStack.
4. new task, t' is assumed after copying the address held in r14 into pc and updating cpsr.
Here is the code for this,

LDR        r13,=PCB_t'
LDR        r13,[r13]
SUB        r13,r13,#Offset15Regs
LDMDB r13,{r0-r14}
MSR       spsr_cxsf, r0
LDMIA  r13,{r0-r14}^
LDR       r13,+PCB_IRQStack
LDR       r13,[r13]
MOVS   ps,r14


Now the Context Switch is complete!!!


touch screen technology



Capacitive touch screen: The capacitive touch screen is made up of a glass panel that is coated with a material.
The property of this material is that it can store electrical charge. So the capacitive touchscreens basically stores electrical charge.
But for good, Human body can also store charge. So, when you touch this screen with your finger, some of these charges on the screen gets transferred to your finger. The oscillator circuits located at the corner of your system will then sense this decrease in the charge on screen and the spot the exact location where touch occurred, and then transfers this specified information to the touchscreen driver software.


Pros:
Multi touch support available
Visibility good even in sunlight
Highly sensitive to finger touch leading to ease of use
Not prone to dust particles
Glossy look and feel

Cons:
Need to have atleast 5% humidity to achieve capacitive effect
More expensive than Resistive touch screen
Doesn't work with inanimate objects/fingernails/gloved fingers
Latest technology, may need to evolve a bit more!





Resistive touch screen: Resistive touch screen, on the other hand is again made up of normal glass panel. However, this glass panel in this case is coated with three layers.
Two of these layers () being conductive and resistive are kept apart using spacers while the third scratch-resistant layer covers the whole setup
When the resistive touch screen system is running, current flows through these layers. On a finger touch, the two layers get connected and change in electrical field occurs. The system calculates the coordinates of point of contact and passes them to touch screen driver software.
It is made of two resistive layers opposing each other with a conducting transparent material call Indium tin oxide (ITO). ITO has 100 – 500 ohm sensitivity per sq. m

Pros:
Relatively cheaper
Can operate with any pointing devices like stylus, pen, nail etc
Can operate at any level of humidity
Ease of use, as it could be used even with your winter gloves on!
Very useful for people using handwriting recongition system, due to ease of use with a stylus!
More accurate than capacitive touch screen!
Old technology and hence more reliable!


Cons:
Multi touch support not available. Though technology did evolve after some modifications with the existing resistive touch screen circuitry, its still not 100% developed yet!
Highly sensitive. As it can operate with almost any sort of pointing devices, can be more vulnerable with dust particles!
Poor visibility in sunlight, mostly due to multiple layers reflecting light!
Screen, being sensitive at the upper layer, can be more vulnerable to scratches!


do we really need sysfs?

I and my colleague were discussing sometime back about the kernel and how the data flow occurs from user to the hardware. How is the kernel driver api is called and in what sequence? Then He poped one question to me - why do we require the SYSFS when we already have DEVFS?

My first answer was - devfs is the one which actually talk to device driver and the using sysfs, we set or get the attributes for the device. But this answer was not convincing. He posted the question in stackoverflow.com and searched but it was not convincing. Even I wondered how two are different.

Searching the internet tells that the sysfs was originally developed to test the new device model which was being written for the kernel 2.5 version. That time the procfs was used primarily for the testing but since the procfs is basically fs for the information on process and other system related information. Due to this, procfs was cluttered with lots of non-process information. So the whole idea was to write a new file system which can aide to the development of new device model. Moreover, there was no mechanism for hotplug in linux kernel. So with the development of new sysfs (previously called ddfs which was based on in-memory fs, ramfs), these were achieved. 

Sysfs is a virtual filesystem which provides a userspace-visible representation of the device model. The sysfs filesystem is usually mounted on /sys. Sysfs is designed to export the information present in the device tree which would then no longer clutter up procfs. Sysfs is used by several utilities to access information about hardware and its driver  such as udev. Scripts have been written to access information and some scripts configure device drivers and devices via their attributes. For every kobject that is registered with the system, a directory is created for it in sysfs.

The device model and sysfs are sometimes confused with each other, but they are distinct entities. The device model functions just fine without sysfs (but the reverse is not true). Driver writers generally need not worry about sysfs; it is magically created and implemented by the driver model and bus driver code. The one exception comes about when it comes to exporting attributes via sysfs. These attributes represent some aspect of how the device and/or its driver operate; they may or may not be writeable from user space. Sysfs is now the preferred way (over /proc or ioctl()) to export these variables to user space. 




I think, this is a good point to start discussion on this topic. Hope, this clears some of the doubts. Still I have some doubts, which I am googling right now ;)


cya then...for now The Big Bang Theory (specially Penny) waiting for me...Bazingaaaa

Welcome Note

Friends,


I have seen my friends, my colleagues, my seniors and juniors almost everyone near me struggling one or other day with some problem in Linux. Though there are forum which do discuss about the problems but sometimes we are not able to find the proper solution or say more convincing solutions.
After discussing with my friends, we realized that there should be some discussion between us. This is not merely limited to the problem solving but also publishing the problems faced by us and the solutions to them. 

Initially, I am starting with Linux OS related discussions but everyone is welcomed to discuss even other interesting topics too. 


P.S. - Please take active part and share the knowledge.