next points to the process to be switched.
Let's talk about the code I transplanted. Since the code is a assembler, first introduce the CPU structure. The cpu I use uses 16-bit commands, 32-bit addresses and data. There are 16 General registers recorded as R0-R15. R0 as the stack pointer register sp, R1 usage is not fixed, r2-r6 as the parameter transfer register, function call if there are no more than five parameters, the parameters are placed in R2-R6 from left to right. At the same time, R2
the address pointer of the operand. Examples of indirect addressing commands in registers are as follows:LDR R1, [R2]; reads the data of the storage unit pointed to by R2. stores the data in R1.SWP R1, R1, [R2]; exchange the value of register R1 with the content of the storage unit pointed to by r2
5. Multi-register addressingMultiple register addressing can transmit several register values at a time, allowing one instruction to transmit any subset or all registers of 16 registers. Examples of
immediate number (24 bits low ).
The following code can be found in entry-common.S.
In section 2.6.21, you will find that you cannot avoid this concept. What is Eabi?
In the kernel, the interview with Eabi and oabi is actually relative to the method of system calling. Of course, the system we call is limited to the arm system.Eabi (Extended Abi) is a new method of calling the system.
MoV R7, # numSWI 0x0
The original system call method is as follows
right is after the call. When B returns, it should return to the Left State (A is before B is called, just like calling B ).
In a stack frame, apart from the previously mentioned parameter area, link area, and local storage area) besides, the stack frame pointer storage area (saved frame pointer) and the register storage area (saved registers area) have been introduced above (R7); the register storage area: save non-loss-prone registers (R4, R5, R6,
digit.Then the code should write the A8 and A3 0x767ea and 0x767eb. We step forward.Bne r7.r0.0x000b3028, meaning R7 not 0 jumps to 0x000b3028. Here is 0x10, so jump to 0x000b3028 to execute.Skips irrelevant instructions and continues execution until it is specified to Addu r2.r9.r2. R2 is 6. " 169 "of the second number.At this time R7 is 1, still jumps back to
Recently, the reverse of the Android/C + +, found that C + + classes, STL templates, in reverse when compared to the C language has brought no small difficulties.Today I wrote a small program, and then reversed the analysisVectorDefine a vector, and then add the data.Ida disassembly is as follows: (comments added).Text:00001164int_tmp = -0x18.Text:00001164vector_ptr = -0x14.Text:00001164Var_8 =-8.Text:00001164.Text:00001164 PUSH{R4-R7,
!Init_thread_union long + thread_start_sp @ SP29The previous code may be in nor flash to run in XIP mode (in fact, NAND flash can also XIP, but a bit technical barriers), but kernel code can not always run in Flash, the function will be kernel section of the Move and processing!Type __mmap_switched,%function__mmap_switched:R3 ADR, __switch_data + 4//R3 point to __mmap_switched comment Error! R3 point to __data_loc!Loading code snippets, initialization data segments, and uninitialized data segmen
, #0x17 @ angel_swireason_entersvc ARM (Swi 0x123456) @ angel_swi_arm THUMB (svc 0xab) @ angel_swi_thumbNot_angel:Mrs R2, CPSR @ turn off interrupts to Orr R2, R2, #0xc0 @ Prevent Angel from running MSR cpsr_c, R2#else teqp pc, #0x0c000003 @ tur N Off Interrupts#endifIf the kernel runs from Angel into a mode of USR mode, it will need to enter the SVC mode and disable all Fiq and IRQ interrupts. These are only performed when the user mode is entered. Normally, the code that closes the interrupt i
Set display, single display hybrid dual graphics technology has a long history, and experienced a number of generations, and the only has a set of obvious, unique AMD in this respect has a unique advantage. Now, the new release of the Catalyst 14.1 Beta added to the Kaveri Apu Dual graphics support, together to see how the match, the effect of how.
The Catalyst Control Center can be checked to turn on dual graphics.
Kaveri APU Dual Graphics combination
The table looks
In Linux, you cannot use userdel to delete users and groups. the solution is described as follows: when reading a book today, you can see an instance, which is followed by an itch... However, a problem occurs .. Users and Groups for testing cannot be deleted .. Situation: We usually remove the user from the group first ,... in Linux, you cannot use userdel to delete users and groups. the solution is described as follows: when reading a book today, you can see an instance, which is followed by an
immediate number is greater than 0xff, immediately the number of loops left to shift even digits, to get a number between 0x0--0xffMeeting the above two conditions is legal:Examples of illegal numbers: 0x101 0xffffffIllegal numbers can be manipulated by this example: LDR r1,=0xfffff, register addressingMOV R1,R2, register Indirect addressingLDR R1,[R2]; R2 the data read out of the storage unit pointed to is saved in R1STR R1,[R2]; Read the data in the R1 and save it in the storage unit that the
I have read the article about the transplantation of UC on the C51 by Mr. Yang from julong. However, with the understanding of UC, it is found that the task function in the porting program of instructor Yang cannot pass parameters, so he tried to change it.
The running process of UC is as follows: 1. osinit () function initializes idle tasks. If there may be statistical tasks, of course, there are PCB and event idle lists (I think anyone who knows UC knows how to get started ); 2. ostaskcreate
Recently, I am very interested in iOS reverse engineering. Currently, iOS reverse engineering books include Hacking and Securing IOS Applications and iOS Hacker's Handbook. The Chinese books include iOS reverse engineering: analysis and practice: the programmer Nian Qian's iOS security attack and defense series english blog includes: Prateek Gianchandani's iOS Security Series blog which involves ARM assembly, but it is only widely used, the ARM assembly on iOS is not described in detail. Therefo
cannot be predicted. Therefore, in scenarios with high real-time requirements, compilation and C joint applications are also required. But is there a latency program that needs to be implemented through assembly? To find this answer, I did an experiment.When using C language to implement latency programs, the first thing that comes to mind is the commonly used loop statements in C. The following code is frequently seen on the Internet:Void delay2 (unsigned char I){For (; I! = 0; I --);}How high
registers cannot be accessed concurrently, and the processor state and operating mode determine which registers are available to the programmer.
L Non-grouped universal register R0-R7
R0--R7 in 16 data registers are non-grouped universal registers that are used to hold data and addresses .
L Packet General register R8-R15, processor mode determines physical register
--r8-r12 Register: Fast Interrupt and o
= tag_next (tag_array );
......
Tag_array-> hdr. tag = ATAG_NONE;
Tag_array-> hdr. size = 0;
Tag_array = tag_next (tag_array );
Finally, copy the linked list of kernel parameters to the default physical address 0x20000100 of the kernel. In this way, the parameter linked list is created.
4. kernel receiving Parameters
The following describes how the Linux kernel receives the kernel parameters passed by BootLoader from the zImage Image Based on the ARM architecture. Shows the zImage startup pro
Most people who have studied single-chip microcomputer know the names of "Water lamp" or "horse lamp". The specific implementation effect is to display a group of changes cyclically according to a fixed rule. For example, if you use a byte length space to realize the "marquee", you can change the value of this Byte as follows:
"0000 0001b"-> "0000 0010b"-> "0000 0100b"-> "0000 1000b"-> "0001 10000b"-> "0010 10000b"-> "0100 10000b" -> "1000 10000b"-> "0000 0001b" (loop)
For example, to change th
vectortable, they are placed in the ROM at the beginning, which requires them to be moved to the specified position when the system starts up, the following code is intended for this purpose.; Setup the vector area.;; (R8) = PTR to exception Vectors
Add R7, PC, # vectorinstructions-(. + 8)Ldmia R7 !, {R0-r3}; load 4 instructionsStmia R8 !, {R0-r3}; store the 4 vector instructionsLdmia
Key words: JNI, win7, Android SDK, Android ndk, cygwin, Eclipse, JDK
1.download and install the latest cygwinsetup.exeNote that you need to select devel @ install, which is required to simulate the Linux environment ,,,,SelectHttp://mirrors.163.comFast download speedAfter installation, open make-V and GCC-V to test whether the installation is successful.
2.download and install jdk-7u2-windows-i586.exeProblems that may occur later: When javah.exeis used in the pathsystem runtime to generat
Eclipse+cdt+gdb Debugging Android NDK ProgramFirst introduce the development environment, in this environment, the UP master guarantee is no problem.
Ubuntu 11.10
Eclipse 3.7 (Indego) for Java
JDK 6
Android SDK 2.2
Andrid NDK R7
Of course, in the Windows environment through the Cygwin and other tools can also be implemented GDB debugging, I have indeed implemented. But the performance is too low, the card can not be used
The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion;
products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the
content of the page makes you feel confusing, please write us an email, we will handle the problem
within 5 days after receiving your email.
If you find any instances of plagiarism from the community, please send an email to:
info-contact@alibabacloud.com
and provide relevant evidence. A staff member will contact you within 5 working days.