Sunday, 22 May 2011
RTOS Basics
http://www.slideshare.net/sundaresan/rtos-concepts
RTOS Concepts
What Does Real-Time Mean?
Main difference to other computation: time
time means that correctness of system depends
- not only on logical results
- but also on the time the results are produced
real => reaction to external events must occur during their evolution.
system time ( internal time ) has to be measured
with same time scale as controlled environment
( external time )
Foreground/Background.
Systems which do not use an RTOS
An application consist of an infinite loop which calls application modules to perform the desired operations.
The modules are executed sequentially (background) with interrupt service routines (ISRs) handling asynchronous events (foreground).
Batch process
A process which executes without user interaction.
Interactive process
A process which requires user interaction while executing
Kernel
Kernel : the smallest portion of the operating system that provides
task scheduling, dispatching, and intertask communication.
Kernel types
Nanokernel - the dispatcher
Microkernel - a nanokernel with task scheduling
Kernel - a microkernel with intertask synchronization
Executive - a kernel that includes privatized memory blocks, I/O services, and other complex issues. Most commercial real-time kernels are in this category.
Operating system - an executive that also provides generalized user interface, security, file management system, etc
What is RTOS?
A real-time operating system (RTOS) that supports real-time applications and embedded systems.
Real-time applications have the requirement to meet task deadlines in addition to the logical correctness of the results.
– Multiple events handled by a single processor
– Events may occur simultaneously
– Processor must handle multiple, often competing events
Desirable Features of Real-Time Systems
Timeliness
- OS has to provide kernel mechanisms for
- time management
- handling tasks with explicit time constraints
Deterministic
Design for peak load
Predictability
Fault tolerance
Maintainability
Multitasking
Must provide mechanisms for scheduling and switching for several user and kernel tasks
Maximize CPU utilization
Allow for managing of complex and real-time applications
Categories
Hard Real Time System:
failure to meet time constraints leads to system failure
Firm Real Time System:
low occurrence of missing a deadline can be tolerated
Soft Real Time System:
performance is degraded by failure to meet time constraints
An RTOS differs from common OS, in that the user when using the former has the ability to directly access the microprocessor and peripherals.
Such an ability of the RTOS helps to meet deadlines.
Real-Time Systems
RTOS is a multitasking system where multiple tasks run concurrently
– system shifts from task to task
– must remember key registers of each task
• called its context
RTOS responsible for all activities related to a task:
– scheduling and dispatching
– intertask communication
– memory system management
– input/output system management
– timing
– error management
– message management
Basic requirements of an RTOS.
(i) Multi-threading and preemptibility
(ii) Thread priority
(iii) Thread synchronization mechanisms
(iv) Priority inheritance
(v) Predefined latencies
Task switching latency: time to save the context of a currently executing task and switch to another task..
Interrupt latency: time elapsed between the execution of the last instruction of the interrupted task and the first instruction in the interrupt handler
Interrupt dispatch latency: This is the time to go from the last instruction in the interrupt handler to the next task scheduled to run.
Basic requirements of an RTOS.
priority inversion
occurs when a higher priority task must wait on a low priority task to release a resource
Priority Ceiling
Each resource has an assigned priority
Priority of thread is the highest of all priorities of the resources it’s holding
Priority Inheritance
The thread holding a resource inherits the priority of the thread blocked on that resource
Preemptive scheduling .
In a preemptive kernel, when an event makes a higher priority task ready to run, the current task is immediately suspended and the higher priority task is given control of the CPU.
Reentrancy .
reentrant function : can be used by more than one task without fear of data corruption.
non-reentrant function : cannot be shared by more than one task unless mutual exclusion to the function is ensured by either using a semaphore, by disabling interrupts during critical sections of code.
A reentrant function can be interrupted at any time and resumed at a later time without loss of data.
Reentrant functions either use local variables (CPU registers or variables on the stack) or protect their data when global variables are used.
Compilers specifically designed for embedded software will generally provide reentrant run-time libraries.
Dynamic Memory Allocation
RTOS uses abstract data types such as record, linked list, and queue
These data types normally use RAM dynamic memory allocation techniques
Data structures are created (allocated) on the fly during program execution and destroyed when no longer needed
– Requires large RAM memory
Heap is portion of memory used for dynamic memory allocation
Must allocate separate RAM spaces for the Heap as well as the Stack
Stack : Last-in-first-out (LIFO) data structure
RTOS requires multiple stacks - one for each task
Memory Management
Two issues
Heap management
Stack management
Heap management
Classic heap
Priority heap
Fixed block heap
Memory Management
Classic heap
The memory is collected into one giant heap and partitioned according to the demand from tasks .
There are several “fit” memory allocation algorithms, e.g., best-fit, first-fit, that also attempt to minimize the memory fragmentation.
Has a big management overhead so is not used in real-time systems
Priority heap
partitions the memory along priority boundaries, e.g., a high and a low priority partitions are created
Fixed block heap
partitions the memory into several pools of fixed block length and upon a request, allocates a single block of memory from the pool with size equal or larger than the requested amount
Stack management:
When multiple tasks share a single processor, their contexts
(volatile information such as the contents of hardware registers, memory-management registers, and the program counter)
need to be saved and restored so as to switch them.
This can be done using
task-control block model OR one or more run-time stacks
Run-time stacks - used to keep context
may use only one run-time stack for all the tasks or one run-time stack in conjunction with several application stacks (or private stacks), one for each task in memory
Multiple stack case allows tasks to interrupt themselves ,
Stack size must be known a priori.
Operating system manages the stacks
Task and Task Control Blocks
In RTOS program consists of independent,asynchronous, and interacting tasks
– Must have capability to store task context
Context is kept in the control block of the task.
Having multiple tasks means multiple control blocks, which are maintained in a list
• RTOS updates TCB when task is switched
best for full-featured real-time operating systems
Device Control Block (DCB)
– tracks status of system associated devices
Priorities
Priority
An ordinal number which represents the relative importance of a task.
Static priority
A priority which is not automatically adjusted by the system.
Static priority can typically be changed by user.
Dynamic priority
A priority which is adjusted automatically by the system according to task behavior and system loading.
Dynamic priority imposes an overhead on the system.
Dynamic priority can improve response times and eliminate indefinite postponing
Scheduling algorithms of RTOS
The most commonly used static scheduling algorithm is the Rate Monotonic (RM) scheduling algorithm
The RM algorithm assigns different priorities proportional to the frequency of tasks.
The task with the shortest period gets the highest priority, and the task with the longest period gets the lowest static priority.
Rate monotonic algorithm is a dynamic preemptive algorithm based on static priorities
RM algorithm provides no support for dynamically changing task periods and/or priorities and tasks that may experience priority inversion.
Rate Monotonic
Priority inversion occurs in an RM system where in order to enforce rate monotonicity, a non-critical task with a high frequency of execution is assigned a higher priority than a critical task with lower frequency of execution
A priority ceiling protocol (PCP) can be used to counter priority inversion, wherein a task blocking a higher priority task inherits the higher priority for the duration of the blocked task.
The priority ceiling protocol is used to schedule a set dependant periodic tasks that share resources protected by semaphores
Earliest deadline first
Earliest deadline first (EDF) scheduling can be used for both static and dynamic real-time scheduling.
a dynamic priority algorithm which uses the deadline of a task as its priority.
The task with the earliest deadline has the highest priority
Minimum Laxity First
A variant of EDF is Minimum Laxity First (MLF) scheduling where a laxity is assigned to each task in the system and minimum laxity tasks are executed first.
Laxity : The difference between the time until a tasks completion deadline and its remaining processing time requirement.
{ the deadline by which _ { the amount of the task must be completed } computation
remaining to be performed }
MLF considers the execution time of a task, which EDF does not
Minimum Laxity First
MLF assigns higher priority to a task with the least laxity
A task with zero laxity must be scheduled right away and executed without preemption or it will fail to meet its deadline.
The negative laxity indicates that the task will miss the deadline, no matter when it is picked up for execution.
A major problem with LLF algorithm is that it is
impractical to implement because laxity ties ( two or more tasks have the same laxities ) result in the frequent context switches among the corresponding tasks.
This will cause the system performance to remarkably degrade.
Modified Least Laxity First
MLLF schedules the task sets the same as LLF algorithm.
If the laxity tie occurs, the running task continues to run with no preemption as far as the deadlines of other tasks are not missed.
The MLLF algorithm defers the context switching until necessary and it is safe even if the laxity tie occurs.
That is, it allows the laxity inversion where a task with the least laxity may not be scheduled immediately.
Laxity inversion applies to the duration that the currently running task can continue running with no loss in schedulability
Maximum Urgency First Algorithm
solves the problem of unpredictability during a transient overload for EDF, LLF and MLLF algorithms.
This algorithm is a combination of fixed and dynamic priority scheduling, also called mixed priority scheduling.
With this algorithm, each task is given an urgency which is defined as a combination of two fixed priorities ( criticality and user priority ) and a dynamic priority that is inversely proportional to the laxity.
The MUF algorithm assigns priorities in two phases
Phase One concerns the assignment of static priorities to tasks
Phase Two deals with the run-time behavior of the MUF scheduler
Maximum Urgency First Algorithm
The first phase consists of these steps :
1) It sorts the tasks from the shortest period to the longest period. Then it defines the critical set as the first N tasks such that the total CPU load factor does not exceed 100%. These tasks are guaranteed not to fail even during a transient overload.
2) All tasks in the critical set are assigned high criticality.The remaining tasks are considered to have low criticality.
3) Every task in the system is assigned an optional unique user priority
{ CHIMERA II, a real-time operating system being used to control sensor-based control systems }
Maximum Urgency First Algorithm
In the second phase , the MUF scheduler follows an algorithm to select a task for execution.
This algorithm is executed whenever a new task is arrived to the ready queue.
The algorithm is as follows:
1) If there is only one highly critical task, pick it up and execute it.
2) If there are more than one highly critical task, select the one with the highest dynamic priority. Here, the task with the least laxity is considered to be the one with the highest priority.
3) If there is more than one task with the same laxity, select the one with the highest user priority.
In addition to basic scheduling and context switching , a real-time kernel typically provides other valuable services to applications such as:
Time Delay
System Time
Inter-Process Communication (IPC)
Synchronization —semaphores or flags
Resource Protection - mutex
RTOS for small footprint, mobile and connected devices
Windows CE
(32 bit devices , minimum footprint of 400KB , 256 priority levels )
RTOS for complex, hard real-time applications
LynxOS
(microkernel is 28 KB, 512 thread priority levels, supports memory protection )
General purpose RTOS in the embedded industry
VxWorks
(256 priority levels, multitasking, deterministic context switching,
preemptive and round robin scheduling, binary and counting semaphores, mutual exclusion with inheritance, supports virtual memory configuration )
RTOS for the Java Platform
Jbed RTOS package
( runs on 32 -bit microprocessors and controllers. Current versions support ARM7, 68k, PowerPC architectures, supports up to 10-thread priority levels, EDF )
Objected-oriented RTOS
pSOSystem
Why Should I Use an RTOS?
True that many or most applications can be written without the support of an RTOS.
A few reasons to consider using an RTOS :
The job of writing application software is generally easier using an RTOS, because the use of a kernel enforces certain disciplines in how your code is structured.
While the illusion of concurrency can be created without the use of an RTOS (though not always), it almost always results in a much more complex piece of software.
Disadvantages of Real-Time Kernels
Extra cost of the kernel at Software
More ROM/RAM
In addition to basic scheduling and context switching, a real-time kernel typically provides other valuable services to applications such as:
Time Delays
System Time
Inter-Process Communication (IPC)
Synchronization
Sundaresan SundarSundaresan Sundar + Follow
24722 views, 6 favs, 4 embeds more
Related
Implementing Lightweight Networking Implementing Lightweight Networking 3131 views
Implementing Lightweight Networking Implementing Lightweight Networking 934 views
TCIL TCIL 236 views
RTOS RTOS 1226 views
070413 임베디드 시스템 070413 임베디드 시스템 379 views
Real Time Operating Systems Real Time Operating Systems 1613 views
Os Concepts Os Concepts 1185 views
Real Time Operating System Concepts Real Time Operating System Concepts 4896 views
Rtos By Avanish Agarwal Rtos By Avanish Agarwal 1595 views
ucOS ucOS 2007 views
Real Time Systems Real Time Systems 1157 views
real-time virtualization experts real-time virtualization experts 139 views
Lecture 09 Lecture 09 366 views
Misconceptions About Real Time Misconceptions About Real Time 312 views
Introduction to Operating systems & RTOS Introduction to Operating systems & RTOS 2719 views
INtime INtime 104 views
About this presentation
Usage Rights
© All Rights Reserved
Stats
6 Favorites
7 Comments
1,434 Downloads
24,452 Views on
SlideShare
270 Views on
Embeds
24,722 Total Views
Embed views
203 views on http://www.slideshare.net
60 views on http://dev.emcelettronica.com
5 views on http://crazyindiandreams.blogspot.com
2 views on http://translate.googleusercontent.com
Accessibility
View text version
Additional Details
Uploaded via SlideShare
Uploaded as Microsoft PowerPoint
Flag as inappropriate
File a copyright complaint
Categories
Technology
Top 25 Tags
s
v
rtos
concepts
Follow SlideShare
SlideShare Blog
8 tweets
8 shares
0 shares
WordPress
More
Saturday, 12 December 2009
Thursday, 12 November 2009
Long Term Evolution(LTE) is first advancement towards stronger, faster and more efficient 4G data networks. The technology provide downlink peak rates of 100Mbps and uplink speeds of 50Mbit/s.
The LTE technology is a scaleable bandwidth technology for carriers operating anywhere from 20Mhz town to 1.4Mhz.
Long Term Evolution offers some excellent advantages over current 3G systems including higher throughput, plug and play compatibility, FDD (Frequency Division Duplexing) and TDD (Time Division Duplexing), low latency and lower operating expenditures. It also offers legacy modes to support devices operating on GPRS systems, while supporting seamless passthrough of technologies operating on other older cellular towers.
LTE is designed with a full Internet Protocol (IP) network infrastructure. This means it can support full voice in packet domains, while also offering advanced radio techniques for achieving higher performance levels beyond 3G data packets can currently achieve.
LTE Requirements
- Reduced cost per bit
- Increased service provisioning – more services at lower cost with better user experience
- Flexibility of use of existing and new frequency bands
- Simplified architecture, Open interfaces
- Allow for reasonable terminal power consumption and
- Provide the subscriber with a "ready-to-use" IP connectivity and an "always-on" experience.
Technologies
- OFDM (Orthogonal Frequency Division Mulplex)
- MIMO (Multiple Input Multiple Output)
- SAE (System Architecture Evolution)
- OFDM (Orthogonal Frequency Division Multiplex): OFDM technology has been incorporated into LTE because it enables high data bandwidths to be transmitted efficiently while still providing a high degree of resilience to reflections and interference. The access schemes differ between the uplink and downlink: OFDMA (Orthogonal Frequency Division Multiple Access is used in the downlink; while SC-FDMA(Single Carrier - Frequency Division Multiple Access) is used in the uplink. SC-FDMA is used in view of the fact that its peak to average power ratio is small and the more constant power enables high RF power amplifier efficiency in the mobile handsets - an important factor for battery power equipment.
- MIMO (Multiple Input Multiple Output): One of the main problems that previous telecommunications systems has encountered is that of multiple signals arising from the many reflections that are encountered. By using MIMO, these additional signal paths can be used to advantage and are able to be used to increase the throughput.
When using MIMO, it is necessary to use multiple antennas to enable the different paths to be distinguished. Accordingly schemes using 2 x 2, 4 x 2, or 4 x 4 antenna matrices can be used. While it is relatively easy to add further antennas to a base station, the same is not true of mobile handsets, where the dimensions of the user equipment limit the number of antennas which should be place at least a half wavelength apart. - SAE (System Architecture Evolution): With the very high data rate and low latency requirements for 3G LTE, it is necessary to evolve the system architecture to enable the improved performance to be achieved. One change is that a number of the functions previously handled by the core network have been transferred out to the periphery. Essentially this provides a much "flatter" form of network architecture. In this way latency times can be reduced and data can be routed more directly to its destination.
LTE Network Architecture
Source: From 3pp Specifications
Describe about Interface and Node Functionality at high level
- eNodeB: The eNodeB(eNB) is reposbile for Radio Resource managment, IP header compression, encrtyption of user data stream. Scheduling and tranmission of paging mesages. It will do measurement and measurement reporting configuration for mobility and scheduling.
- MME (Mobility Management Entity): The MME node responsible for idle mode UE (User Equipment) tracking and paging procedure including retransmissions.It is involved in the bearer activation/deactivation process and is also responsible for choosing the SGW for a UE at the initial attach and at time of intra-LTE handover involving Core Network (CN) node relocation. It is responsible for authenticating the user (by interacting with the HSS). The Non-Access Stratum (NAS) signaling terminates at the MME and it is also responsible for generation and allocation of temporary identities to UEs. It checks the authorization of the UE to camp on the service provider’s Public Land Mobile Network (PLMN) and enforces UE roaming restrictions. The MME is the termination point in the network for ciphering/integrity protection for NAS signaling and handles the security key management. Lawful interception of signaling is also supported by the MME. The MME also provides the control plane function for mobility between LTE and 2G/3G access networks with the S3 interface terminating at the MME from the SGSN. The MME also terminates the S6a interface towards the home HSS for roaming UEs.
- SGW (Serving Gateway): The SGW routes and forwards user data packets, while also acting as the mobility anchor for the user plane during inter-eNodeB handovers and as the anchor for mobility between LTE and other 3GPP technologies (terminating S4 interface and relaying the traffic between 2G/3G systems and PGW). For idle state UEs, the SGW terminates the DL data path and triggers paging when DL data arrives for the UE. It manages and stores UE contexts, e.g. parameters of the IP bearer service, network internal routing information. It also performs replication of the user traffic in case of lawful interception.
- PGW (PDN Gateway): The PDN Gateway provides connectivity from the UE to external packet data networks by being the point of exit and entry of traffic for the UE. A UE may have simultaneous connectivity with more than one PGW for accessing multiple PDNs. The PGW performs policy enforcement, packet filtering for each user, charging support, lawful Interception and packet screening. Another key role of the PGW is to act as the anchor for mobility between 3GPP and non-3GPP technologies such as WiMAX and 3GPP2 (CDMA 1X and EvDO).
Downlink
LTE uses OFDM for the downlink – that is, from the base station to the terminal. OFDM meets the LTE requirement for spectrum flexibility and enables cost-efficient solutions for very wide carriers with high peak rates. It is a well-established technology, for example in standards such as IEEE 802.11a/g, 802.16, HIPERLAN-2, DVB and DAB.
In the time domain there is a radio frame that is 10 ms long and consists of 10 sub frames of 1 ms each. Every sub frame consists of 2 slots where each slot is 0.5 ms. The subcarrier spacing in the frequency domain is 15 kHz. Twelve of these subcarriers together (per slot) is called a resource block so one resource block is 180 kHz. 6 Resource blocks fit in a carrier of 1.4 MHz and 100 resource blocks fit in a carrier of 20 MHz.
In the downlink there are three different physical channels. The Physical Downlink Shared Channel (PDSCH) is used for all the data transmission, the Physical Multicast Channel (PMCH) is used for broadcast transmission using a Single Frequency Network, and the Physical Broadcast Channel (PBCH) is used to send most important system information within the cell. Supported modulation formats on the PDSCH are QPSK, 16QAM and 64QAM.
For MIMO operation, a distinction is made between single user MIMO, for enhancing one user's data throughput, and multi user MIMO for enhancing the cell throughput.
Uplink
In the uplink, LTE uses a pre-coded version of OFDM called SC-FDMA. This is to compensate for a drawback with normal OFDM, which has a very high peak to average power ration(PAPR). High PAPR requires expensive and inefficient power amplifiers with high requirements on linearity, which increases the cost of the terminal and drains the battery faster. SC-FDMA solves this problem by grouping together the resource blocks in a way that reduces the need for linearity, and so power consumption, in the power amplifier. A low PAPR also improves coverage and the cell-edge performance.
In the uplink there are two physical channels. While the Physical Random Access Channel (PRACH) is only used for initial access and when the UE is not uplink synchronized, all the data is being sent on the Physical Uplink Shared Channel (PUSCH). Supported modulation formats on the uplink data channel are QPSK, 16QAM and 64QAM.
If virtual MIMO / Spatial division multiple access (SDMA) is introduced the data rate in the uplink direction can be increased depending on the number of antennas at the base station. With this technology more than one mobile can reuse the same resources.
LTE Protocols:
The objective of EPS to provide the subscriber with a "ready-to-use" IP connectivity and an "always-on" experience.
User plane protocols:
These are the protocols implementing the actual E-RAB service, i.e. carrying user data through the access stratum.
Control plane protocols:
These are the protocols for controlling the E-RABs and the connection between the UE and the network from different aspects (including requesting the service, controlling different transmission resources, handover etc.). Also a mechanism for transparent transfer of NAS messages is included.
Brief details about interfaces:
• X2: The X2 interface connects neighboring eNodeBs to each other and is used for forwarding contexts and user data packets at inter-eNodeB handover.
• S1-MME: Reference point for the control plane protocol between E-UTRAN and MME
• S1-U: Serves as a reference point between E-UTRAN and Serving GW for the per bearer user plane tunneling and inter eNodeB path switching during handover
• S3: Enables user and bearer information exchange for inter 3GPP access network mobility in idle and/or active state. It is based on Gn reference point as defined between SGSNs.
• S4: Provides related control and mobility support between GPRS Core and the 3GPP Anchor function of Serving GW and is based on Gn reference point as defined between SGSN and GGSN. In addition, if Direct Tunnel is not established, it provides the user plane tunneling.
• S5: Provides user plane tunneling and tunnel management between Serving GW and PDN GW. It is used for Serving GW relocation due to UE mobility and if the Serving GW needs to connect to a non-collocated PDN GW for the required PDN connectivity.
• S6a: Enables transfer of subscription and authentication data for authenticating/authorizing user access to the evolved system (AAA interface) between MME and HSS
• S6d: Enables transfer of subscription and authentication data for authenticating/authorizing user access to the evolved system (AAA interface) between S4-SGSN and HSS
• Gx: Provides transfer of (QoS) policy and charging rules from PCRF to Policy and Charging Enforcement Function (PCEF) in the PDN GW
• S8: Inter-PLMN reference point providing user and control plane between the Serving GW in the VPLMN and the PDN GW in the HPLMN. It is based on Gp reference point as defined between SGSN and GGSN. S8 is the inter PLMN variant of S5.
• S9: Provides transfer of (QoS) policy and charging control information between the Home PCRF and the Visited PCRF in order to support local breakout function.
Brief functionality about each protocol:
S1AP:
S1AP protocol has the following functions
a)E-RAB management function
b) Initial Context Transfer function
c) UE Capability Info Indication
d) Mobiliry Functions
e) Paging
f) S1 Interface managment
g) S1 UE Context Release function
h) UE Context modification
i) Status Transfer
j)Location Reporting
k) NAS Signaling transport
X2 AP:
a) Mobility Management: This function allows the eNB to move the responsibility of a certain UE to
another eNB. Forwarding of user plane data, Status Transfer and UE Context Release function are parts of the mobility management.
b) Load Management: This function is used by eNBs to indicate resource status, overload and traffic load to each other.
c) Managing the X2 interface.
d) eNB Configuration Update. This function allows updating of application level data needed for two
eNBs to interoperate correctly over the X2 interface.
NAS(eMM/eSm):
Main functions of the protocols that are part of the NAS are:
- the support of mobility of the user equipment (UE)
- the support of session management procedures to establish and maintain IP connectivity
between the UE and a packet data network gateway (PDN GW).
- NAS security is an additional function of the NAS providing services to the NAS protocols,
e.g. integrity protection and ciphering of NAS signalling messages.
RRC:
a)Broadcast of system information
Including NAS common information.
Information applicable for UEs(cell selection parameters, neighbouring cell information and
information and common channel configuration information)
b)RRC connection control
Paging
Establishment/ modification/ release of RRC connection(SRB1 and SRB2)
Initial security activation
Establishment/ modification/ release of RBs carrying user data (DRBs)
Recovery from radio link failure
c)Measurement configuration and reporting
Establishment/ modification/ release of measurements
Setup and release of measurement gaps
Measurement reporting
PDCP:
The Packet Data Convergence Protocol do the following functions
a) header compression and decompression of IP data flows using the ROHC protocol;
b) transfer of data (user plane or control plane);
c)in-sequence delivery of upper layer PDUs at re-establishment of lower layers;
d)ciphering and deciphering of user plane data and control plane data;
e)integrity protection and integrity verification of control plane data;
f)timer based discard;
RLC:
a)Transfer of upper layer PDUs;
b) error correction through ARQ (only for AM data transfer);
c) concatenation, segmentation and reassembly of RLC SDUs (only for UM and AM data transfer);
d) re-segmentation of RLC data PDUs (only for AM data transfer);
e) reordering of RLC data PDUs (only for UM and AM data transfer);
f) duplicate detection (only for UM and AM data transfer);
g)RLC SDU discard (only for UM and AM data transfer);
h)protocol error detection (only for AM data transfer).
MAC:
a) mapping between logical channels and transport channels;
b) multiplexing of MAC SDUs from one or different logical channels onto transport blocks (TB) to be
delivered to the physical layer on transport channels;
c) demultiplexing of MAC SDUs from one or different logical channels from transport blocks (TB)
delivered from the physical layer on transport channels;
d) scheduling information reporting;
e) error correction through HARQ;
f) priority handling between UEs by means of dynamic scheduling;
g)priority handling between logical channels of one UE;
h) Logical Channel prioritisation;
i) transport format selection
PHY:
Physical channels and modulation
- Definition of the uplink and downlink physical channels;
- The structure of the physical channels, frame format, physical resource elements, etc.;
- Modulation mapping (BPSK, QPSK, etc);
- Physical shared channel in uplink and downlink;
- Reference signal in uplink and downlink;
- Random access channel;
- Primary and secondary synchronization signals;
- OFDM signal generation in downlink;
- SC-FDMA signal generation in uplink;
- Scrambling, modulation and up conversion;
- Uplink-downlink timing relation
- Layer mapping and precoding in downlink.
Multiplexing and channel coding
- Channel coding schemes;
- Coding of Layer 1 / Layer 2 control information;
- Interleaving;
- Rate matching;
Physical layer procedures
- Synchronisation procedures, including cell search procedure and timing synchronisation;
- Power control procedure;
- Random access procedure;
- CQI reporting and MIMO feedback;
- UE sounding and HARQ ACK/NACK detection;
Physical layer – Measurements
- Measurements to be performed by Layer 1 in UE and E-UTRAN;
- Reporting of measurement results to higher layers and the network;
- Handover measurements, idle-mode measurements, etc.
LTE Bearers:
Source: 3gpp Specifications
LTE Signaling procedures:
Note: Most of the information have been driven from 3gpp specifications. If any one feels/detects/finds any copy right violation please bring to me notice, So I will keep update with required information if required.