Prep For TI - Embedded SW (With Sample Questions)

Download as pdf or txt
Download as pdf or txt
You are on page 1of 14

Preparation Tips – Embedded SW

TI Information – Selective Disclosure 1


What are we looking for?
We are looking for individuals, who are passionate about electronics, love to tackle challenging problems and build
solutions that have an impact and can improve human lives though technology.
1. Basics, basics, basics! Strong basics and fundamentals are what allow engineers to tackle new problems effectively
2. Perseverance – people who quickly give up on a problem without trying or just saying “I don’t know” without taking time
to think, are pretty much immediately ruled out.
3. Sharpness – being able to identify patterns, and making logical leaps that can circumvent multiple steps
4. Thoroughness – after making such a leap, being able to go back and justify the answer

TI Information – Selective Disclosure 2


Topics – for both written test and interview
• Basic C programming: Pointers, algorithms, • Operating systems
stacks/queues – NCG:
– NCG: • Scheduling algorithm
• Data structures: upto basics of graphs. BST, • Multi-process synchronization techniques.
Hash, LL, etc. with corresponding algos. • Virtual & physical memory.
– Interns: – Inters
• Data structures: upto LL etc. with • Multi-process synchronization techniques.
corresponding algos.
• Computer Arch.
• Embedded C – NCG
– NCG & intern • Caches.
• Struct size calculation. • DMA.
• Bit manipulation. • Organization.
• Memory layout of C program. • Pipeline.
• Static & volatile keyword.
• Compilation stages.

TI Information – Selective Disclosure 3


Topics – for both written test and interview
• Microcontroller
– NCG & Intern
• 8051 Assembly
• Interrupts and their processing
• DMA, timers, memories, ADC, DAC, GPIO & SPI.

TI Information – Selective Disclosure 4


References
• C Programming Language – by Brian W. Kernighan and Dennis M. Ritchie
• Embedded Systems: An Integrated Approach – by Layla b Das
• Operating Systems – by Andrew S Tanenbaum
• Computer Organization & Architecture – by William Stallings

TI Information – Selective Disclosure 5


Sample Problem 1.1
Implementation 1 int global_sum = 0;
For a deeply embedded processor such that it: compute_sum(range)
• do not has any cache {
• Has three memories such that in terms of speed they are: for value in range {
global_sum = global_sum + value
L1 RAM > L2 RAM > FLASH }
• On startup it zero-initialize its .bss section (a place where all }
un-initialize variables are placed) Implementation 2 int global_sum = 0;
identify which implementations would be the slowest and compute_sum(range)
{
fastest?
int local_sum = 0;
for value in range {
Program Section Name Target Memory local_sum = local_sum + value
}
.data L2 RAM global_sum = local_sum;
}
.bss L1 RAM Implementation 3 int global_sum = 0;
compute_sum(range)
.stack L1 RAM {
static int local_sum = 0;
.heap L2 RAM for value in range {
local_sum = local_sum + value
.code FLASH }
global_sum = local_sum;
.rodata FLASH }

TI Information – Selective Disclosure 6


Solution 1.1
Here, we have to remember the following

Program Section Name Contains


.data All initialized global sections and initialized local
static
.bss All uninitialized global sections and uninitialized
local static
.stack Call stack
.heap Dynamic allocation
.text Code
.rodata Read only data

Therefore, implementation 3 would be slowest, since, this implementation access variables stored in .data section a greater
number of times.
Implementation 2 is the fastest because, even without any compiler optimization, local_sum would be stored in .stack which
is present in L1RAM.

TI Information – Selective Disclosure 7


Sample Problem 1.2
Identify the error in the implementation:
int length;
void foo(int sg)
{
int reverse_sg;
while(sg>0)
{
length = length + 1;
reverse_sg = reverse_sg * 10 + (sg%10);
sg = sg / 10;
}
}

TI Information – Selective Disclosure 8


Solution 1.2
• Here the problem is with file reverse_sg = reverse_sg * 10 + (sg%10); because
reverse_sg is a local variable which could be stored in either stack or in CPU
register bank and in either case, it will have garbage value, however, length
variable will never be a problem because program on startup is zero-initializing
the bss section.

TI Information – Selective Disclosure 9


Sample Problem 2
Consider a high performance application which is running on CortexA72. It has
many different functions
1. it has a function that loops over every element of a linear data-structure
starting from a beginning to end. To reduce the run time of this function, which
linear data structure should it loop onto?
2. It has a function that does computation of a 2d matrix. Should that matrix be
computed in column-major fashion or row-major fashion in order to reduce run-
time? Why?
3. In a linked-list, how would you detect a loop?

TI Information – Selective Disclosure 10


Solution 2
1. Array because it has good special locality.
2. Row-major because it has good special locality.
3. Floyd's cycle-finding algorithm is used for this.

TI Information – Selective Disclosure 11


Sample Problem 3
An Industrial memory access controller access a memory bank which is 16K-
bytes in size and is organized as 16K × 8. During testing, it was found that
1. At normal temperature, it works as per its design i.e. it reads and writes 4
bytes at a time.
2. at elevated temperature of 105 deg C, it writes 4 bytes correctly but reads 4
bytes with Least-Significant-Byte as garbage.
Write functions in C that read 4 bytes of data at a time at elevated temperature.

TI Information – Selective Disclosure 12


Solution 3
• This is to test bit manipulation.
// function to read bytes at normal temperature.
uint32_t read4bytes(uint32_t address)
{
return MemoryController_HAL_get4bytes(address);
}

// function to read bytes at elevated temperature.


uint32_t read4bytes_ex(uint32_t address)
{
uint32_t hi = read4bytes(address);
uint32_t lo = read4bytes(address + 1);
uint32_t res = (hi & ((uint32_t)(~0xff))) | ((lo >> 8) & ((uint32_t)(0xff)));
return res;
}

TI Information – Selective Disclosure 13


Thank you!
All the best ☺

TI Information – Selective Disclosure 14

You might also like