OLD | NEW |
1 // Copyright (c) 1994-2006 Sun Microsystems Inc. | 1 // Copyright (c) 1994-2006 Sun Microsystems Inc. |
2 // All Rights Reserved. | 2 // All Rights Reserved. |
3 // | 3 // |
4 // Redistribution and use in source and binary forms, with or without | 4 // Redistribution and use in source and binary forms, with or without |
5 // modification, are permitted provided that the following conditions | 5 // modification, are permitted provided that the following conditions |
6 // are met: | 6 // are met: |
7 // | 7 // |
8 // - Redistributions of source code must retain the above copyright notice, | 8 // - Redistributions of source code must retain the above copyright notice, |
9 // this list of conditions and the following disclaimer. | 9 // this list of conditions and the following disclaimer. |
10 // | 10 // |
(...skipping 1837 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1848 // cond(31-28) | 110(27-25)| PUDW0(24-20) | Rbase(19-16) | | 1848 // cond(31-28) | 110(27-25)| PUDW0(24-20) | Rbase(19-16) | |
1849 // first(15-12) | 1011(11-8) | (count * 2) | 1849 // first(15-12) | 1011(11-8) | (count * 2) |
1850 ASSERT(CpuFeatures::IsEnabled(VFP3)); | 1850 ASSERT(CpuFeatures::IsEnabled(VFP3)); |
1851 ASSERT_LE(first.code(), last.code()); | 1851 ASSERT_LE(first.code(), last.code()); |
1852 ASSERT(am == ia || am == ia_w || am == db_w); | 1852 ASSERT(am == ia || am == ia_w || am == db_w); |
1853 ASSERT(!base.is(pc)); | 1853 ASSERT(!base.is(pc)); |
1854 | 1854 |
1855 int sd, d; | 1855 int sd, d; |
1856 first.split_code(&sd, &d); | 1856 first.split_code(&sd, &d); |
1857 int count = last.code() - first.code() + 1; | 1857 int count = last.code() - first.code() + 1; |
| 1858 ASSERT(count <= 16); |
1858 emit(cond | B27 | B26 | am | d*B22 | base.code()*B16 | sd*B12 | | 1859 emit(cond | B27 | B26 | am | d*B22 | base.code()*B16 | sd*B12 | |
1859 0xB*B8 | count*2); | 1860 0xB*B8 | count*2); |
1860 } | 1861 } |
1861 | 1862 |
1862 void Assembler::vldm(BlockAddrMode am, | 1863 void Assembler::vldm(BlockAddrMode am, |
1863 Register base, | 1864 Register base, |
1864 SwVfpRegister first, | 1865 SwVfpRegister first, |
1865 SwVfpRegister last, | 1866 SwVfpRegister last, |
1866 Condition cond) { | 1867 Condition cond) { |
1867 // Instruction details available in ARM DDI 0406A, A8-626. | 1868 // Instruction details available in ARM DDI 0406A, A8-626. |
1868 // cond(31-28) | 110(27-25)| PUDW1(24-20) | Rbase(19-16) | | 1869 // cond(31-28) | 110(27-25)| PUDW1(24-20) | Rbase(19-16) | |
1869 // first(15-12) | 1010(11-8) | (count/2) | 1870 // first(15-12) | 1010(11-8) | (count/2) |
1870 ASSERT(CpuFeatures::IsEnabled(VFP3)); | 1871 ASSERT(CpuFeatures::IsEnabled(VFP3)); |
1871 ASSERT_LE(first.code(), last.code()); | 1872 ASSERT_LE(first.code(), last.code()); |
1872 ASSERT(am == ia || am == ia_w || am == db_w); | 1873 ASSERT(am == ia || am == ia_w || am == db_w); |
1873 ASSERT(!base.is(pc)); | 1874 ASSERT(!base.is(pc)); |
1874 | 1875 |
1875 int sd, d; | 1876 int sd, d; |
1876 first.split_code(&sd, &d); | 1877 first.split_code(&sd, &d); |
1877 int count = last.code() - first.code() + 1; | 1878 int count = last.code() - first.code() + 1; |
| 1879 ASSERT(count <= 16); |
1878 emit(cond | B27 | B26 | am | d*B22 | B20 | base.code()*B16 | sd*B12 | | 1880 emit(cond | B27 | B26 | am | d*B22 | B20 | base.code()*B16 | sd*B12 | |
1879 0xA*B8 | count); | 1881 0xA*B8 | count); |
1880 } | 1882 } |
1881 | 1883 |
1882 | 1884 |
1883 void Assembler::vstm(BlockAddrMode am, | 1885 void Assembler::vstm(BlockAddrMode am, |
1884 Register base, | 1886 Register base, |
1885 SwVfpRegister first, | 1887 SwVfpRegister first, |
1886 SwVfpRegister last, | 1888 SwVfpRegister last, |
1887 Condition cond) { | 1889 Condition cond) { |
(...skipping 781 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2669 | 2671 |
2670 // Since a constant pool was just emitted, move the check offset forward by | 2672 // Since a constant pool was just emitted, move the check offset forward by |
2671 // the standard interval. | 2673 // the standard interval. |
2672 next_buffer_check_ = pc_offset() + kCheckPoolInterval; | 2674 next_buffer_check_ = pc_offset() + kCheckPoolInterval; |
2673 } | 2675 } |
2674 | 2676 |
2675 | 2677 |
2676 } } // namespace v8::internal | 2678 } } // namespace v8::internal |
2677 | 2679 |
2678 #endif // V8_TARGET_ARCH_ARM | 2680 #endif // V8_TARGET_ARCH_ARM |
OLD | NEW |