2013-04-24 Sandra Loosemore <sandra@codesourcery.com>
[deliverable/binutils-gdb.git] / gas / ChangeLog
1 2013-04-24 Sandra Loosemore <sandra@codesourcery.com>
2
3 * config/tc-nios2.c (nios2_control_register_arg_p): Rename
4 "fstatus" control register to "eccinj".
5
6 2013-04-19 Kai Tietz <ktietz@redhat.com>
7
8 * configure.tgt (i386-*-cygwin): Handle x86_64 cygwin.
9
10 2013-04-15 Julian Brown <julian@codesourcery.com>
11
12 * expr.c (add_to_result, subtract_from_result): Make global.
13 * expr.h (add_to_result, subtract_from_result): Add prototypes.
14 * config/tc-sh.c (sh_optimize_expr): Use add_to_result,
15 subtract_from_result to handle extra bit of precision for .sleb128
16 directive operands.
17
18 2013-04-10 Julian Brown <julian@codesourcery.com>
19
20 * read.c (convert_to_bignum): Add sign parameter. Use it
21 instead of X_unsigned to determine sign of resulting bignum.
22 (emit_expr): Pass extra argument to convert_to_bignum.
23 (emit_leb128_expr): Use X_extrabit instead of X_unsigned. Pass
24 X_extrabit to convert_to_bignum.
25 (parse_bitfield_cons): Set X_extrabit.
26 * expr.c (make_expr_symbol, expr_build_uconstant, operand):
27 Initialise X_extrabit field as appropriate.
28 (add_to_result): New.
29 (subtract_from_result): New.
30 (expr): Use above.
31 * expr.h (expressionS): Add X_extrabit field.
32
33 2013-04-10 Jan Beulich <jbeulich@suse.com>
34
35 * gas/config/tc-arm.c (encode_arm_addr_mode_3): Only reject base
36 register being PC when is_t or writeback, and use distinct
37 diagnostic for the latter case.
38
39 2013-04-10 Jan Beulich <jbeulich@suse.com>
40
41 * gas/config/tc-arm.c (parse_operands): Re-write
42 po_barrier_or_imm().
43 (do_barrier): Remove bogus constraint().
44 (do_t_barrier): Remove.
45
46 2013-04-09 Joerg Wunsch <joerg.wunsch@atmel.com>
47
48 * gas/config/tc-avr.c (mcu_types): Add ATmega64RFR2,
49 ATmega644RFR2, ATmega128RFR2, ATmega1284RFR2, ATmega256RFR2,
50 ATmega2564RFR2
51 * gas/doc/c-avr.texi (-mmcu documentation): Likewise.
52
53 2013-04-09 Jan Beulich <jbeulich@suse.com>
54
55 * gas/config/tc-arm.c (do_vmrs): Accept all control registers.
56 Use local variable Rt in more places.
57 (do_vmsr): Accept all control registers.
58
59 2013-04-09 Jan Beulich <jbeulich@suse.com>
60
61 * gas/config/tc-arm.c (do_neon_mov): Fake an instruction suffix
62 if there was none specified for moves between scalar and core
63 register.
64
65 2013-04-09 Jan Beulich <jbeulich@suse.com>
66
67 * gas/config/tc-arm.c (do_neon_ldx_stx): Reject VSTn in the
68 NEON_ALL_LANES case.
69
70 2013-04-08 Jan Beulich <jbeulich@suse.com>
71
72 * gas/config/tc-arm.c (do_neon_ldr_str): Correct disgnostics for
73 PC-relative VSTR.
74
75 2013-04-08 Jan Beulich <jbeulich@suse.com>
76
77 * gas/config/tc-arm.c (reg_names): Convert duplicate SP_fiq
78 entry to sp_fiq.
79
80 2013-04-03 Alan Modra <amodra@gmail.com>
81
82 * doc/as.texinfo: Add support to generate man options for h8300.
83 * doc/c-h8300.texi: Likewise.
84
85 2013-03-28 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com>
86
87 * config/tc-arm.c (arm_cpus): Add support for Cortex-A53 and
88 Cortex-A57.
89
90 2013-03-27 Alexis Deruelle <alexis.deruelle@gmail.com>
91
92 PR binutils/15068
93 * config/tc-tic6x.c (tic6x_try_encode): Add use of bitfields array.
94
95 2013-03-26 Nick Clifton <nickc@redhat.com>
96
97 PR gas/15295
98 * listing.c (rebuffer_line): Rewrite to avoid seeking back to the
99 start of the file each time.
100
101 PR gas/15178
102 * config/tc-sparc.h (ELF_TARGET_FORMAT): Set to elf32-sparc for
103 FreeBSD targets.
104
105 2013-03-26 Douglas B Rupp <rupp@gnat.com>
106
107 * config/tc-ia64.c (emit_one_bundle): Move last_slot adjustment
108 after fixup.
109
110 2013-03-21 Will Newton <will.newton@linaro.org>
111
112 * config/tc-arm.c (encode_thumb32_addr_mode): Emit an error for all
113 pc-relative str instructions in Thumb mode.
114
115 2013-03-21 Michael Schewe <michael.schewe@gmx.net>
116
117 * config/tc-h8300.c (do_a_fix_imm): Add relaxation of mov
118 @(disp:32,ERx) to mov @(disp:16,ERx) insns by new reloc
119 R_H8_DISP32A16.
120 * config/tc-h8300.h: Remove duplicated defines.
121
122 2013-03-21 Senthil Kumar Selvaraj <senthil_kumar.selvaraj@atmel.com>
123
124 PR gas/15282
125 * tc-avr.c (mcu_has_3_byte_pc): New function.
126 (tc_cfi_frame_initial_instructions): Call it to find return
127 address size.
128
129 2013-03-20 Alexis Deruelle <alexis.deruelle@gmail.com>
130
131 PR gas/15095
132 * config/tc-tic6x.c (tic6x_try_encode): Handle
133 tic6x_coding_dreg_(msb|lsb) field coding types and use it to
134 encode register pair numbers when required.
135
136 2013-03-15 Will Newton <will.newton@linaro.org>
137
138 * config/tc-arm.c (do_neon_ldr_str): Fix error check for PC register
139 in vstr in Thumb mode for pre-ARMv7 cores.
140
141 2013-03-14 Andreas Schwab <schwab@suse.de>
142
143 * doc/c-arc.texi (ARC Directives): Revert last change and use
144 @itemize instead of @table.
145 * doc/c-arm.texi (ARM-Instruction-Set): Likewise.
146
147 2013-03-14 Nick Clifton <nickc@redhat.com>
148
149 PR gas/15273
150 * config/tc-arm.c (do_co_reg): Do not call check_obsolete with a
151 NULL message, instead just check ARM_CPU_IS_ANY directly.
152
153 2013-03-14 Nick Clifton <nickc@redhat.com>
154
155 PR gas/15212
156 * doc/c-arc.texi (ARC Directives): Use @code instead of @bullet
157 for table format.
158 * doc/c-arm.texi (ARM-Instruction-Set): Likewise. Also add text
159 to the @item directives.
160 (ARM-Neon-Alignment): Move to correct place in the document.
161 * doc/c-cr16.texi (CR16 Operand Qualifiers): Fix up table
162 formatting.
163 * doc/c-tic54x.texi (TIC54X-Subsyms): Correct use of
164 @smallexample.
165
166 2013-03-12 Sebastian Huber <sebastian.huber@embedded-brains.de>
167
168 * config/tc-nios2.c (nios2_consume_arg): Delete 'k' case. Add 'o'
169 case. Add default BAD_CASE to switch.
170
171 2013-03-11 Sebastian Huber <sebastian.huber@embedded-brains.de>
172
173 * config/tc-nios2.c (nios2_assemble_args_ds): New function.
174 (nios2_arg_info_structs): Add "d,s" and "d,s,E" entries.
175
176 2013-03-11 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
177
178 * config/tc-arm.c (crc_ext_armv8): New feature set.
179 (UNPRED_REG): New macro.
180 (do_crc32_1): New function.
181 (do_crc32b, do_crc32h, do_crc32w, do_crc32cb,
182 do_crc32ch, do_crc32cw): Likewise.
183 (TUEc): New macro.
184 (insns): Add entries for crc32 mnemonics.
185 (arm_extensions): Add entry for crc.
186
187 2013-03-08 Chung-Lin Tang <cltang@codesourcery.com>
188
189 * write.h (struct fix): Add fx_dot_frag field.
190 (dot_frag): Declare.
191 * write.c (dot_frag): New variable.
192 (fix_new_internal): Set fx_dot_frag field with dot_frag.
193 (fixup_segment): Base calculation of fx_offset with fx_dot_frag.
194 * expr.c (expr): Save value of frag_now in dot_frag when setting
195 dot_value.
196 * read.c (emit_expr): Likewise. Delete comments.
197
198 2013-03-07 H.J. Lu <hongjiu.lu@intel.com>
199
200 * config/tc-i386.c (flag_code_names): Removed.
201 (i386_index_check): Rewrote.
202
203 2013-03-05 Yufeng Zhang <yufeng.zhang@arm.com>
204
205 * config/tc-aarch64.c (aarch64_imm_float_p): Rename 'e' to 'pattern';
206 add comment.
207 (aarch64_double_precision_fmovable): New function.
208 (parse_aarch64_imm_float): Add parameter 'dp_p'; call the new
209 function; handle hexadecimal representation of IEEE754 encoding.
210 (parse_operands): Update the call to parse_aarch64_imm_float.
211
212 2013-02-28 H.J. Lu <hongjiu.lu@intel.com>
213
214 * config/tc-i386.c (_i386_insn): Replace have_hle with hle_prefix.
215 (check_hle): Updated.
216 (md_assemble): Likewise.
217 (parse_insn): Likewise.
218
219 2013-02-28 H.J. Lu <hongjiu.lu@intel.com>
220
221 * config/tc-i386.c (_i386_insn): Add rep_prefix.
222 (md_assemble): Check if REP prefix is OK.
223 (parse_insn): Remove expecting_string_instruction. Set
224 i.rep_prefix.
225
226 2013-02-28 Yufeng Zhang <yufeng.zhang@arm.com>
227
228 * config/tc-aarch64.c (aarch64_features): Add the 'crc' option.
229
230 2013-02-28 Yufeng Zhang <yufeng.zhang@arm.com>
231
232 * config/tc-aarch64.c (parse_sys_reg): Allow the full range of CRn
233 for system registers.
234
235 2013-02-27 DJ Delorie <dj@redhat.com>
236
237 * config/tc-rl78.c (reloc_function): Add %code -> BFD_RELOC_RL78_CODE.
238 (rl78_op): Handle %code().
239 (rl78_cons_fix_new): Likewise, but ignore for 20-bit operands.
240 (tc_gen_reloc): Likwise; convert to a computed reloc.
241 (md_apply_fix): Likewise.
242
243 2013-02-25 Kaushik Phatak <Kaushik.Phatak@kpitcummins.com>
244
245 * config/rl78-parse.y: Fix encoding of DIVWU insn.
246
247 2013-02-25 Terry Guo <terry.guo@arm.com>
248
249 * config/tc-arm.c (arm_cpus): Add cortex-r7 entry.
250 * doc/c-arm.texi: Add cortex-r7 and missing cortex-r5 to
251 list of accepted CPUs.
252
253 2013-02-19 H.J. Lu <hongjiu.lu@intel.com>
254
255 PR gas/15159
256 * config/tc-i386.c (cpu_arch): Add ".smap".
257
258 * doc/c-i386.texi: Document smap.
259
260 2013-02-18 Maciej W. Rozycki <macro@codesourcery.com>
261
262 * config/tc-mips.c (s_cpload): Call mips_mark_labels and set
263 mips_assembling_insn appropriately.
264 (s_cpsetup, s_cprestore, s_cpreturn, s_cpadd): Likewise.
265
266 2013-02-18 Maciej W. Rozycki <macro@codesourcery.com>
267
268 * config/tc-mips.c (append_insn): Correct indentation, remove
269 extraneous braces.
270
271 2013-02-15 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
272
273 * config/tc-arm.c (do_neon_mov): Break on NS_NULL.
274
275 2013-02-15 Sebastian Huber <sebastian.huber@embedded-brains.de>
276
277 * configure.tgt: Add nios2-*-rtems*.
278
279 2013-02-14 Yufeng Zhang <yufeng.zhang@arm.com>
280
281 * config/tc-aarch64.c (md_begin): Change to check if 'name' is
282 NULL.
283
284 2013-02-09 Jürgen Urban <JuergenUrban@gmx.de>
285
286 * config/tc-mips.c (CPU_HAS_LDC1_SDC1): New macro.
287 (macro): Use it. Assert that trunc.w.s is not used for r5900.
288
289 2013-02-08 Yi-Hsiu, Hsu <ahsu@marvell.com>
290
291 * gas/config/tc-arm.c (arm_cpus): Add support for mcpu=marvell-pj4
292 core.
293
294 2013-02-06 Sandra Loosemore <sandra@codesourcery.com>
295 Andrew Jenner <andrew@codesourcery.com>
296
297 Based on patches from Altera Corporation.
298
299 * Makefile.am (TARGET_CPU_CFILES): Add config/tc-nios2.c.
300 (TARGET_CPU_HFILES): Add config/tc-nios2.h.
301 * Makefile.in: Regenerated.
302 * configure.tgt: Add case for nios2*-linux*.
303 * config/obj-elf.c: Conditionally include elf/nios2.h.
304 * config/tc-nios2.c: New file.
305 * config/tc-nios2.h: New file.
306 * doc/Makefile.am (CPU_DOCS): Add c-nios2.texi.
307 * doc/Makefile.in: Regenerated.
308 * doc/all.texi: Set NIOSII.
309 * doc/as.texinfo (Overview): Add Nios II options.
310 (Machine Dependencies): Include c-nios2.texi.
311 * doc/c-nios2.texi: New file.
312 * NEWS: Note Altera Nios II support.
313
314 2013-02-06 Alan Modra <amodra@gmail.com>
315
316 PR gas/14255
317 * config/tc-avr.h (TC_VALIDATE_FIX): Mark symbol used by reloc.
318 Don't skip fixups with fx_subsy non-NULL.
319 * config/tc-avr.c (tc_gen_reloc): Don't specially handle fixups
320 with fx_subsy non-NULL.
321
322 2013-02-04 H.J. Lu <hongjiu.lu@intel.com>
323
324 * doc/c-metag.texi: Add "@c man" markers.
325
326 2013-02-04 Alan Modra <amodra@gmail.com>
327
328 * write.c (fixup_segment): Return void. Delete seg_reloc_count
329 related code.
330 (TC_ADJUST_RELOC_COUNT): Delete.
331 * config/tc-i960.h (TC_ADJUST_RELOC_COUNT): Delete.
332
333 2013-02-04 Alan Modra <amodra@gmail.com>
334
335 * po/POTFILES.in: Regenerate.
336
337 2013-01-30 Markos Chandras <markos.chandras@imgtec.com>
338
339 * config/tc-metag.c: Make SWAP instruction less permissive with
340 its operands.
341
342 2013-01-29 DJ Delorie <dj@redhat.com>
343
344 * config/tc-rl78.c (rl78_cons_fix_new): Handle user-specified
345 relocs in .word/.etc statements.
346
347 2013-01-29 Roland McGrath <mcgrathr@google.com>
348
349 * config/tc-arm.c (md_apply_fix): Use as_bad_where for "bad
350 immediate value for 8-bit offset" error so it shows line info.
351
352 2013-01-24 Joseph Myers <joseph@codesourcery.com>
353
354 * config/tc-ppc.c (md_assemble): Do not generate APUinfo sections
355 for 64-bit output.
356
357 2013-01-24 Nick Clifton <nickc@redhat.com>
358
359 * config/tc-v850.c: Add support for e3v5 architecture.
360 * doc/c-v850.texi: Mention new support.
361
362 2013-01-23 Nick Clifton <nickc@redhat.com>
363
364 PR gas/15039
365 * config/tc-avr.c: Include dwarf2dbg.h.
366
367 2013-01-18 H.J. Lu <hongjiu.lu@intel.com>
368
369 * config/tc-i386.c (reloc): Support size relocation only for ELF.
370 (tc_i386_fix_adjustable): Likewise.
371 (lex_got): Likewise.
372 (tc_gen_reloc): Likewise.
373
374 2013-01-17 Yufeng Zhang <yufeng.zhang@arm.com>
375
376 * config/tc-aarch64.c (output_operand_error_record): Change to output
377 the out-of-range error message as value-expected message if there is
378 only one single value in the expected range.
379 (programmer_friendly_fixup): Remove the handling of 8-bit MOVI with
380 LSL #0 as a programmer-friendly feature.
381
382 2013-01-16 H.J. Lu <hongjiu.lu@intel.com>
383
384 * config/tc-i386.c (reloc): Support BFD_RELOC_SIZE32.
385 (tc_i386_fix_adjustable): Keep symbol for BFD_RELOC_32_SIZE and
386 BFD_RELOC_64_SIZE relocations.
387 (lex_got): Support "symbol@SIZE" and don't create GOT symbol
388 for it.
389 (tc_gen_reloc): Resolve BFD_RELOC_SIZE32 and BFD_RELOC_SIZE64
390 relocations against local symbols.
391
392 2013-01-16 Alan Modra <amodra@gmail.com>
393
394 * config/tc-ppc.c (md_assemble <TE_PE>): Ignore line after
395 finding some sort of toc syntax error, and break to avoid
396 compiler uninit warning.
397
398 2013-01-15 H.J. Lu <hongjiu.lu@intel.com>
399
400 PR gas/15019
401 * config/tc-i386.c (lex_got): Increment length by 1 if the
402 relocation token is removed.
403
404 2013-01-15 Nick Clifton <nickc@redhat.com>
405
406 * config/tc-v850.c (md_assemble): Allow signed values for
407 V850E_IMMEDIATE.
408
409 2013-01-11 Sean Keys <skeys@ipdatasys.com>
410
411 * config/tc-xgate.c (md_begin): Fix mistake made when going from
412 git to cvs.
413
414 2013-01-10 Peter Bergner <bergner@vnet.ibm.com>
415
416 * doc/as.texinfo (Target PowerPC): Document -mpower8 and -mhtm.
417 * doc/c-ppc.texi (PowerPC-Opts): Likewise.
418 * config/tc-ppc.c (md_show_usage): Likewise.
419 (ppc_handle_align): Handle power8's group ending nop.
420
421 2013-01-10 Sean Keys <skeys@ipdatasys.com>
422
423 * config/tc-xgate.c (md_begin): Fix the printing of opcodes so
424 that the assember exits after the opcodes have been printed.
425
426 2013-01-10 H.J. Lu <hongjiu.lu@intel.com>
427
428 * app.c: Remove trailing white spaces.
429 * as.c: Likewise.
430 * as.h: Likewise.
431 * cond.c: Likewise.
432 * dw2gencfi.c: Likewise.
433 * dwarf2dbg.h: Likewise.
434 * ecoff.c: Likewise.
435 * input-file.c: Likewise.
436 * itbl-lex.h: Likewise.
437 * output-file.c: Likewise.
438 * read.c: Likewise.
439 * sb.c: Likewise.
440 * subsegs.c: Likewise.
441 * symbols.c: Likewise.
442 * write.c: Likewise.
443 * config/tc-i386.c: Likewise.
444 * doc/Makefile.am: Likewise.
445 * doc/Makefile.in: Likewise.
446 * doc/c-aarch64.texi: Likewise.
447 * doc/c-alpha.texi: Likewise.
448 * doc/c-arc.texi: Likewise.
449 * doc/c-arm.texi: Likewise.
450 * doc/c-avr.texi: Likewise.
451 * doc/c-bfin.texi: Likewise.
452 * doc/c-cr16.texi: Likewise.
453 * doc/c-d10v.texi: Likewise.
454 * doc/c-d30v.texi: Likewise.
455 * doc/c-h8300.texi: Likewise.
456 * doc/c-hppa.texi: Likewise.
457 * doc/c-i370.texi: Likewise.
458 * doc/c-i386.texi: Likewise.
459 * doc/c-i860.texi: Likewise.
460 * doc/c-m32c.texi: Likewise.
461 * doc/c-m32r.texi: Likewise.
462 * doc/c-m68hc11.texi: Likewise.
463 * doc/c-m68k.texi: Likewise.
464 * doc/c-microblaze.texi: Likewise.
465 * doc/c-mips.texi: Likewise.
466 * doc/c-msp430.texi: Likewise.
467 * doc/c-mt.texi: Likewise.
468 * doc/c-s390.texi: Likewise.
469 * doc/c-score.texi: Likewise.
470 * doc/c-sh.texi: Likewise.
471 * doc/c-sh64.texi: Likewise.
472 * doc/c-tic54x.texi: Likewise.
473 * doc/c-tic6x.texi: Likewise.
474 * doc/c-v850.texi: Likewise.
475 * doc/c-xc16x.texi: Likewise.
476 * doc/c-xgate.texi: Likewise.
477 * doc/c-xtensa.texi: Likewise.
478 * doc/c-z80.texi: Likewise.
479 * doc/internals.texi: Likewise.
480
481 2013-01-10 Roland McGrath <mcgrathr@google.com>
482
483 * hash.c (hash_new_sized): Make it global.
484 * hash.h: Declare it.
485 * macro.c (define_macro): Use hash_new_sized instead of hash_new,
486 pass a small size.
487
488 2013-01-10 Will Newton <will.newton@imgtec.com>
489
490 * Makefile.am: Add Meta.
491 * Makefile.in: Regenerate.
492 * config/tc-metag.c: New file.
493 * config/tc-metag.h: New file.
494 * configure.tgt: Add Meta.
495 * doc/Makefile.am: Add Meta.
496 * doc/Makefile.in: Regenerate.
497 * doc/all.texi: Add Meta.
498 * doc/as.texiinfo: Document Meta options.
499 * doc/c-metag.texi: New file.
500
501 2013-01-09 Steve Ellcey <sellcey@mips.com>
502
503 * config/tc-i386.c (md_begin): Remove 'internal Error' from as_fatal
504 calls.
505 * config/tc-mips.c (internalError): Remove, replace with abort.
506
507 2013-01-08 Yufeng Zhang <yufeng.zhang@arm.com>
508
509 * config/tc-aarch64.c (parse_operands): Change to compare the result
510 of function call 'parse_sys_reg' with 'PARSE_FAIL' instead of 'FALSE'.
511
512 2013-01-07 Nick Clifton <nickc@redhat.com>
513
514 PR gas/14887
515 * config/tc-arm.c (skip_past_char): Skip whitespace before the
516 anticipated character.
517 * config/tc-arm.c (parse_address_main): Delete skip of whitespace
518 here as it is no longer needed.
519
520 2013-01-06 Andreas Schwab <schwab@linux-m68k.org>
521
522 * doc/c-mips.texi (MIPS Opts): Fix use of @itemx.
523 * doc/c-score.texi (SCORE-Opts): Likewise.
524 * doc/c-tic54x.texi (TIC54X-Directives): Likewise.
525
526 2013-01-04 Juergen Urban <JuergenUrban@gmx.de>
527
528 * config/tc-mips.c: Add support for MIPS r5900.
529 Add M_LQ_AB and M_SQ_AB to support large values for instructions
530 lq and sq.
531 (can_swap_branch_p, get_append_method): Detect some conditional
532 short loops to fix a bug on the r5900 by NOP in the branch delay
533 slot.
534 (M_MUL): Support 3 operands in multu on r5900.
535 (M_TRUNCWS): Support trunc.w.s on r5900 in MIPS ISA I.
536 (s_mipsset): Force 32 bit floating point on r5900.
537 (mips_ip): Check parameter range of instructions mfps and mtps on
538 r5900.
539 * configure.in: Detect CPU type when target string contains r5900
540 (e.g. mips64r5900el-linux-gnu).
541
542 2013-01-02 H.J. Lu <hongjiu.lu@intel.com>
543
544 * as.c (parse_args): Update copyright year to 2013.
545
546 2013-01-02 Yufeng Zhang <yufeng.zhang@arm.com>
547
548 * config/tc-aarch64.c (aarch64_cpus): Add entries for "cortex-a53"
549 and "cortex57".
550
551 2013-01-02 Nick Clifton <nickc@redhat.com>
552
553 PR gas/14987
554 * config/tc-arm.c (parse_address_main): Skip whitespace before a
555 closing bracket.
556
557 For older changes see ChangeLog-2012
558 \f
559 Copyright (C) 2013 Free Software Foundation, Inc.
560
561 Copying and distribution of this file, with or without modification,
562 are permitted in any medium without royalty provided the copyright
563 notice and this notice are preserved.
564
565 Local Variables:
566 mode: change-log
567 left-margin: 8
568 fill-column: 74
569 version-control: never
570 End:
This page took 0.040965 seconds and 4 git commands to generate.