Talk:MOS Technology 6502
From Wikipedia, the free encyclopedia
Contents |
[edit] Poor Wording
The 6502 was released to the market in September 1975 at $25, while the 6800 and Intel 8008 were selling for $179. At first many people thought it was some sort of a scam, but before the show was over both Motorola and Intel had dropped their prices to $79. Instead of saving them, the 6502 was now legitimized and started selling by the hundreds.
- Before the show was over... what show? It isn't otherwise mentioned. "Instead of saving them" is a bit of a vague pronoun reference. Instead of saving Intel? Might also want a comma after "At first". I'm not a grammar nazi, but this paragraph struck me as being pretty bad. --Jmccorm 04:48, 3 February 2006 (UTC)
-
- From other articles on Wikipedia I gather it was a trade show and that all the 6502 samples were handed out (free?) by the time the show was over.
[edit] 2A03's extra A/V features
The 2A03 lacked the 6502's decimal mode but added 23 memory-mapped registers for sound generation, object drawing, and joypad reading.
This can't be correct. All 6502 based systems use memory mapped IO, as the 6502 doesn't provide any other means of doing IO. All the sound and specialized graphics are provided by other specialized chips. --jay kominek (i'm not outright correcting this as there is a small chance that it is correct. comments?)
- I looked this up and if there is any error it appears to be related to it being audio-only. I think you may be confusion memory-mapped I/O with I/O _register_? I assume the difference would be the ability to work the registers directly without any memory accesses. User:Maury Markowitz
I presume - without having checked - that they're memory mapped registers that access internal (to the chip) hardware - so certain addresses are handled internally rather than causing an external memory cycle. That's certainly plausible given the processor's architecture - but I haven't checked it. User: AndyArmstrong
Andy, accesses to the on-chip components *do* cause an external memory cycle. This was used in a 'state saving' device (GameMaster?) that could detect and store all the data written to the on-chip components by the 2A03, and then write them back so a program could resume where it was saved.
[edit] 6501<>6502 slot converters?
The fact that the processor only had a different pin arrangement than the 6501 makes me wonder if anyone made converters (much like the slockets that became common with Athlons and/or Pentiums of more recent times). Anyone know? —Mulad, May 29, 2003.
It wouldn't be too hard, except for the clocking stuff, which is different on the 6502. Simply get a 6800 datasheet (remember, the 6501 had the same pinout as the 6800), and a 6502 datasheet, and match the pins.
There weren't enough 6501 chips shipped that it made any commercial sense to offer such a product. --Brouhaha 03:41, 20 November 2005 (UTC)
The point is that it would make it possible to plug a 6502 into a 6800 slot - nothing to do with the 6501. The existence of the 6501 just confirms that it's possible. I remember Elektor publishing a project that allowed a 6809 to be plugged into a 6502 socket. There may have been some glue circuitry - but there was clearly some electrical compatibility between 68xx processors and the 6502. AndyArmstrong
Fine, but why would you want to plug a 6800 into a product designed for a 6502, or vice versa? --Brouhaha 21:31, 13 December 2005 (UTC)
The 6501 was designed to be pin compatible with the 6800 - so you could take a 6800 SBC and build it up with the (cheaper, better) 6501. With a suitable adaptor you could use a 6502 in the same way. AndyArmstrong
It's somewhat debatable as to whether the 6501 was any "better" than the 6501. In any case, you haven't really explained why someone would want to do this. In what 6800 system would it be useful to substitute a 6502? Or vice versa? It's not going to make a system run faster or do more; in general all it's going to do is break it. For instance, the Apple I was designed to be usable with a 6800 instead of the 6502, by adding jumpers and additional components, but there's no record of anyone actually having done this, because no Apple I software would run on it. --Brouhaha 01:23, 15 December 2005 (UTC)
- Obviously a 6501 isn't any better than a 6501... I don't see what you're missing; 6501 was pin compatible with / cheaper and faster than a 6800 which means it could be plugged into an existing design and immediately improve it. Sure, it wasn't code compatible but that wasn't such a big deal - at most you'd be talking about rewriting a few K of assembler. Andy Armstrong 08:50, 15 December 2005 (UTC)
-
- So rewriting a few K of assembly is no big deal, but a minor hardware change is? Okay...Mirror Vax 13:21, 15 December 2005 (UTC)
-
-
- An entirely different processor that costs less than half as much - at a time when the cost of the processor was a significant portion of the system price is not a minor hardware change. What part of this are you not getting? You need to understand that these processors weren't designed for home computer applications - they were designed mainly as embedded processors.
-
-
-
-
- Most embedded applications are too cost-sensitive to spend money on an extra adapter. If they were willing to rewrite their 6800 application to run on a 650x, after the 6501 was discontinued they would have done a minor board revision to switch the the 6502. And for applications that weren't cost-sensitive, they just stuck with the 6800. --Brouhaha 20:10, 15 December 2005 (UTC)
-
-
[edit] Clock multiplication
I think the 6502 was a static design and the comment about internal clock multiplcation is plain wrong. I had to write a grant application comparing processors mid 80's the real difference was that Z80 et. al. had clock dividers where the 6502 did not. I also have no knowledge of it ever doing 2 instructions at the same time. Archivist 23:57, Nov 13, 2003 (UTC) (For the application at the time, 6800 Z80 6802 6502 65C02(2Mhz), the 65C02 won hands down and was designed in.)
- AFAIK the 6502 used a lot of dynamic logic, as was common in the NMOS days. It does not have a clock multiplier, but several phase shifted clocks that are internally generated. Check here for more information than you ever wanted to know http://impulzus.sch.bme.hu/6502/6502/6502_kapcs.php3 (oh wait, its hungarian..)
Btw, the Z80 did not have clock deviders, but a state machine. --Qdr 16:53, 13 Jul 2004 (UTC)
-
- WDC's current line is now fully static, at least the 14mhz are from what I remember. --PZ
-
- The NMOS processors were all dynamic; this can most easily be verified by looking at the maximum clock pulse widths in the data sheet. All of the CMOS processors other than some relatively obscure ones from Commodore Semiconductor Group were fully static. There was no clock multiplier in either. --Brouhaha 23:58, 3 September 2005 (UTC)
[edit] Terminator 6502 code
Thanks to Fixative for contributing the checksum program fact to the Trivia item on Terminator! Does someone by any chance have access to a copy of that exact code, either the complete program or the Terminator snippet? (yes, I plan to buy the DVD and press "still picture" at the magic moment, but I still think it strange that Google is unable to find me that code; also, since I was and am a Commodore man, I didn't read Nibble back in the day... come to think of it, Nibble probably never was available in Norway anyway). --Wernher 23:25, 22 Feb 2004 (UTC)
- Update: Having checked out the DVD and received friendly assistance by Nibble 's founder, Mike Harvey (http://www.nibblemagazine.com), I've been able to make the Terminator item a tad more precise. However, the assembly program "OVLY OBJ" (?), which the "KEY PERFECT 4.0" checksum utility is run on in the movie sequence, is still very much a mystery. Anyone know more about this? Also, we've yet to identify the asm programs from which the other code segments are excerpted. They may or may not be from Nibble. --Wernher 21:35, 3 August 2005 (UTC)
Parts of the 6502 source code that appears in Terminator make little sense, but the labels or comments indicate that the code performs operations on VTOC (kind of FAT in 8-bit Atari filesystems). The code was printed in Polish magazine "Tajemnice Atari" (http://tajemnice.atari8.info), but I cannot remember which issue. --0xF 09:40, 12 April 2006 (UTC)
[edit] MOS Technology?
There is evidence that the company is not named "MOS Technologies", but rather "MOS Technology, inc.". See for example this datasheet: [1]. Anybody else has input on this? --Qdr 16:55, 13 Jul 2004 (UTC)
- I'll have to check it in my databooks/sheets. I'd guess there's probably a reason the MOS articles started out under the "Technologies" name in the first place. --Wernher 21:34, 13 Jul 2004 (UTC)
- I'm in the process of editing pages containing refrences to "MOS Technologies" to "MOS Technology", to give it it's proper name. This website has early MOS Technology, Inc. documents, dated January 1976. [2] It is a common mistake to refer to MOS as MOS Techonolgies. I for one made that mistake years ago. Saying "MOS Technologies" sounds right, where as saying "MOS Technology" sounds slightly awkward (for me at least). (Bill Bertram 00:16, 14 Jul 2004 (UTC))
[edit] Memory Access
Re: "History & Use" "The 6502 had one feature that made it particularly good for a home computer system, a small delay in which it was guaranteed to not be accessing the bus. Video display hardware could use this period to read out a line of the screen without having the 6502 pause while this happened. In general terms this sped up the performance of a system using the 6502 by about 25%." vs "Description" "Although all operations took between 2 and 7 cycles, a simplification made in design meant that the 6502 performed a memory access every cycle. According to the original design criteria this wasn't a problem due to the speed advantage of RAM over the CPU. For the microcomputers of the mid-80s this proved a serious disadvantage as slow memory access, especially in systems with a unified memory architecture, would often require CPUs to be significantly underclocked."
I wrote the latter and fully believe it to be true, based on documents such as c64doc and home computers such as the BBC Micro which shipped with 4Mhz RAM coupled to a 2Mhz 6502 so that video could be collected without undue CPU halting and the Acorn Electron which shipped with 2Mhz RAM and a 2Mhz CPU and saw significant CPU halting.
Can anybody clear up which paragraph is right?
- A 1Mhz 6502 accesses memory at 1Mhz, every cycle. If you run 2Mhz memory cycles (possible even with 1970s technology), you can neatly interleave CPU and graphics. That's how it's done on the Apple II, where the CPU always runs at full speed. The C64 is similar, but the CPU is blocked sometimes (for character pointer and sprite fetches). The Atari 800 is different. The CPU and memory run at 1.79Mhz, so there is heavy contention. I suppose there is some disadvantage to the dummy cycles in that case. How much? You'd have to simulate it to find out. It's all pretty academic. Take away the dummy cycles, and the 6502 still needs to access memory most cycles. So it wouldn't really change the system designs. Mirror Vax 28 June 2005 11:59 (UTC)
-
- So you'd entirely disagree with the statement "The 6502 had one feature that made it particularly good for a home computer system, a small delay in which it was guaranteed to not be accessing the bus." as the only time in which the CPU is not accessing the bus is time in which its clock is stopped?
-
-
- The way I read the two allegedly contradictory statements they are not contradictory—rather, they reinforce/confirm each other. I agree with all the other posters that it was possible to interleave CPU and video access to memory and thus totally prevent CPU halting. This is only possible if you can synchronize the CPU and video clocks (with the right phase) so that the CPU is never accessing.memory when the video wants it. For this you would have to know that the CPU is not accessing memory during some specified part of each cycle—not that it doesn't access memory at all during that cycle. That's why the BBC needs 4MHz memory for a 2MHz processor: during each processor cycle there are two memory accesses, one from 2MHz CPU and one from 2MHz video. The guarantee you need is that the access from the processor will happen only at the right point in the cycle, so it can be interlaced with the access from video without collision. This is exactly what the original paragraph said, "a [period in each cycle during] which it was guaranteed to not be accessing the bus". I'm reinstating it. —Blotwell 05:35, 17 August 2005 (UTC)
-
-
-
-
- Why don't you include a little ASCII sketch of the 6502 bus cycle? Then you can make hard statements about it rather than argue about vague generalities. Mirror Vax 06:31, 17 August 2005 (UTC)
-
-
-
-
-
-
- " I agree with all the other posters that it was possible to interleave CPU and video access to memory and thus totally prevent CPU halting" - that isn't really the point. The article says "The 6502 had one feature that made it particularly good for a home computer system, a small delay in each cycle during which it was guaranteed not to be accessing the bus". We have all agreed that the 6502 has no such feature. It is possible for an external bus controller to interleave accesses but this is completely independant of the hardware in the 6502. To put it another way - the sentence is clearly trying to suggest that this is something that made the 6502 more suitable for home computer systems than other CPUs. But clearly it's an implementation decision completely separate to the 6502 that doesn't favour it over the z80, 6809 or anything else. The statement is clearly 100% false as phrased and irrelevant to this article if phrased correctly. ThomasHarte 11:53, 29 August 2005 (UTC)
-
-
-
-
-
-
-
-
- Furthermore, what utility does the statement "In general terms this sped up the performance of a system using the 6502 by about 25%." I only get that figure if I assume a 1Mhz 6502 outputting a 40 byte pitch display (e.g. 160 pixels, 4bpp) with 200 scanlines on an NTSC display. In other words, the Commodore 64. Given the wide variations, and regardless of the rest of the paragraph, I certainly feel this should be removed as it is impossible to come up with a meaningful generality. ThomasHarte 12:25, 29 August 2005 (UTC)
-
-
-
-
I don't understand what ThomasHarte is saying here. "We have all agreed that the 6502 has no such feature"—I certainly didn't intend to agree to this (as I understand it). The point is that there is no external bus master and the CPU never has to wait for the bus. The entire system is synchronous and the bus operates at twice the CPU frequency, thus it is always free when the CPU wants it but it alternates this with servicing other requests from the video CRTC. The CPU and CRTC are synchronized using their external clock inputs. This setup would not work if the CPU were not designed to guarantee its bus accesses to be synchronous with the external clock, hence it is a feature of the 6502 design. —Blotwell 05:18, 1 September 2005 (UTC)
- Apologies, I will try to explain in a clearer fashion. It's a shame that unlike other additions I might make to wikipedia, nobody is in the position of being able to come back and reformat my thoughts! I believe I have been in the wrong here, and I hope to explain the confusion and, in a minute, have a hack at modifying the wording of the article so that people who think as I do will not be confused in future. This message is meant to explain the edit, and I hope it will be acceptable to all. I'm just going to go ahead and do it because it is a wording fix and I am not going to attempt to remove or add new information.
- You say the following: "The point is that there is no external bus master and the CPU never has to wait for the bus ... This setup would not work if the CPU were not designed to guarantee its bus accesses to be synchronous with the external clock, hence it is a feature of the 6502 design."
- The article says: "The 6502 had one feature that made it particularly good for a home computer system, a small delay in each cycle during which it was guaranteed not to be accessing the bus."
- These statements are not contradictory. But the article continues "Video display hardware could use this period to read out of screen memory without having the 6502 pause while this happened." For me, pause and delay are synonymous. For example, Roget's thesaurus (with 1991 supplement) lists both 'pause' and 'delay' as alternatives to 'hinder'. So the meaning of that text becomes confusing as it appears to say "The 6502 had one feature that made it particularly good for a home computer system, a small delay in each cycle during which it was guaranteed not to be accessing the bus. Video display hardware could use this period to read out of screen memory without having the 6502 delay while this happened."
- Confused by this I note your comment "If you run 2Mhz memory cycles ... you can neatly interleave CPU and graphics." which further implies you have some sort of external logic as I read the sentence as being from the point of view of whatever is running the clock. Hence "YOU can neatly interleave" strongly implies something external to the CPU doing some smart interleaving of memory access.
- Anyway, it was because of my general confusion that I first posted here, then only commented out the sentences that I believed you had confirmed as incorrect rather than removing entirely and I thank you for clearing up this topic. I hope that I am about to give some the article the benefit of this discussion! ThomasHarte 23:05, 1 September 2005 (UTC)
-
- Excellent, I think this is what talk pages do best—and it certainly isn't news to me that my explanations are incomprehensible the first few times I try to write them :). I notice you've left unaltered what it sounds as if you might agree is the most poorly-chosen word in the paragraph—the "delay" in "... a small delay in each cycle ...". As you point out, the CPU isn't waiting for the bus in that time, it's probably doing something productive like instruction decode or arithmetic/logic. (It would be different things in different cycles since one instruction took 2–7 cycles to execute.) What would a better expression be? A "short period during each cycle"? —Blotwell 10:46, 2 September 2005 (UTC)
-
-
- You're right, my edit is somewhat imperfect. I think period is right as a direct replacement word. Probably the best replacement would be if anybody knows exactly what period of a cycle the 6502 is accessing the bus? ThomasHarte 17:18, 2 September 2005 (UTC)
-
-
-
-
- The 6502 "expects" to have control of the bus during the entire clock period. It starts driving the address bus and R/W* partway into phase one; for simplicity some hardware designs don't require them to be valid until the start of phase 2 even though they will actually be valid some time before that. The data transfer occurs at the end of phase 2. In systems like the Apple II, external multiplexers and buffers are used to keep the 6502 from driving the memory address and data during phase 1, in order for the video circuitry to use the memory during that time. However, there's nothing in the 6502 design that would preclude more complicated hardware from using more or less than half of the cycle for other purposes, provided that on reads the memory data makes it to the 6502 within the necessary window of setup and hold time. The use of phase 1 for an alternate bus master is simply a convenient way of designing the hardware. As Blotwell previously pointed out, this is a matter of synchronous bus design rather than any designed-in "delay" in the memory cycle. Inside the chip, it simply takes a certain amount of time from the leading edge of phase one until it can provide a valid address on the bus, and clever designs stole a portion of the cycle. There were 8080 and Z-80 based systems that did similar things, but the designs were more complex because although the 8080 and Z-80 did have synchronous busses, they used more than one clock cycle per memory access. --Brouhaha 23:37, 3 September 2005 (UTC)
-
-
-
-
-
-
- "Inside the chip, it simply takes a certain amount of time from the leading edge of phase one until it can provide a valid address on the bus" - I feel I am probably now straying far from the topic of "how to clarify things in the article" but does this mean that a 6502 rated at 2Mhz which expects to reach phase 2 after 50% of a cycle will reach phase 2 after only 25% of a cycle if the input clock is 1Mhz?
-
-
-
-
-
-
-
- "There were 8080 and Z-80 based systems that did similar things, but the designs were more complex because although the 8080 and Z-80 did have synchronous busses, they used more than one clock cycle per memory access. " - is this the reason that, e.g. the Amstrad CPC is usually said to round instruction lengths up to the nearest 4 rather than having the somewhat more complicated timing characteristics of a ZX Spectrum (which just raises the halt line when a clash is detected and otherwise operates a floating bus)? ThomasHarte 14:38, 4 September 2005 (UTC)
-
-
-
-
-
-
-
-
- "but does this mean that a 6502 rated at 2Mhz which expects to reach phase 2 after 50% of a cycle will reach phase 2 after only 25% of a cycle if the input clock is 1Mhz?" - Yes, in a sense that is true., depending on the external hardware. The actual timing of the phases is determined by the external clock input (known as phase 0). The 2 MHz rated part has minimum clock high and low specifications of a little less than 250 ns, vs. a little less than 500 ns for the 1 MHz rated part. Most commonly the 6502 is run on a symmetric clock, but it is also possible to run the 2 MHz part on a clock that is 250 ns low, 750 ns high (1 MHz), or any other asymmetric timing that doesn't violate the minumum clock low and high times. The 6502 won't "reach phase 2" until shortly after the rising edge of the clock phase 0 input, but on a 2 MHz part that can happen about 250 ns after the falling edge of the input, even if the actual frequency is substantially lower than 2 MHz.
-
-
-
-
-
-
-
-
-
- The 2 MHz part also has a better (lower) maximum address delay specification (the maximum time from the falling phase 2 clock edge to the address bus and R/W* signals being valid), so even if you run the 2 MHz part at 1 MHz, you potentially can use slower memory parts with it (depending on your hardware design) because the address is valid for a larger portion of the cycle. In practice, though, many hardware designs simply assume that the address will be valid by the rising edge of phase 2, which is guaranteed by the specs because the maximum address delay spec is less than the minimum clock low time spec. --Brouhaha 21:29, 4 September 2005 (UTC)
-
-
-
-
Despite the discussion above, the misleading paragraphs were still in the article, so I cut them. To summarize:
- There is never a time when the 6502 isn't using the bus.
- Some bus cycles are useless, "dummy" cycles. Most are real. For example, LDA $1234,x requires four memory accesses (3 for the instruction and 1 for the load) and takes four cycles, except when it crosses a page boundary, in which case there's an extra cycle. With or without the dummy memory accesses, the 6502 - or any cacheless CPU - is memory dependent, and obviously cycle-stealing DMA is going to effectively halt the processor. Mirror Vax 13:17, 21 October 2005 (UTC)
- Huh? Pursuant to the discussion above, the misleading paragraphs were carefully reworded to, I thought, everyone's satisfaction. So I reinstated them. If you have a problem with their wording feel free to modify them, but don't just remove the information. —Blotwell 10:54, 19 November 2005 (UTC)
-
- The information is not consistent with Brouhaha's description above, or my summary. Perhaps you could point out where anyone agreed with the "carefully reworded" version? Mirror Vax 20:31, 19 November 2005 (UTC)
-
-
- If anything needs to be said about it, the significant fact about the 6502 (and 6800 and 6809) is not that they only need memory data during part of a clock cycle. That's true of all microprocessors. What made interleaved video easy is that all 6502 memory cycles take exactly one clock cycle (unless external hardware requests wait states), so the memory is used by the processor with consistent, uniform timing. (Some processor cycles actually ignore the data from memory, but the plain 6502 doesn't provide any indication of this to the external hardware.) By comparison, on an 8080 or Z-80, memory cycles can take from 2 to 5 clocks, so the processor requests for memory occur at less predictable times.
- However, I'm not completely certain that the main page needs a description of this at all.--Brouhaha 03:48, 20 November 2005 (UTC)
-
-
-
-
- Incidentally, the MOS
65SC02eliminates most (all?) of the 'dead' cycles. The datasheet claims a 25% performance improvement at the same clock frequency. Note that this in no way ameliorates the so-called "serious disadvantage" (according to the other wrong paragraph) of accessing memory every clock cycle (which is shared by cacheless CPUs in general). Mirror Vax 06:40, 20 November 2005 (UTC)- Whoops, make that the 65CE02. Mirror Vax 00:17, 27 November 2005 (UTC)
- Incidentally, the MOS
-
-
[edit] MHz
Didn't the earlier 6502s run at 1.024 MHz (i.e. 1024 Hz), not (unless you're rounding) 1MHz (i.e. 1000 Hz)? I recall seeing "1.024 MHz" in one of my Apple ][+ manuals, but I think it's in landfill. Just wondering; Binary_prefix indicates Hz is always in decimal.
-
- The rating was 1 MHz exactly. Apple ran it very slightly above the rating, so technically it may have been "overclocked". It's also possible that Apple obtained a specification waiver from the manufacturer.
- The processor clock cycle timing in the Apple II was not constant; it consisted of a repeating series of 64 "normal" cycles followed by a single "long" cycle. This was done in order to keep the color carrier phase constant for each scan line; in a normal NTSC signal there are 227.5 cycles of the color carrier per scan line, so consecutive scan lines within a field have opposite carrier phase. In the Apple II, there are 228.0 ccyles of hte color carrier per scan line, and in that same time there are 65 processor cycles.
- The "normal" Apple II CPU cycle is 3.5 cycles of the color carrier (~977 ns, ~1.023 MHz), and the "long" cycle is 4.0 cycles of the color carrier (~1117 ns). Thus the average cycle time is ~979 ns, which is ~1.020 MHz.
- It has always bothered me that most microprocessor timing specifications give a hard limit on frequency (or equivalently, cycle time) that is an "exact" frequency, e.g., 1 MHz, 1.5, 2.0, 4.0, etc. Thus if you use a 1 MHz crystal oscillator with a 1 MHz microprocessor, there's about a 50% chance that you're overclocking the processor, due to the tolerance of the oscillator frequency being distributed both above and below its nominal frequency. It would technically be more appropriate for the microprocessor vendors to spec (and test) to perhaps 0.5% high, so that a crystal at the nominal frequency can guarantee operation within spec. --Brouhaha 23:32, 10 March 2006 (UTC)
[edit] Branch range
"Relative was used for conditional branch instructions, which could move the program counter 126 bytes backwards or 129 bytes forwards (commonly incorrectly documented as being 128 and 127 respectively)".
It's -128..+127 if you count from the address of the instruction that follows the branch. This is how branch ranges are normally specified for processors. Saying about 126 and 129 is thus very confusing. --0xF 09:57, 12 April 2006 (UTC)
[edit] Non-Wikipedia Style
The entire style of this article is very strange for Wikipedia. The most serious problem is the informal and un-encyclopedic language, as in the phrase "At first many people thought it was some sort of a scam...." The use of asterisked footnotes (without even #anchor links) is also non-standard and off-putting for a Wikipedia article.
Was this information adapted from some other, unattributed source? (I know the FOLDOC entry is attributed, but very little of this article comes from that entry.) Is there a possible copyvio here? Falcotron 04:48, 18 June 2006 (UTC)
- I also suspected copyvio, but didn't turn up anything that substantiated that. The asterisks first appeared in this edit. While they do appear to be a well-meaning edit, they severely break style and just don't belong. Best course of action is probably to work the important bits into the normal text. Aluvus 03:51, 20 July 2006 (UTC)
-
- I'm the one to blame for the asterisked footnotes — they were an attempt to make the notes more "local" (i.e closer to the text they aim at), as I find it somewhat ugly that every footnote ends up at the end of the whole article. However, as there are probably no standard way to achieve this (?) it's probably better to integrate them into the main text, as suggested. Still, I must say I find factual errors much more problematic than errors regarding style, conventions, and language ;) — my edits actually corrected a few, quite severe, technical errors and misconceptions. -- HenkeB 02:07, 23 July 2006 (UTC)
[edit] Opcodes
In "Dubious Features": The 6502's instruction decoding is implemented in a hardwired logic array (similar to a programmable logic array) which is only defined for 151 of the 255 available opcodes. The remaining 105...
But 151+105=256, not 255. 256 makes more sense, and saying "255" is an easy error to make. I would modify the page but I don't know anything about the 6502. Elektron 13:59, 18 June 2006 (UTC)
- I started programming the 6502 back in the 70s, so I took care of it. :-) --Dennette 11:30, 21 June 2006 (UTC)
- I love how it describes the strange actions. It'll either do nothing, or do everything, or crash :)
[edit] 6502B, C
I know there were addition 6502 chips, such as the B and C revisions. The C had some additions asked for by Atari, and they used this chip in several of their 8bit systems. Not sure who (MOS or WDC) created it. Would be nice to have this info included.
[edit] BCD status flags
In "Dubious Features": The N (result negative) and V (sign bit overflow) status flags are invalid while the processor is operating in BCD mode. Only the Z (result is zero) and C (carry) flags are valid. This was also fixed in the CMOS derivatives.
In official datasheets is stated that N, V and Z flags (are) invalid in decimal mode. (W65C816S 16-bit Microprocessor p. 56). Moreover the Z flag bug is used in processor type detection routine to distinguish CMOS from NMOS CPUs [3]. More detiled information can be found here. Any suggestions why previous statement including Z flag being invalid was removed? --Laoo 13:30, 10 January 2007 (UTC)
No objections so I've fixed. --Laoo 14:12, 24 March 2007 (UTC)