Slashdot Mirror


Coder Accuses IBM of Patenting His Work

ttsiod writes "Back in 2001, I coded HeapCheck, a GPL library for Windows (inspired by ElectricFence) that detected invalid read/write accesses on any heap allocations at runtime — thus greatly helping my debugging sessions. I published it on my site, and got a few users who were kind enough to thank me — a Serbian programmer even sent me $250 as a thank you (I still have his mails). After a few years, Microsoft included very similar technology in the operating system itself, calling it PageHeap. I had more or less forgotten this stuff, since for the last 7 years I've been coding for UNIX/Linux, where valgrind superseded Efence/dmalloc/etc. Imagine my surprise when yesterday, Googling for references to my site, I found out that the technology I implemented, of runtime detection of invalid heap accesses, has been patented in the States, and to add insult to injury, even mentions my site (via a non-working link to an old version of my page) in the patent references! After the necessary 'WTFs' and 'bloody hells' I thought this merits (a) a Slashdotting, and (b) a set of honest questions: what should I do about this? I am not an American citizen, but the 'inventors' of this technology (see their names in the top of the patent) have apparently succeeded in passing this ludicrous patent in the States. If my code doesn't count as prior art, Bruce Perens's Efence (which I clearly state my code was inspired from) is at least 12 years prior! Suggestions/cursing patent trolls most welcome."

57 of 249 comments (clear)

  1. ludicrous by alphatel · · Score: 5, Insightful

    Can I drop a hint about the patent office having no credibility any more?

    --
    When the foot seeks the place of the head, the line is crossed. Know your place. Keep your place. Be a shoe.
    1. Re:ludicrous by ebbe11 · · Score: 4, Insightful

      Can I drop a hint about the patent office having no credibility any more?

      Actually , the Patent Office does have crecibility in a few places. Unfortunately, courts of law are among them...

      --

      My opinion? See above.
    2. Re:ludicrous by mcvos · · Score: 4, Interesting

      Didn't the USPTO some years ago stop checking the validity of patents completely, leaving it to the courts to decide whether a patent is actually valid?

      That means in this particular case, the patentholder just wasted a lot of money, as the submitter's code is clearly prior art. It also raises the question why patent applications are still so expensive if the patent office doesn't actually do anything anymore. (Answer: to increase profits, of course!)

    3. Re:ludicrous by rbanffy · · Score: 2, Funny

      Courts still find it credible enough to accept patent lawsuits. Even trolls have credibility in East Texas.

    4. Re:ludicrous by networkconsultant · · Score: 5, Informative

      Unless you sue IBM and have very deep pockets once someone has stolen your idea and had the theft accredited by the rating agency (patent office) you are essentially screwed. You may file an appeal, but then the burden of proof is on you.
      Tesla and Marconi had similar ideas around the same time but the patent office ruled in favor of Marconi, you my friend may be a Tesla at this point.

    5. Re:ludicrous by splutty · · Score: 3, Insightful

      Yeah. Trolls have credibility in East Texas, but that's only because the bridges there are so damn cheap!

      1s/bridges/judges/

      --
      Coz eternity my friend, is a long *ing time.
    6. Re:ludicrous by youn · · Score: 2, Funny

      Ah I miss the days when a troll was a giant mythical character causing havoc wherever it went :)

      --
      Never antropomorphize computers, they do not like that :p
    7. Re:ludicrous by Anonymous Coward · · Score: 4, Informative

      Pretty sure the patent office is accepting applications for examiners right now, lol. They like people with Master's degrees.

    8. Re:ludicrous by Anonymous Coward · · Score: 3, Funny

      That may explain why I get all itchy when I get out of the basement.

    9. Re:ludicrous by hedwards · · Score: 2, Insightful

      Probably, I suspect that might be the sort of thing that resulted in Facebook being granted the trademark to "Face." Back when MS was trademarking for their new GUI, they had to include Microsoft in the name to get the trademark because windows is eponymous. I don't think they would've bothered even trying to get Windows.

      I know that ISO is apparently no longer a standards organization preferring to let the markets make the selection. Which begs the question of why do we need ISO if somebody else is choosing the standards.

    10. Re:ludicrous by jbengt · · Score: 2, Informative

      What's that you say? The PTO is not a private company, but rather a branch of our omnipotent benevolent government, . . . Well, in that case they can't possibly be concerned with revenue...

      I believe that the USPTO is set up to pay for itself. budget
      They certainly are concerned with revenue.
      The USPTO’s earned revenue is derived from the fees collected for patent and trademark products and services. Fee collections are recognized as earned revenue when the activities to complete the work associated with the fee are completed.

    11. Re:ludicrous by FatdogHaiku · · Score: 2, Informative

      Well, U.S. Supreme Court upheld Tesla's patent in the end, but it was after Tesla had passed away... and it was to nullify a lawsuit against the US for Marconi.

      --
      You have the right to remain sentient. If you give up the right to remain sentient, you will be elected to public office
    12. Re:ludicrous by Dachannien · · Score: 5, Informative

      Before spouting off about how the USPTO sucks so much ass solely on the basis of what the OP says, first try a little independent research. You can look up the entire prosecution history of the application in question on the USPTO's website at Public PAIR.

      First off, the guy's website was cited by the examiner rather than by IBM. The examiner used the OP's website to reject the claims three times before IBM's attorney finally came around and amended the claims to include this:

      wherein setting the allocation mode for the process to enable determining in real-time an invalid access is performed in real-time, and wherein the setting sets the allocation mode for an application executed by the process without requiring recompiling, linking or loading of the application to set, in real-time, the allocation mode for the application

      This was cited by the examiner in the reasons for allowance. Does the OP's code do this?

      Once again, this is an example of people who know very little about the patent system reading the abstract or looking at the figures, and not understanding that the really important part of the application is the claims. Nothing to see here, move along.

    13. Re:ludicrous by makomk · · Score: 5, Insightful

      First off, the guy's website was cited by the examiner rather than by IBM. The examiner used the OP's website to reject the claims three times before IBM's attorney finally came around and amended the claims to include this:

      In other words, IBM tried really hard to patent exactly the method used by HeapCheck and Electric Fence - down to the last detail. They eventually settled for a patent with just enough of an amendment to the claims to avoid the prior art, but not enough to actually be an improvement on the state of the art.

      (The extra stuff IBM have put into their claim is actually a trivial addition to something like HeapCheck - it's just that under most circumstances it's a pointless one. All it allows you to do is enable or disable checking prior to process startup on a per-process basis, and on most systems you can do that easily using LD_PRELOAD and the linker-loader.)

      This seems to be fairly common. Microsoft did the same with their patent on XML formats for documents. Amazon's patent on one-click shopping is even worse - they have a whole bunch of bizarre and narrow exclusions in the claims, each aimed at excluding a particular example of prior art.

    14. Re:ludicrous by _Sprocket_ · · Score: 2, Interesting

      Pretty sure the patent office is accepting applications for examiners right now, lol. They like people with Master's degrees.

      NASA requires science and math degrees in their civil servants to include IT positions. I met one person who's sole qualification for the system they were responsible for was that they had a math degree. They had no experience and very little understanding for the system they were responsible for, much less any general IT experience. They were great to work with; very smart. But bluntly put, they were unqualified for the role. The only reason they took the job was that they wanted an in at NASA and that was the only position they were offered. A couple years later, offered a position elsewhere that more closely matched their interest in manned space so they moved on. There are numerous individuals in that same IT organisation who's sole qualifications are the degree and a desire for a career change that involves "working with computers."

      I don't have any insight with the Patent Office. However, having witnessed other US Federal bureaucracies at work, I wouldn't put a whole lot of weight in their requirement for Master's degrees.

  2. Answers and Suggestions and Further Questions by eldavojohn · · Score: 5, Insightful

    what should I do about this?

    Disclaimer: I'm not a lawyer; this isn't legal advice. But you've got a few options. All or none of which you can pursue.

    The first option is to simply contact IBM and ask them how their patent is novel or different or disjoint from your work. This could result in one of two things: no response or a response. If you are satisfied with the response, you might change your mind about your situation and congratulate them on putting some novel innovations on HeapCheck, patenting it and listing you in the claim references (do you own any patents related to it?). Now, assuming that it does not satisfy you as an explanation, you could indicate that you are going to pursue legal action (the I in IBM stands for International) but you are willing to settle and sign away your rights for some relatively nominal fee. You could choose to reveal you're not interested in a lengthy expensive court battle with them or you could make it sound like you are angry and this is all you have to do with 100% of your time. Either mentality will send them a message, that's up to you.

    The second option is to get litigious. Judging by your ccTLD (and awesome name), I'm guessing you are from Greece. Which means that you would probably have to hire a patent lawyer in your home country who can work with the Greek or European Patent Office in order to discuss your options. There should be channels through the WIPO that allow things like these to be resolved almost exactly like they're on a local level. I'm guessing your options are going to amount to two things. Either pursuing your own patent on the technology in order to invalidate IBM's patent or presenting your evidence of prior art to invalidate IBM's patent. The former probably more expensive than the latter.

    Normally patents are only valid in the country they are granted but lately there have been intellectual property laws that have tried to extend patents on a global scale. Normally on this site people seem to be against this, often applying the logic of following their local laws when it suits them. Example: Pirate Party. But now we're so concerned if suddenly this is American company gets an American patent on a foreigner's work.

    cursing patent trolls

    Um, that phrase has a particular meaning, one that I cannot find in your story. Who did IBM sue with your patent? Did they sue you? Did they wait for everyone to adopt HeapCheck and then sue them? If anyone in this story is considered the patent troll, it's going to be you if you waited a decade before ligating against IBM.

    I would take Bruce Perens' approach and try working with IBM first. It's the cheapest, most sensible way to resolve this. You're angry but you just said you had forgotten about that work for seven years. Was your intention to leave that concept in the graveyard until you died, getting angry should anyone try to profit from it or license it?

    --
    My work here is dung.
    1. Re:Answers and Suggestions and Further Questions by mcvos · · Score: 3, Interesting

      Now, assuming that it does not satisfy you as an explanation, you could indicate that you are going to pursue legal action (the I in IBM stands for International) but you are willing to settle and sign away your rights for some relatively nominal fee.

      What rights does he have to sign away? He didn't patent anything. He just published prior art under an open source license. So everybody already has the right to use this technology for free. IBM acquired a useless patent.

      At least, that's as far as I understand patent law. Maybe someone will correct me if I'm wrong.

    2. Re:Answers and Suggestions and Further Questions by Sockatume · · Score: 4, Interesting

      Patents (like registered trademarks, and unlike copyright) are assumed enforcable unless proven otherwise. They're not supposed to be granted in the first place if they're invalid.

      --
      No kidding!!! What do you say at this point?
    3. Re:Answers and Suggestions and Further Questions by mcvos · · Score: 2, Interesting

      Patents (like registered trademarks, and unlike copyright) are assumed enforcable unless proven otherwise.

      Wouldn't prior art prove otherwise?

      They're not supposed to be granted in the first place if they're invalid.

      I seem to recall that some years ago, the USPTO stopped checking the validity of patents, simply approving pretty much every application. It would certainly explain the flood of ridiculous patents.

    4. Re:Answers and Suggestions and Further Questions by 42forty-two42 · · Score: 5, Insightful

      You're angry but you just said you had forgotten about that work for seven years. Was your intention to leave that concept in the graveyard until you died, getting angry should anyone try to profit from it or license it?

      If he didn't take a patent on it, then there's nothing stopping IBM from using the same techniques. The problem arises when IBM patents it as if they were the first to invent the technique, then restrict everyone (including the OP) from using the OP's invention. If IBM just used it without patenting, no problem. Of course, it's entirely possible that IBM's invention is slightly different from the OP's - patent claims are rather hard to read for a layman after all.

    5. Re:Answers and Suggestions and Further Questions by dataminator · · Score: 3, Informative

      Now, assuming that it does not satisfy you as an explanation, you could indicate that you are going to pursue legal action (the I in IBM stands for International) but you are willing to settle and sign away your rights for some relatively nominal fee.

      Ok, you said you are not a lawyer, but you could at least try to know what you're talking about before writing such a post.

      IANAL either, but even I know that being granted a patent doesn't magically make you own all prior art in the domain. The patent examiner even noticed HeapCheck as related work! The author has no claims whatsoever against IBM, and the idea to push for a settlement is ridiculous. What can there possibly be to settle?

      Since the examiner approved the patent, while knowing about HeapCheck, they must have thought that the patent claims (only the claims count, the description is worthless in that regard) are not fully covered by prior art. I doubt they could be wrong on this, so the prior art defense is pretty much out. They must also have thought that there is significant non-obvious innovation in relation to the prior art. That part is more subjective and thus may be debatable.

      In any case, the only possible outcome would be that IBM loses the patent, which changes exactly nothing for anybody unless IBM starts to sue people based on that patent. In any case the author has absolutely nothing to gain, and no basis whatsoever to negotiate with IBM.

      There are no rights to sign away, the author can do nothing to help IBM maintain the patent if it is invalid, and has no benefit from invalidating it. And if the patent is valid, as it probably is, he's just going to lose a lot of money and look like a fool (as opposed to losing a lot of money but without looking like a fool if he wins).

      No, I did not look at the patent, and am not going to. It would change nothing about the above.

    6. Re:Answers and Suggestions and Further Questions by ttsiod · · Score: 5, Informative

      I only take an issue with your last paragraph - I certainly didn't leave the code in a graveyard, I released it with an open source license, so that anyone could use it and make his life a bit better. The fact that 10 years later, someone else has now patented the ideas in Electric Fence and HeapCheck, and can now sue me and everyone else using it, is what got me mad (hence the "trolls" comment).

    7. Re:Answers and Suggestions and Further Questions by Darfeld · · Score: 2, Informative

      Patents (like registered trademarks, and unlike copyright) are assumed enforcable unless proven otherwise.

      Wouldn't prior art prove otherwise?

      Assuming someone is sued and find the prior art, the patent would be nullified. But the patent exist until then, and is still dissuasive for someone to use the technology.

      --
      (\__/) This is Lapinator
      (='.'=) copy it in your sig
      (")_(") so it can take over the world
    8. Re:Answers and Suggestions and Further Questions by Spazmania · · Score: 4, Interesting

      Wouldn't prior art prove otherwise?

      As I understand it (and IANAL so I could be way off base) the process goes something like this:

      You're sued for infringing X.
      You assert that Y (which they failed to cite or differentiate) is prior art for X.
      They file a modification to X adding a citation for Y and explaining the difference between Y and X.
      Rinse, repeat.
      If the patent on X is still broad enough to cover your use, you either settle or lose in court.
      If the patent on X has been narrowed enough that it no longer covers your use, they settle or lose in court.

      Generally, one or the other of you decides to settle once things are fully fleshed out. The matter becomes pretty obvious and there's no point in either of you continuing the expense. You're not going to succeed on process-related counterclaims; they had a reasonable belief that you'd infringed the patent when they sued.

      Occasionally the mistaken party gets stubborn and goes to court anyway. When that happens, it's about 50/50 whether the court rules in favor of the plaintiff or defendant. The court rarely invalidates the patent; when ruling in favor of the defendant, it's usually because the defendant's use was enough different from what the patent has become by the time of the actual trial that it doesn't infringe.

      Generally speaking, the patent office is not your friend in this situation. When you submit a claim of prior art, they rule more carelessly than a court and once they rule the court is loathe to reconsider.

      --
      Moderating "-1, Disagree" is simple censorship. Have the guts to post your opinion.
    9. Re:Answers and Suggestions and Further Questions by gnasher719 · · Score: 3, Informative

      The first option is to simply contact IBM and ask them how their patent is novel or different or disjoint from your work. This could result in one of two things: no response or a response. If you are satisfied with the response, you might change your mind about your situation and congratulate them on putting some novel innovations on HeapCheck, patenting it and listing you in the claim references (do you own any patents related to it?). Now, assuming that it does not satisfy you as an explanation, you could indicate that you are going to pursue legal action (the I in IBM stands for International) but you are willing to settle and sign away your rights for some relatively nominal fee. You could choose to reveal you're not interested in a lengthy expensive court battle with them or you could make it sound like you are angry and this is all you have to do with 100% of your time. Either mentality will send them a message, that's up to you.

      There is a problem here. The only situation where his code would affect IBM's patent is if he has published prior art that would genuinely make their patent invalid. But in this case he has no rights that he could sign away. Patents are not like copyright. If you illegally copied my code, I could say "give me $100,000 and I give you the rights to this code", and maybe you accept and we are both happy. If you use my patent without a license, I could say "give me $100,000 and I'll give you a license". If he has prior art that makes their patent valid, then it is out of his hands. _Anybody_ can invalidate the patent. He could say to IBM "give me $100,000 and I'll forget about my prior art". But even if IBM pays, I could then say to IBM "give me $100,000 and I'll forget about this guy's prior art". What makes it prior art is that it has been published. If this guy can prove that it has been published, then so can I, and everybody else. He doesn't get any rights from having created the prior art. The right to invalidate the patent is something that _everybody_ has.

      Of course he can spend a lot of money to invalidate IBM's patent, but even if he wins, at an enormous cost, all he gets is that IBM's patent is invalid. There is no money to be had from this. The only way to make money is to carefully collect evidence for the prior art (collect evidence that the invention was available to the public), and if he hears that IBM sues anybody for patent infringement, then he can go to the defendant and say "give me $100,000 and I give you clear documentation that proves beyond any doubt that their patent should be invalid".

    10. Re:Answers and Suggestions and Further Questions by The+Empiricist · · Score: 3, Informative

      The first option is to simply contact IBM and ask them how their patent is novel or different or disjoint from your work.

      A similar option is to look at the patent prosecution history in Public PAIR. Get through the CAPTCHA, click on the Image File Wrapper tab, and look at the rejections, amendments, responses, etc.

      It looks like the Tsiodras reference was used by the Examiner to reject the patent application. What happened is that the applicants amended their claims so that they would not cover what was taught by HeapCheck 1.2. For example, the applicants state that in the HeapCheck 1.2 documentation "it clearly states that all source files that want to make use of the alternative heap memory allocation mode must be compiled to include specific header files and then linked to a specific library that will satisfy those requests (see, e.g., Section 4 'Usage')." After this argument was first made, it wasn't enough for the Examiner, who ended up rejecting the application two more times before satisfactory claim language was submitted.

      The point is that IBM has already said why it thinks that they have something that is novel and nonobvious, so it is a good idea to look at what they've said before demanding that they say it all over again. More importantly, HeapCheck (version 1.2 at least) does not infringe on the patent claims. According to the documentation on the HeapCheck v1.2 web page, you have to compile support for it into the software you are creating. But the IBM patent requires that "setting the allocation mode for the process . . . is performed in real-time, and wherein the seting sets the allocation mode . . . without requiring recompiling, linking or loading of the applicaiton to set, in real-time, the allocation mode for the application."

      Tsiodras could have trouble if future versions of HeapCheck included features that fall within the scope of the claimed invention, but even version 1.34 appears to require re-compilation to enable and disable the heap checking features.

    11. Re:Answers and Suggestions and Further Questions by Fareq · · Score: 2, Informative

      With regard to the patents, he has nothing to negotiate. However, if he wrote the code, and released it under the GPL, he could definitely claim that their software which uses the technology is a violation of the terms of the GPL license. This claim might be legitimate (if they copied) or completely not legitimate (if they didn't re-use any of the code, and merely developed new software with similar capabilities and features).

      In reality, OP is going nowhere with this. The USPTO is unlikely to invalidate the patent because somebody presents them with prior art that they already considered. Even if the USPTO was wrong, they aren't going to reconsider. Even if this was new prior art that nobody had previously known about... the USPTO is extremely unlikely to reconsider the patent grant. If it has been granted already, then, as they say, "prosecution on the merits is closed." Oh, sure, if IBM sues somebody, the prior art might be helpful. Claim 1 might or might not hold up unmodified in court, depending. Were it to require modification, then IBM could potentially lose a suit. IBM is unlikely to pursue the matter at this stage anyway, and they probably don't even realize that they have this particular patent.

      I'm not going to read the entire document to make sure that I understand precisely all of IBM's definitions of terms, so I can't give an informed opinion on the validity. Without doing enough reading to be informed ('cause hey, this is the internet after all, I'm supposed to be wrong or at least uninformed), the whole thing probably turns on the feature of not having to re-link or even re-load the application to set the heap checking feature on and off.

      Remember, you're only infringing a claim if you are infringing the entire claim. This patent isn't on "heap checking" or even "run-time detection of invalid heap access", or anything of the sort. If you aren't infringing the entirety of claim 1, the entirety of claim 12, or the entirety of claim 16 (the 3 independent claims), then you aren't infringing this patent. Similarly, if the HeapCheck software didn't do everything listed in those claims, then the differences between HeapCheck and those claims is the part that is (supposedly) novel and non-obvious.

      (standard disclaimers apply; I'm no lawyer, this isn't legal advice, I'm just an engineer that happens to work the IP/patent process for my department)

    12. Re:Answers and Suggestions and Further Questions by Svartalf · · Score: 2, Informative

      Just because they already considered it, doesn't mean they won't invalidate it.

      The truth of the matter is that just because an examiner "considered" it, doesn't make the examiner right. I've had patent submissions that didn't get done because I ran out of funds (it's expensive to file one of these things...) where the "examiner" did their initial rejection on one of my early claims, and went looking for things that "anticipated" the usage in question- none of which were relevant. If they had people that were qualified and competent to do the examinations in the space they're doing them in, it'd be one thing, but it's not there and they're not even really trying these days.

      --
      I am not merely a "consumer" or a "taxpayer". I am a Citizen of the State of Texas
    13. Re:Answers and Suggestions and Further Questions by Kalriath · · Score: 2, Interesting

      You missed one point completely - for once, Microsoft is on the same side as you here. You could probably point out to Microsoft legal that IBM has attempted to patent technology that's been in Windows since 2001, and see where that goes.

      Remember, if you aren't large enough to get in the fight, just open the gate and let one of the bigger dogs do it.

      --
      For a site about things like basic rights, Slashdot users sure do like to censor "dissent".
  3. Cited by examiner by Sockatume · · Score: 5, Informative
    --
    No kidding!!! What do you say at this point?
    1. Re:Cited by examiner by michelcolman · · Score: 3, Funny

      You mean patent examiners actually examine patents? Wow, that's news to me! Maybe they just pick a few and auto-approve the rest?

    2. Re:Cited by examiner by hey! · · Score: 4, Interesting

      Hmmm. It would seem that the patent is for an operating system memory management feature. Note in claim 1:

      wherein setting the allocation mode for the process to enable determining in real-time an invalid access is performed in real-time, and wherein the setting sets the allocation mode for an application executed by the process without requiring recompiling, linking or loading of the application to set, in real-time,

      So you don't have to modify your source or link against a certain library, either statically or dynamically. In fact, it *sounds* like you can turn this on for a process as it is running. An argument might be made that the existence of techniques for the programmer to compile and link his program with relative transparency makes putting this capability into the operating system an obvious step, but I think reasonable people might disagree.

      --
      Post may contain irony: discontinue use if experiencing mood swings, nausea or elevated blood pressure.
  4. How to solve patent problems in 3 easy steps by Haedrian · · Score: 4, Insightful

    Step 1 - Be a large company.

    Step 2 - Afford the world's best lawyers

    Step 3 - Sue

    No luck for the rest of us.

  5. Re:Probably not patenting your exact work by Sockatume · · Score: 4, Informative

    "The shortcomings of the prior art are overcome and additional advantages are provided through the provision of a method of facilitating management of dynamically allocated memory. The method includes, for instance, having a dynamically allocated memory buffer; and determining in real-time that an invalid access of the dynamically allocated memory buffer has occurred."

    I'm no expert on HeapCheck but that doesn't sound far removed from its basic functionality.

    --
    No kidding!!! What do you say at this point?
  6. Do not try to sue IBM by PolygamousRanchKid+ · · Score: 4, Insightful

    I had to give a deposition on the IBM / SCO case, since I had access to AIX source code, and also worked for their Linux Technology center. Damn good folks! The lawyer worked for a law firm with a 5th Avenue address in New York City. Although he talked very polite with me, I had the feeling that he could skin me alive, if necessary.

    Hey, sue IBM! No, bad idea.

    --
    Schroedinger's Brexit: The UK is both in and out of the EU at the same time!
    1. Re:Do not try to sue IBM by PseudonymousBraveguy · · Score: 4, Funny

      The IBM laywers are also known by the term of Nazgûl. It has been said they can blacken the sky with their legal arguments, if IBM so desires. So don't mess with them unless you either have a certain ring in your posession, or at least a bunch of enchanted swords.

    2. Re:Do not try to sue IBM by plover · · Score: 3, Interesting

      Hey, sue IBM! No, bad idea.

      +5 Insightful.

      I've worked with our corporate lawyers on various issues over the years. These are some of the nicest people I deal with. Off work they're soccer moms, volunteers, pilots, geocachers, just ordinary people.

      On the clock, though, they are seriously unnerving. When I'm having that conversation about the real topic, they listen to me with such intensity that it's frightening.

      I'm a bit slow to pick up on stuff like this, but eventually came to understand that they work 100% for the company, and are defending only the company's interests. That leaves 0% for concern over what happens to me. If they hear just one word that sounds like I acted without corporate approval, the tone in the room drops by 25 degrees, and the questions get a lot more personal until they satisfy themselves that there's nothing further to pursue; or at least they leave me with the impression that it's over.

      After the interviews I feel like someone's going to slip in behind me like a buttered ninja, and end it all without my saying another word.

      In contrast, I've worked with external lawyers brought in to work specific tasks. There's definitely a different dynamic. External lawyers seem to be more interested in completing the paperwork, and less interested in what I'm saying. Or maybe they're just that much better at staying on task and not pursuing side issues unless they hear something that sounds actionable. Perhaps I'm not as scared as I should be!

      --
      John
    3. Re:Do not try to sue IBM by T+Murphy · · Score: 3, Funny

      or at least a bunch of enchanted swords

      I hear Stallman has a few.

  7. Re:Probably not patenting your exact work by arivanov · · Score: 5, Informative

    As with all patents read Claim No 1. It should contain the novel element, you cannot leave it for later. The "novelty" in this one is that you do not need to recompile the program the way original efence worked.

    However, times have changed since the days of the original Efence and things are linked dynamically at runtime on all OSes which in turn means that any LD_PRELOAD-ed Efence like debugging library which relies on OS R/W page management to control access is prior art. It satisfies literally the requirements of claim 1.

    I do not recall off the top of my head what valgrind uses, but I would not be surprised if it fits the bill. The original Efence does not - it has to be linked in.

    --
    Baker's Law: Misery no longer loves company. Nowadays it insists on it
    http://www.sigsegv.cx/
  8. Re:Probably not patenting your exact work by js3 · · Score: 2, Informative

    It seems their patent covers doing it on a per process bases plus the ability to turn it on or off in real time. Either way MS does have a similar thing in windows 7

    --
    did you forget to take your meds?
  9. Much prior art. by Ancient_Hacker · · Score: 5, Informative

    Back in 1990, I redid the Borland Pascal memory allocator so each block was given its own hardware-protected segment descriptor and length. Worked magnificently, as any reference outside a valid block would immediately fault. Only prob, you could only allocate about 4000 blocks as there were only 4,096 entries in the hardware segment table. So the next refinement was to allocate each block with short pre and postambles set to $12345678 and check thee for overwriting periodically. Worked almost as well, if not so immediately finding the errors.

    And no, I did not try to patent this, as I knew the Burroughs machines, since 1961, allocated a fresh memory-protected segment for each array, and using pre and post safety zones sure sounded like an "obvious" thing to do..

  10. Doesn't Look as if IBM really patented his work. by Bruce+Perens · · Score: 4, Informative

    I am busy this week and have not been able to look at the patent. However, if IBM referenced this person's work in the prior art section of the patent, they are admitting that his work IS prior art, and is not subject of the patent. The issue then becomes, do any of the PATENT CLAIMS (not the summary) claim art that is exercised in his program.

    Electric Fence is listed as prior art in two ATT patents. When they saw it, they refrained from including two claims they otherwise would have, because I had precedence. The ATT patents should have expired by now.

    I doubt there's anything to worry about in this specific case. However, software patents in general present a severe problem. [Oops - previously submitted this as AC. Sorry]

  11. Re:Doesn't Look as if IBM really patented his work by KamuZ · · Score: 4, Informative

    Actually in another post by Sockatume pointed the USPTO examiner is the one mentioning his website and not IBM.

    (for some reason I cannot link the article)

  12. They aren't claiming your invention. by John+Hasler · · Score: 4, Insightful

    They are claiming an improvement on your invention. That's why they reference it.

    --
    Warning: this article may contain humor, sarcasm, parody, and perhaps even irony. Read at your own risk.
    1. Re:They aren't claiming your invention. by ttsiod · · Score: 3, Informative

      I am a coder, not a lawyer - and from reading the patent's claims, I can see only one thing that was not in HeapCheck, but which DID exist in Electric Fence: the ability to enable heap checks at runtime, without recompilation. Electric Fence allowed one to do that via LD_PRELOAD, so I am sorry, but I stand by what I said - I can see nothing in there that didn't exist in either Efence or my HeapCheck.

    2. Re:They aren't claiming your invention. by The+Empiricist · · Score: 3, Informative

      I can see only one thing that was not in HeapCheck, but which DID exist in Electric Fence: the ability to enable heap checks at runtime, without recompilation. Electric Fence allowed one to do that via LD_PRELOAD

      But this patent requires the ability to set allocaiton mode in real-time without requiring recompiling, linking, or loading. Using LD_PRELOAD to link to the Electric Fence library would still be an instance of requiring (dynamic) linking and loading. Someone else suggested that enabling/disabling application configuration settings at runtime might be an obvious modification to HeapCheck. That may be the case, but there is a difference between something that is not new (i.e., it has already been done before) and something that is obvious (i.e., it has not been done before, but it really isn't new enough).

      If someone actually gets sued or is threatened by this patent, then the courts will get a chance to consider whether the Patent Office erroneously allowed the patent. Alternatively, if you want to get together with some of your buddies, you could file a request for reexamination (the filing fee is only $2,250.00, less than $23 each for 100 angry /.ers). Perhaps the Patent Office will take another look at the claims and reject them based on some insight that you provide.

    3. Re:They aren't claiming your invention. by jc42 · · Score: 2, Interesting

      ... from reading the patent's claims, I can see only one thing that was not in HeapCheck, but which DID exist in Electric Fence: the ability to enable heap checks at runtime, without recompilation. Electric Fence allowed one to do that via LD_PRELOAD, so I am sorry, but I stand by what I said - I can see nothing in there that didn't exist in either Efence or my HeapCheck.

      It sounds like, if I were to implement the algorithm in a compiled language such as C or C++, I wouldn't have to worry about IBM's patent. But if I were to recode it in a very similar language such as java, perl or python that does run-time compilation, it would be a violation of IBM's patent.

      So what IBM has actually patented is the run-time compilation of languages like java, perl or python. I'd wonder how this makes for any sort of "innovation" or improvement of the algorithm on IBM's part. Or is IBM just trying to lay claim to coding in languages that "don't need recompilation" because they compile code dynamically at runtime? If so, any work being in such languages may be at serious risk when they are used to implement public-domain and GPL'd algorithms.

      I wonder what would happen if I (or IBM) were to apply for a patent on the concept of array bounds checking without recompilation (which java, perl and python do, and other languages did back in the 1970s) ...

      --
      Those who do study history are doomed to stand helplessly by while everyone else repeats it.
  13. Re:Doesn't Look as if IBM really patented his work by Bruce+Perens · · Score: 3, Interesting

    Wow, an examiner actually found prior art! Of course, that's what they're supposed to do... I'll have time to decompose the claims next week. If anyone wants to do it this week, go ahead.

  14. FSF by snookiex · · Score: 2, Informative

    You could contact the FSF. They have a legal department that can help you with this.

    --
    Open Source Network Inventory for the masses! Kuwaiba
  15. Re:Probably not patenting your exact work by ObsessiveMathsFreak · · Score: 2, Funny

    Indeed. Their extension uses the IBM logo.

    --
    May the Maths Be with you!
  16. Tag: Jews? by Trip6 · · Score: 2, Insightful

    I'm not Jewish, but do we really need a tag for this story that says "Jews?" Stereotype much?

    --
    I hate being bipolar; it's awesome!
  17. Listing References as Prior Art by Compulawyer · · Score: 2, Informative

    If a reference is listed in the prior art section of a patent, that means that a patent examiner felt that the reference was pertinent, but that the *claimed invention* was sufficiently *different* from the prior art reference so as to be patentable. God was the only one who ever created something from nothing. Everyone else has had to build off what was already here - including previous versions of software. The phrase *claimed invention* is key here. To properly evaluate a patent, you must focus on the claims at the end. If a patent issued over prior art, the general rule is that there is some feature recited in the claims that is not disclosed in the prior art. You can argue whether the examiner was wrong, but it is virtually never the case that someone saw someone else's invention and then decided to get a patent on the exact same thing.

    --

    Laws affecting technology will always be bad until enough techies become lawyers.

  18. Re:Probably not patenting your exact work by wmelnick · · Score: 4, Informative

    Not at all. It is standard in the patent world to make the thing that you actually want to patent be the middle claim. The reasons are many and varied, but you can jump right to the thing that any company actually wants to get the patent upon by checking the center claim. There are 20 claims here, so it is likely this one: 10. The method of claim 1, further comprising: detecting that another allocation mode is to be used to allocate one or more buffers for the process; and dynamically deactivating the allocation mode that enables the determining in real-time, wherein the dynamically deactivating includes turning off an indicator in the process to deactivate the allocation mode, and wherein another dynamically allocated memory buffer for the process is allocated based on the another allocation mode, said another dynamically allocated memory buffer being allocated without additional memory as a guard.

  19. Re:I Bet What Happened by O('_')O_Bush · · Score: 2, Informative

    You clearly have no idea how any large engineering company works.

    First, no employee can just go out and file a patent, they sign that right away when they join a company like IBM.

    Secondly, it's the legal department of IBM that would file a patent, the employee would just submit a proposal. The legal department meticulously goes through the proposal claims just as a patent office would to avoid scenarios like what the OP is implying.

    Thirdly, the employee only makes a bonus once the patent is granted, not on the submission of a proposal, such that there is NO incentive for submitting stolen or invalid patent proposals.

    What is happening here is that the OP doesn't understand what IBM patented. IBM patented an improvement of the OPs invention and specifically claims that they are NOT patenting the OPs invention.

    --
    while(1) attack(People.Sandy);
  20. Backwards: US is really first to invent by Theaetetus · · Score: 3, Informative
    Your post is entirely backwards. The US is actually a first-to-invent country, and one of the very few. The majority of the rest of the world uses a first-to-file system, but because the Constitution references "inventors", Congress decided that it would be unconstitutional to grant patents to someone who merely filled out paperwork. This is why, in the US, the applicant is the inventor while in Europe, for example, the applicant is usually a corporation.

    You reference Edison for proof that the US is a first-to-file system... But did you read your link?

    Edison fared no better back home in the U.S., where the U.S. Patent Office already ruled, on October 8, 1883, that Edison's patents were invalid, because he based them upon the earlier art of a gentleman named William Sawyer.

    I think, based on your links to the lightbulb and the telephone, that you don't actually understand how patents work... Patents cover the claims, no more, no less. As a result, there are frequently new inventions that are improvements on earlier work that are valid because the claims claim the improvement. For example, there have been literally thousands of patents relating to lightbulb technology, but they don't all say, "I claim, 1. A lightbulb." Instead, each claims specific improvements, such as this one from 1998:

    1. A light bulb, comprising: a housing configured to fit at least one of a halogen, incandescent and fluorescent light fixture; an illumination source including a plurality of light emitting diodes (LEDs); a processor coupled to the illumination source and controlling current to the plurality of LEDs to generate color within a color spectrum, wherein the illumination source and the processor are disposed within the housing; and, at least one of a receiver and a transmitter coupled to the processor for respectively receiving or transmitting a data signal from an external device.

    If you just look at the titles of patent applications, you wouldn't realize this, however. That claim is from a patent titled "smart light bulb", so not understanding that the titles are legally irrelevant would lead to complaints that the patent office was allowing someone to patent things that had already been invented before.

  21. MOD PARENT DOWN! by raftpeople · · Score: 4, Informative

    Nothing in your explanation describes why such simple coding (for someone with experience) should be patentable. The USPTO does "suck ass" because they allow patents that are pretty straightforward for any skilled practitioner.

  22. Re:Probably not patenting your exact work by orgelspieler · · Score: 4, Insightful

    I hope you were trying to be funny.

    Here's how it works: the novel, non-obvious kernel of a patent is called the independent claim (or claims). Independent claims don't refer to any other claim. Any claim that refers to another claim is called a dependent claim. If you infringe on one of them, you also infringe on the independent claim. Therefore, the independent claims are the main ones that you have to focus on first.

    Inventors add dependent claims in an attempt to keep somebody from building a new patent on the independent claim. Sometimes, these extended claims make the original invention much more interesting or marketable, but they still depend on the core concept in the independent claim. It has nothing to do with hiding the heart of your invention under a pile of meaningless legalese. I'm sure it seems like that to the untrained eye, though.

    I am not a lawyer, but I am an engineer that has successfully defended my company against a frivolous patent suit.